欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jQuery、zepto、js常用小技巧

 更新時(shí)間:2017年02月12日 16:08:40   作者:前端小武  
本文給大家分享的是小編jQuery、zepto、js常用小技巧的心得,非常實(shí)用,有需要的小伙伴可以參考下

以下只為記錄自己工作常用的片段和心得, 如有問題請指正, 多謝~

jQuery/zepto判斷元素是否存在

// 判斷長度是否存在, 正確
if ($elem.length) {
}

// 錯(cuò)誤, 因?yàn)榭諗?shù)組也是true
if ($elem) {
}

合理判斷數(shù)據(jù)類型

先看代碼:

function case(str) {
  return str.match(/reg/);
}

看著沒問題, 但當(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) {
  // 不論頁面鏈接有沒有querystring, location.search都會是字符串
  // substr為了忽略?號
  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)也會觸發(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ò)
  }
}

艾瑪, 判斷那么長, 但不判斷直接用可能會報(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-* 為名稱的屬性字段
點(diǎn)擊查看 兼容性
使用 DOM.dataset 獲取元素的 DOMStringMap對象 , 可以直接 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>
語義化更強(qiáng)
.data, .attr, .prop, dataset的區(qū)別

注: .data, .attr, .prop是 jQuery, zepto 的方法

名稱 描述 是否顯示在dom樹上
attr 操作 dom.getAttribute
prop 操作元素的 dom 屬性, 常用于選中 selected, checked 、禁用 disabled 
dataset 操作元素的節(jié)點(diǎn)數(shù)據(jù)

對于 .data 跟庫的有關(guān), 如:

名稱 描述 是否顯示在dom樹上
jQuery .data(key) - 先判斷緩存對象, 不存在則獲取 attr('data-key') 并寫入緩存到 $.cache[id].data[key] 
.data(key, value) - 設(shè)置緩存
zepto 直接使用 .attr('data-' + key, value)
zepto - 加載 data.js .data(key) - 先判斷緩存對象, 不存在則獲取 attr('data-key') 
.data(key, value) - 設(shè)置緩存
有以上結(jié)論了, 那么可以根據(jù)自己的場景選擇了, 比如在 css 里有使用 div[data-xx='1'] {} 這樣的選擇器來控制樣式, 那么就得使用 .attr() 或者 dataset 來操作了, 你懂的~

相關(guān)文章

最新評論