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 相关文章推荐
jQuery 1.8 Release版本发布了
Aug 14 Javascript
浅析jQuery中常用的元素查找方法总结
Jul 04 Javascript
Javascript原型链和原型的一个误区
Oct 22 Javascript
10分钟掌握XML、JSON及其解析
Dec 06 Javascript
从零学习node.js之利用express搭建简易论坛(七)
Feb 25 Javascript
如何理解Vue的v-model指令的使用方法
Jul 19 Javascript
解决vue路由后界面没有变化,但是链接有的问题
Sep 01 Javascript
关于js陀螺仪的理解分析
Apr 11 Javascript
vue+echarts实现可拖动节点的折线图(支持拖动方向和上下限的设置)
Apr 12 Javascript
.netcore+vue 实现压缩文件下载功能
Sep 24 Javascript
帮你提高开发效率的JavaScript20个技巧
Jun 18 Javascript
JavaScript中的LHS和RHS分析详情
Apr 06 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
Yii学习总结之数据访问对象 (DAO)
2015/02/22 PHP
PHP常用文件操作函数和简单实例分析
2016/06/03 PHP
thinkPHP5.0框架开发规范简介
2017/03/25 PHP
Yii2汉字转拼音类的实例代码
2017/04/18 PHP
javascript 二维数组的实现与应用
2010/03/16 Javascript
window.showModalDialog参数传递中含有特殊字符的处理方法
2013/06/06 Javascript
jQuery操作属性和样式详解
2016/04/13 Javascript
jQuery实现获取元素索引值index的方法
2016/09/18 Javascript
js实现图片左右滚动效果
2017/02/27 Javascript
用vue封装插件并发布到npm的方法步骤
2017/10/18 Javascript
React操作真实DOM实现动态吸底部的示例
2017/10/23 Javascript
详解webpack + react + react-router 如何实现懒加载
2017/11/20 Javascript
Vue的watch和computed方法的使用及区别介绍
2018/09/06 Javascript
js实现坦克大战游戏
2020/02/24 Javascript
JavaScript设计模式--桥梁模式引入操作实例分析
2020/05/23 Javascript
JS简易计算器实例讲解
2020/06/30 Javascript
vue treeselect获取当前选中项的label实例
2020/08/31 Javascript
[01:10:03]OG vs EG 2018国际邀请赛淘汰赛BO3 第三场 8.23
2018/08/24 DOTA
[46:53]Secret vs Liquid 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
Python中sort和sorted函数代码解析
2018/01/25 Python
django 多数据库配置教程
2018/05/30 Python
使用OpenCV-python3实现滑动条更新图像的Canny边缘检测功能
2019/12/12 Python
tensorflow 模型权重导出实例
2020/01/24 Python
深入浅析python 中的self和cls的区别
2020/06/20 Python
Python优秀开源项目Rich源码解析的流程分析
2020/07/06 Python
深入浅析pycharm中 Make available to all projects的含义
2020/09/15 Python
俄罗斯汽车零件和配件在线商店:CarvilleShop
2019/11/29 全球购物
物流合作计划书
2014/01/10 职场文书
个人简历自我评价范文
2014/02/04 职场文书
党的群众路线教育实践活动总结报告
2014/04/28 职场文书
创先争优标语
2014/06/27 职场文书
2014学校领导四风问题对照检查材料思想汇报
2014/09/22 职场文书
2015教师年度考核评语
2015/03/25 职场文书
2016年学校综治宣传月活动总结
2016/03/16 职场文书
2017年寒假社区服务活动总结
2016/04/06 职场文书
SQL Server 数据库实验课第五周——常用查询条件
2021/04/05 SQL Server