以下只为记录自己工作常用的片段和心得, 如有问题请指正, 多谢~
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) - 设置缓存 |
否 |
本文向大家介绍JS常用函数和常用技巧小结,包括了JS常用函数和常用技巧小结的使用技巧和注意事项,需要的朋友参考一下 学习和工作的过程中总结的干货,包括常用函数、常用js技巧、常用正则表达式、git笔记等。为刚接触前端的童鞋们提供一个简单的查询的途径,也以此来缅怀我的前端学习之路。 Ajax请求 jquery ajax函数 我自己封装了一个ajax的函数,代码如下: jsonp方式 有时候我们为了跨
本文向大家介绍zepto与jquery的区别及zepto的不同使用8条小结,包括了zepto与jquery的区别及zepto的不同使用8条小结的使用技巧和注意事项,需要的朋友参考一下 首先是效果: jquery中有fadeIn和fadeOut两个效果,用来实现渐隐渐显的效果,这个在PC端自然是常用的效果。然后我们前端组的组员Mr Huang自然是想到手机页面也可以更加炫丽,于是加上了登录框的渐隐效
本文向大家介绍JavaScript常用小技巧小结,包括了JavaScript常用小技巧小结的使用技巧和注意事项,需要的朋友参考一下 前言 总结一下最近接触到的JavaScript语法糖,与大家共享。 每块糖都有详细的说明和示例,就不多说了。 准确的类型检查 优雅的添加原型方法 快捷创建命名空间
本文向大家介绍Android ListView常用小技巧汇总,包括了Android ListView常用小技巧汇总的使用技巧和注意事项,需要的朋友参考一下 ListView在我们Android项目中的地位是有目共睹的,相信几乎每一个App中都有它的身影。 ListView主要是用列表形式来加载数据,在特定情况下需要实现一些特殊功能:如刷新数据,加载数据,实现动画效果等。 作为我们常用的控件,有哪些
本文向大家介绍常用的jQuery前端技巧收集,包括了常用的jQuery前端技巧收集的使用技巧和注意事项,需要的朋友参考一下 调试时巧用console.log(),这比用alert()方便多了。 jquery易错点:元素拼接的时候,元素还未添加到DOM,就用该预添加元素操作。 ajax动态获取的数据,还没有装载html元素,下面就开始用预拼凑的元素操作。 这样写,点击“提交”的时候,会报错“Unca
本文向大家介绍jquery常用操作小结,包括了jquery常用操作小结的使用技巧和注意事项,需要的朋友参考一下 页面load方法 div隐藏操作 获取对象 属性设置