以下只为记录自己工作常用的片段和心得, 如有问题请指正, 多谢~
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 "function" === typeof callback) { callback(); } }
再比如, 要获取地址栏的参数:
function getQuery(key) { // 不论页面链接有没有querystring, location.search都会是字符串 // substr为了忽略"(" + key + "=(.+")); // 如果匹配成功为数组 return result "htmlcode">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 来操作了, 你懂的~
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新动态
- 崩坏星穹铁道椒丘阵容怎么搭 崩铁椒丘组队阵容推荐
- 奥斯卡视觉奖《哥斯拉-1》,好坏参半的70周年纪念作
- 跟你走的话会被嘎蛋吗 囧图 深得自媒体新闻学的真传
- 国产游戏产业:为何手游成为新宠?
- 谭艳《再度重相逢HQ》头版限量编号[低速原抓WAV+CUE]
- ABC德国制《姚公白·三千年古琴艺术》6N纯银镀膜[低速原抓WAV+CUE]
- 群星1990-似曾相识1--2[日本天龙1A1首版][WAV+CUE]
- 《地狱潜者2》诞生大量梗图:索尼毁了一款GOTY潜力之作
- 五一档电影导演:绝不撤档!可以战死但不退
- 淘宝确认免单不是bug:是周年庆答题免单
- 鐜嬭彶銆婃垜鍜屾垜鐨勭鍥?HQCD銆媅WAV+CUE][700MB]
- 群星《宝丽金 粤语老歌珍藏·男人篇 HQCD》[WAV+CUE][590MB]
- 《张雨生3CD合集》[WAV+CUE][1.4G]
- 群星.1999-98滚石年度最卖座主打歌刷新全纪录·新台湾爱人【滚石】【WAV+CUE】
- 张碧晨.2021-时【少城时代】【FLAC分轨】