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 live( type, fn ) 委派事件实现
Oct 11 Javascript
jQuery+CSS 半开折叠效果原理及代码(自写)
Mar 04 Javascript
禁用Enter键表单自动提交实现代码
May 22 Javascript
jQuery实现响应浏览器缩放大小并改变背景颜色
Oct 31 Javascript
jQuery解析XML文件同时动态增加js文件的方法
Jun 01 Javascript
vue-cli如何引入bootstrap工具的方法
Oct 19 Javascript
微信小程序列表渲染功能之列表下拉刷新及上拉加载的实现方法分析
Nov 27 Javascript
微信小程序使用Promise简化回调
Feb 06 Javascript
ionic使用angularjs表单验证(模板验证)
Dec 12 Javascript
在Node.js下运用MQTT协议实现即时通讯及离线推送的方法
Jan 24 Javascript
vue项目中使用vue-layer弹框插件的方法
Mar 11 Javascript
nuxt 每个页面head标签内容设置方式
Nov 05 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 输出缓存详解
2009/06/20 PHP
php获取数组元素中头一个数组元素值的实现方法
2014/12/20 PHP
php使用PDO操作MySQL数据库实例
2014/12/30 PHP
PHP基于单例模式实现的数据库操作基类
2016/01/15 PHP
php微信开发之图片回复功能
2018/06/14 PHP
jquery 学习之二 属性相关
2010/11/23 Javascript
jQuery实现动画效果的简单实例
2014/01/27 Javascript
Javascript玩转继承(三)
2014/05/08 Javascript
jQuery多项选项卡的实现思路附样式及代码
2014/06/03 Javascript
jQuery EasyUI中DataGird动态生成列的方法
2016/04/05 Javascript
3分钟快速搭建nodejs本地服务器方法运行测试html/js
2017/04/01 NodeJs
Node.js简单入门前传
2017/08/21 Javascript
JS基于设计模式中的单例模式(Singleton)实现封装对数据增删改查功能
2018/02/06 Javascript
jQuery中的类名选择器(.class)用法简单示例
2018/05/14 jQuery
VUE实现可随意拖动的弹窗组件
2018/09/25 Javascript
深入理解 JS 垃圾回收
2019/06/03 Javascript
vue实现员工信息录入功能
2020/06/11 Javascript
vue中实现点击变成全屏的多种方法
2020/09/27 Javascript
[47:12]TFT vs Secret Supermajor小组赛C组 BO3 第三场 6.3
2018/06/04 DOTA
[55:44]OG vs NAVI 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
python中stdout输出不缓存的设置方法
2014/05/29 Python
gearman的安装启动及python API使用实例
2014/07/08 Python
Python合并字符串的3种方法
2015/05/21 Python
Python实现统计文本文件字数的方法
2017/05/05 Python
python中的迭代和可迭代对象代码示例
2017/12/27 Python
Django如何将URL映射到视图
2019/07/29 Python
Python3 翻转二叉树的实现
2019/09/30 Python
django中media媒体路径设置的步骤
2019/11/15 Python
Spark处理数据排序问题如何避免OOM
2020/05/21 Python
美国顶级户外凉鞋品牌:Chacos
2017/03/27 全球购物
Etam德国:内衣精品店
2019/08/25 全球购物
下列程序在32位linux或unix中的结果是什么
2015/01/26 面试题
民主评议政风行风活动心得体会
2014/10/29 职场文书
2015年消费者权益日活动总结
2015/02/09 职场文书
2015年环境整治工作总结
2015/05/22 职场文书
Javascript之datagrid查询详解
2021/09/15 Javascript