小编给大家分享一下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
常用于存放一些自定义数据, 如: 我是一个兵
语义化更强
.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) - 设置缓存 | 否 |
以上是“jQuery、zepto、js常用小技巧有哪些”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联网站建设公司行业资讯频道!
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。