jQuery、zepto、js常用小技巧
以下只為記錄自己工作常用的片段和心得, 如有問(wèn)題請(qǐng)指正, 多謝~
jQuery/zepto判斷元素是否存在
// 判斷長(zhǎng)度是否存在, 正確 if ($elem.length) { } // 錯(cuò)誤, 因?yàn)榭諗?shù)組也是true if ($elem) { }
合理判斷數(shù)據(jù)類(lèi)型
先看代碼:
function case(str) { return str.match(/reg/); }
看著沒(méi)問(wèn)題, 但當(dāng) str 為空(false, null等)時(shí)就掛了, 適當(dāng)?shù)臋z查讓代碼更健壯, 如:
function case(str) { return "string" === typeof str ? str.match(/reg/) : null; // 或者強(qiáng)制轉(zhuǎn)換下 return String(str).match(/reg/); } function case2(callback) { if ("function" === typeof callback) { callback(); } }
再比如, 要獲取地址欄的參數(shù):
function getQuery(key) { // 不論頁(yè)面鏈接有沒(méi)有querystring, location.search都會(huì)是字符串 // substr為了忽略?號(hào) var result = location.search.substr(1).match(new RegExp("(?:^|&)" + key + "=(.+?)(?:$|&)")); // 如果匹配成功為數(shù)組 return result ? result[1] : result; }
因?yàn)橐袛嘟Y(jié)果是否存在從而多了個(gè)變量 result , 然而可以使用默認(rèn)值替換:
function getQuery(key) { return (location.search.substr(1).match(new RegExp("(?:^|&)" + key + "=(.+?)(?:$|&)")) || ["", "我是默認(rèn)值, 因?yàn)榍懊鏋榭站偷轿伊?])[1]; }
合理try,catch
在正常情況下不推薦使用 try , 但在一些未知情況下建議使用, 比如: 異步接口成功后的數(shù)據(jù)結(jié)構(gòu)太多:
// 原判斷 success: res => { // zepto里空的200響應(yīng)也會(huì)觸發(fā)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 { // 數(shù)據(jù)處理出錯(cuò) } }
艾瑪, 判斷那么長(zhǎng), 但不判斷直接用可能會(huì)報(bào)js錯(cuò), 于是:
// 原判斷 success: res => { try { // 嘗試使用, 當(dāng)報(bào)錯(cuò)時(shí)進(jìn)入下面分支 res.data.result[0].list.forEach(); } catch (e) { // 數(shù)據(jù)處理出錯(cuò) } }
合理使用dataset
dataset 是指在 html 元素中添加的以 data-* 為名稱(chēng)的屬性字段
點(diǎn)擊查看 兼容性
使用 DOM.dataset 獲取元素的 DOMStringMap對(duì)象 , 可以直接 DOM.dataset.key = value 賦值和 delete DOM.dataset.key 刪除, 如: document.body.dataset.xxoo = 1
常用于存放一些自定義數(shù)據(jù), 如: <a href="#" rel="external nofollow" data-uid="1" data-name="xxoo">我是一個(gè)兵</a>
語(yǔ)義化更強(qiáng)
.data, .attr, .prop, dataset的區(qū)別
注: .data, .attr, .prop是 jQuery, zepto 的方法
名稱(chēng) | 描述 | 是否顯示在dom樹(shù)上 |
---|---|---|
attr | 操作 dom.getAttribute |
是 |
prop | 操作元素的 dom 屬性, 常用于選中 selected, checked 、禁用 disabled 等 |
否 |
dataset | 操作元素的節(jié)點(diǎn)數(shù)據(jù) | 是 |
對(duì)于 .data 跟庫(kù)的有關(guān), 如:
名稱(chēng) | 描述 | 是否顯示在dom樹(shù)上 |
---|---|---|
jQuery | .data(key) - 先判斷緩存對(duì)象, 不存在則獲取 attr('data-key') 并寫(xiě)入緩存到 $.cache[id].data[key] .data(key, value) - 設(shè)置緩存 |
否 |
zepto | 直接使用 .attr('data-' + key, value) |
是 |
zepto - 加載 data.js |
.data(key) - 先判斷緩存對(duì)象, 不存在則獲取 attr('data-key') .data(key, value) - 設(shè)置緩存 |
否 |
- JS截取與分割字符串常用技巧總結(jié)
- javascript 常用代碼技巧大收集
- 史上最全JavaScript常用的簡(jiǎn)寫(xiě)技巧(推薦)
- 收藏Javascript中常用的55個(gè)經(jīng)典技巧
- JavaScript中最常用的10種代碼簡(jiǎn)寫(xiě)技巧總結(jié)
- 分享Javascript中最常用的55個(gè)經(jīng)典小技巧
- JS常用函數(shù)和常用技巧小結(jié)
- javascript簡(jiǎn)寫(xiě)常用的12個(gè)技巧(可以大大減少你的js代碼量)
- JavaScript數(shù)組常用操作技巧匯總
- 7個(gè)好用的JavaScript技巧分享(譯)
相關(guān)文章
通過(guò)JQuery實(shí)現(xiàn)win8一樣酷炫的動(dòng)態(tài)磁貼效果(示例代碼)
相信大家喜歡這個(gè)界面無(wú)非也是喜歡它的動(dòng)態(tài)磁貼。剛好今天研究了一下如何通過(guò)JQuery在網(wǎng)頁(yè)上模仿這種效果,就貼出來(lái)給大家噴一下。雖然是一些很低級(jí)的技術(shù),但是也希望有需要的朋友可以參考下2013-07-07JQuery日歷插件My97DatePicker日期范圍限制
這篇文章主要介紹了JQuery日歷插件My97DatePicker日期范圍限制的相關(guān)資料,需要的朋友可以參考下2016-01-01jQuery實(shí)現(xiàn)輸入框郵箱內(nèi)容自動(dòng)補(bǔ)全與上下翻動(dòng)顯示效果【附demo源碼下載】
這篇文章主要介紹了jQuery實(shí)現(xiàn)輸入框郵箱內(nèi)容自動(dòng)補(bǔ)全與上下翻動(dòng)顯示效果,涉及jquery.autoComplete.js插件的使用,可實(shí)現(xiàn)輸入框內(nèi)容自動(dòng)補(bǔ)全的功能,附帶了完整的demo源碼供讀者下載參考,需要的朋友可以參考下2016-09-09基于jquery的文字向上跑動(dòng)類(lèi)似跑馬燈的效果
這是一個(gè)基于jquery的文字向上跑動(dòng),其效果類(lèi)似跑馬燈,在某些情況下還是比較實(shí)用的,下面與大家分享下實(shí)現(xiàn)代碼2014-09-09Javascript 驗(yàn)證上傳圖片大小[客戶(hù)端]
在做上傳圖片的時(shí)候,如果不限制上傳圖片大小,后果非常的嚴(yán)重。那么我們?cè)鯓硬趴梢越鉀Q一個(gè)棘手的問(wèn)題呢?2009-08-08