jQuery技术

jQuery、zepto、js应用之小技巧

字号+ 作者:H5之家 来源:H5之家 2017-03-22 09:01 我要评论( )

jQuery、zepto、js三者的应用相信大家比较熟悉了,在项目中,同一种功能or效果,可以用不同的代码来实现,这就要求我们掌握一些小技巧了,今天主要介绍三者一些实用性的技巧。 jQuery/zepto判断元素是否存在: //判断长度是否存在,正确if($elem.length){}//

20120810080914305056.JPG

jQuery、zepto、js三者的应用相信大家比较熟悉了,在项目中,同一种功能or效果,可以用不同的代码来实现,这就要求我们掌握一些小技巧了,今天主要介绍三者一些实用性的技巧。

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="#" rel="external nofollow" data-uid="1" data-name="xxoo">我是一个兵</a>
语义化更强
.data, .attr, .prop, dataset的区别

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

描述名称

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.作者投稿可能会经我们编辑修改或补充。

相关文章
  • jQuery全屏滚动插件fullPage.js

    jQuery全屏滚动插件fullPage.js

    2017-03-25 09:12

  • 常用的JS/jQuery技术和技巧

    常用的JS/jQuery技术和技巧

    2017-03-21 15:00

  • Jquery数组操作技巧 - snowfly123

    Jquery数组操作技巧 - snowfly123

    2017-03-21 14:02

  • jQuery 中的 39 个技巧 码农网

    jQuery 中的 39 个技巧 码农网

    2017-03-20 08:00

网友点评
l