以下只為記錄自己工作常用的片段和心得, 如有問題請指正, 多謝~
jQuery/zepto判斷元素是否存在
// 判斷長度是否存在, 正確if ($elem.length) {}// 錯誤, 因為空數組也是trueif ($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)- 設置緩存 | 否 | 
新聞熱點
疑難解答