jQuery、zepto、js常用小技巧

前端之家收集整理的这篇文章主要介绍了jQuery、zepto、js常用小技巧前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

jQuery/zepto判断元素是否存在

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

合理判断数据类型

先看代码:

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

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

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

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

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

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

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

合理try,catch

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

{ // 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错,于是:

{ 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 常用于存放一些自定义数据,如: nofollow" data-uid="1" data-name="xxoo">我是一个兵 语义化更强 .data,.attr,.prop,dataset的区别

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

名称属性,常用于选中

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

显示在dom树上
名称
获取

猜你在找的jQuery相关文章