jQuery技术

jQuery、zepto、js常用小技巧

字号+ 作者:H5之家 来源:H5之家 2017-04-24 10:00 我要评论( )

jQuery、zepto、js常用小技巧

以下只为记录自己工作常用的片段和心得, 如有问题请指正, 多谢~


jQuery/zepto判断元素是否存在




// 判断长度是否存在, 正确
if ($elem.length) {
}

// 错误, 因为空数组也是true
if ($elem) {
}



合理判断数据类型


先看代码:




function case(str) {
return str.match(/reg/);
}


看着没问题, 但当 str 为空(false, null等)时就挂了, 适当的检查让代码更健壮, 如:




function case(str) {
return "string" === typeof str ? str.match(/reg/) : null;

// 或者强制转换下
return String(str).match(/reg/);
}

function case2(callback) {
if ("function" === typeof callback) {
callback();
}
}



再比如, 要获取地址栏的参数:




function getQuery(key) {
// 不论页面链接有没有querystring, location.search都会是字符串
// substr为了忽略?号
var result = location.search.substr(1).match(new RegExp("(?:^|&)" + key + "=(.+?)(?:$|&)"));

// 如果匹配成功为数组
return result ? result[1] : result;
}



因为要判断结果是否存在从而多了个变量 result , 然而可以使用默认值替换:




function getQuery(key) {
return (location.search.substr(1).match(new RegExp("(?:^|&)" + key + "=(.+?)(?:$|&)")) || ["", "我是默认值, 因为前面为空就到我了"])[1];
}


合理try,catch


在正常情况下不推荐使用 try , 但在一些未知情况下建议使用, 比如: 异步接口成功后的数据结构太多:




// 原判断
success: res => {
// zepto里空的200响应也会触发success
if (res && res.data && res.data.result && res.data.result[0] && res.data.result[0].list && res.data.result[0].list.length) {
// 成功
res.data.result[0].list.forEach();
}
else {
// 数据处理出错
}
}


艾玛, 判断那么长, 但不判断直接用可能会报js错, 于是:




// 原判断
success: res => {
try {
// 尝试使用, 当报错时进入下面分支
res.data.result[0].list.forEach();
}
catch (e) {
// 数据处理出错
}
}


合理使用dataset


dataset 是指在 html 元素中添加的以 data-* 为名称的属性字段

点击查看 兼容性

使用 DOM.dataset 获取元素的 DOMStringMap对象 , 可以直接 DOM.dataset.key = value 赋值和 delete DOM.dataset.key 删除, 如: document.body.dataset.xxoo = 1

常用于存放一些自定义数据, 如: <a href="#" data-uid="1" data-name="xxoo">我是一个兵</a>

语义化更强

.data, .attr, .prop, dataset的区别


注: .data, .attr, .prop是 jQuery, zepto 的方法






名称
描述
是否显示在dom树上





attr
操作 dom.getAttribute



prop
操作元素的 dom 属性, 常用于选中 selected, checked 、禁用 disabled 



dataset
操作元素的节点数据





对于 .data 跟库的有关, 如:






名称
描述
是否显示在dom树上





jQuery
.data(key) - 先判断缓存对象, 不存在则获取 attr('data-key') 并写入缓存到 $.cache[id].data[key] 

.data(key, value) - 设置缓存



zepto
直接使用 .attr('data-' + key, value)



zepto - 加载 data.js
.data(key) - 先判断缓存对象, 不存在则获取 attr('data-key') 

.data(key, value) - 设置缓存




有以上结论了, 那么可以根据自己的场景选择了, 比如在 css 里有使用 div[data-xx='1'] {} 这样的选择器来控制样式, 那么就得使用 .attr() 或者 dataset 来操作了, 你懂的~



 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
网友点评