jQuery、zepto、js常用小技巧


Posted in Javascript onFebruary 12, 2017

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

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 的方法

名称 描述 是否显示在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 来操作了, 你懂的~
Javascript 相关文章推荐
javascript函数中参数传递问题示例探讨
Jul 31 Javascript
JS+CSS实现弹出全屏灰黑色透明遮罩效果的方法
Dec 20 Javascript
JavaScript中Null与Undefined的区别解析
Jun 30 Javascript
轻量级jQuery插件slideBox实现带底栏轮播(焦点图)代码
Mar 28 Javascript
将Sublime Text 3 添加到右键中的简单方法
Dec 12 Javascript
JavaScript 跨域之POST实现方法
May 07 Javascript
30分钟快速实现小程序语音识别功能
Nov 27 Javascript
在layui tab控件中载入外部html页面的方法
Sep 04 Javascript
vue动态路由:路由参数改变,视图不更新问题的解决
Nov 05 Javascript
Angular5整合富文本编辑器TinyMCE的方法(汉化+上传)
May 26 Javascript
实现一个Vue自定义指令懒加载的方法示例
Jun 04 Javascript
二维码条形码生成的JavaScript脚本库
Jul 07 Javascript
JS中如何实现Laravel的route函数详解
Feb 12 #Javascript
js输入框使用正则表达式校验输入内容的实例
Feb 12 #Javascript
浅谈js中同名函数和同名变量的执行问题
Feb 12 #Javascript
老生常谈jquery id选择器和class选择器的区别
Feb 12 #Javascript
使用jquery判断一个元素是否含有一个指定的类(class)实例
Feb 12 #Javascript
浅谈jQuery中事情的动态绑定
Feb 12 #Javascript
浅谈jQuery中的$.extend方法来扩展JSON对象
Feb 12 #Javascript
You might like
php输出xml格式字符串(用的这个)
2012/07/12 PHP
PHP框架性能测试报告
2016/05/08 PHP
php单元测试phpunit入门实例教程
2017/11/17 PHP
PHP中关于php.ini参数优化详解
2020/02/28 PHP
Javascript模块模式分析
2008/05/16 Javascript
Jquery 扩展方法
2010/05/06 Javascript
jQuery随机切换图片的小例子
2013/04/18 Javascript
使用GruntJS链接与压缩多个JavaScript文件过程详解
2013/08/02 Javascript
JQuery Highcharts 动态生成图表的方法
2013/11/15 Javascript
【经验总结】编写JavaScript代码时应遵循的14条规律
2016/06/20 Javascript
Vue.Draggable实现拖拽效果
2020/07/29 Javascript
Node层模拟实现multipart表单的文件上传示例
2018/01/02 Javascript
浅析vue深复制
2018/01/29 Javascript
React之PureComponent的使用作用
2018/07/10 Javascript
详解axios中封装使用、拦截特定请求、判断所有请求加载完毕)
2019/04/09 Javascript
基于Vue实现电商SKU组合算法问题
2019/05/29 Javascript
小程序使用watch监听数据变化的方法详解
2019/09/20 Javascript
jQuery实现开关灯效果
2020/08/02 jQuery
[01:04]DOTA2上海特锦赛现场采访 FreeAgain遭众解说围攻
2016/03/25 DOTA
Python实现统计文本文件字数的方法
2017/05/05 Python
在PyCharm中批量查找及替换的方法
2019/01/20 Python
Django 内置权限扩展案例详解
2019/03/04 Python
python用requests实现http请求代码实例
2019/10/31 Python
使用pyqt 实现重复打开多个相同界面
2019/12/13 Python
Python基于BeautifulSoup爬取京东商品信息
2020/06/01 Python
FitFlop美国官网:英国符合人体工学的鞋类品牌
2018/10/05 全球购物
什么是唯一索引
2015/07/05 面试题
专科应届生求职信
2013/11/24 职场文书
测试工程师程序员求职信范文
2014/02/20 职场文书
学校领导班子四风问题整改意见
2014/10/02 职场文书
大学生村官个人总结
2015/02/15 职场文书
员工自我工作评价
2015/03/06 职场文书
2015年爱牙日活动总结
2015/03/23 职场文书
回复函格式及范文
2015/07/14 职场文书
煤矿隐患排查制度
2015/08/05 职场文书
关于空气污染危害的感想
2015/08/11 职场文书