老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

jQuery、zepto、js常用小技巧有哪些

小編給大家分享一下jQuery、zepto、js常用小技巧有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創新互聯專業為企業提供滎陽網站建設、滎陽做網站、滎陽網站設計、滎陽網站制作等企業網站建設、網頁設計與制作、滎陽企業網站模板建站服務,十載滎陽做網站經驗,不只是建網站,更提供有價值的思路和整體網絡服務。

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
常用于存放一些自定義數據, 如: 我是一個兵
語義化更強
.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) - 設置緩存

以上是“jQuery、zepto、js常用小技巧有哪些”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創新互聯行業資訊頻道!


網站欄目:jQuery、zepto、js常用小技巧有哪些
分享URL:http://www.xueling.net.cn/article/pdicgh.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 九九有精品 | 先锋影音9porny自拍啪 | 国产一区二区极品 | 黑人巨大精品欧美一区二区 | A片粗大的内捧猛烈进出AVV | 亚洲精品国产情侣AV在线 | 福利网址 | 青青操天天干 | 日本三级免费片 | av一区在线观看 | av中文字幕在线观看第一页 | 亚洲成人日韩在线 | 国产资源视频在线观看 | 偷拍自拍在线视频 | 成人无高清96免费 | 精品国产一区二区三区麻豆 | 日韩欧美色图 | 精品国产2区 | 亚洲VA在线∨A天堂VA欧美VA | 伊人福利视频 | 99er精品视频 | 国产中文日韩欧美 | 国产女人精品视频国产灰线 | 亚洲精品成人悠悠色影视 | 2021国产精品久久精品 | 我要看特级黄色片 | 国产一级AⅤ久久无码 | 吃奶揉捏奶头高潮视频在线观看 | 国产精品一级毛片av | 久久欧美高清二区三区 | 日本性视频在线 | 91九色影院 | 日韩伦理亚洲一区 | 激情99 | 又爽又高潮的BB视频免费看 | 视频免费看在线观看 | 久久丫精品国产亚洲av | 北条麻纪在线观看aⅴ | 91久操| 精品人妻无码一区二区三区毛片 | 91麻豆国产精品 |