亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

利用原生JS實現data方法示例代碼

2024-05-06 16:51:31
字體:
來源:轉載
供稿:網友

前言

在開發中經常會在DOM上存儲一些自定義數據,我們可以通過setAttribute方法來實現。但是當數據為引用類型時,存儲后的數據卻無效。這里將用原生的JSdata方法進行實現。

使用setAttribute:

<div id="test-data"></div><p class="test-data-list"></p><p class="test-data-list"></p><p class="test-data-list"></p><p class="test-data-list"></p>
var testData = document.querySeletor('#test-data');testData.setAttribute('baukh', {a:1,b:2})// 執行后DOM節點變化為<div baukh="[object Object]"></div>testData.getAttribute('baukh'); // => "[object Object]"

可以從上面的代碼中看出,存進去的是個Object,取出來的是Object.toString()所產出的字符串。

分析

在JS經典類庫-jQuery中存在data方法是通過jQuery.cache的方式進行數據存儲,那么還有沒有其它方法可以實現?

由于使用場景不同,我想實現的方式是將數據直接存儲到DOM節點上,以達到使用時更方便簡捷的目的。

那如何存儲? 變量testData存儲的是通過document.querySeletor('#test-data')獲取到的Element,而Element是Object的一個實例。通過[testData instanceof Object]可以進行驗證。

那么一切都簡易了,即然是Object類型,那么就可以隨意的增刪自定義屬性。

通過在Element的原型上增加data方法來實現DOM擴展

Element.prototype.data = function(key, value){ var _this = this,  _dataName = 'testData', // 存儲至DOM上的對象標記, 這里只是測試用名  _data = {}; // 未指定參數,返回全部 if(typeof key === 'undefined' && typeof value === 'undefined'){  return _this[_dataName]; } // setter if(typeof(value) !== 'undefined'){  // 存儲值類型為字符或數字時, 使用attr執行  var _type = typeof(value);  if(_type === 'string' || _type === 'number'){   _this.setAttribute(key, value);  }  _data = _this[_dataName] || {};  _data[key] = value;  _this[_dataName] = _data;  return this; } // getter else{  _data = _this[_dataName] || {};  return _data[key] || _this.getAttribute(key); }};

這里來試一下:

var testData = document.querySelector('#test-data');// 字符串類型測試testData.data('name', 'baukh');console.log(testData.data('name')); // => 'baukh'// 對象類型測試testData.data('info', {'name': 'baukh', 'age': 27});console.log(testData.data('info')); // => Object {name: "baukh", age: 27}

解決NodeList存儲

現在還有一個問題, 通過Element.prototype綁定的方法只支持Element類生效,而對NodeList類并無效果.

可以通過下面這些代碼進行效果測試:

var testDataList = document.querySelectorAll('.test-data-list'); // 獲取的為NodeList 而非 ElementtestDataList.data('name', 'baukh'); // Uncaught TypeError: testDataList.data is not a function

這肯定不是想要的結果, 那么NodeList類就需要如下處理:

NodeList.prototype.data = function (key, value) { // setter if(typeof(value) !== 'undefined'){  [].forEach.call(this, function (element, index) {   element.data(key, value);  });  return this; } // getter else{  return this[0].data(key, value); // getter 將返回第一個 }};

來測試下NodeList類的data實現:

var testDataList = document.querySelectorAll('.test-data-list'); // 獲取的為NodeList 而非 ElementtestDataList.data('name', 'baukh'); // Uncaught TypeError: testDataList.data is not a function// 字符串類型測試testDataList.data('name', 'baukh');console.log(testDataList.data('name')); // => 'baukh'// 對象類型測試testDataList.data('info', {'name': 'baukh', 'age': 27});console.log(testDataList.data('info')); // => Object {name: "baukh", age: 27}

這樣就功能上就完成了.

當然也可以將NodeList與Element進行互換, 具體情況具體考慮.

很簡單不是嗎?

順帶說一下,Array類型的數據,也可以增加自定義屬性。

var ar = [1,2,3];console.log(ar instanceof Object); //true 能添加自定義屬性的原因就在這里,Array也是Object的實例。ar.test1 = {a:1,b:2};console.log(ar); //[1, 2, 3, test1: Object]console.log(ar.test1); //Object {a: 1, b: 2}

隨筆一行

這是前端最好的時代, 這也是前端最壞的時代。 眾多前端框架滿天飛,隨著 jQuery 在前端行業的慢慢弱化,總是會有一種斯人遠去,何者慰籍的感覺。互勉吧,各位。

另推薦個表格組件gridManager

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人亚洲综合青青| 久久久久久久久久久国产| 亚洲国产精品热久久| 日韩欧美在线第一页| 亚洲国产成人精品久久久国产成人一区| 国产成人短视频| 欧美在线一级va免费观看| 国产精品美女免费视频| 久久久久国产精品www| 中文字幕亚洲一区在线观看| 久久精品久久久久久国产 免费| 精品视频在线播放色网色视频| 国产精品一区专区欧美日韩| 日韩中文字幕第一页| 国产日韩欧美电影在线观看| 亚洲一区二区久久| 日韩电影大全免费观看2023年上| 国产国语刺激对白av不卡| 亚洲精品免费av| 欧美高清无遮挡| 亚洲理论片在线观看| 国产一区二区丝袜| 精品久久久久久久久久国产| 久久久久国色av免费观看性色| 欧美国产在线视频| 精品国产欧美一区二区三区成人| 亚洲色图15p| 欧美成人精品三级在线观看| 亚洲性线免费观看视频成熟| 亚洲国产高清自拍| 国产一区二区成人| 久久伊人91精品综合网站| 羞羞色国产精品| 欧美电影在线观看高清| 亚洲电影中文字幕| 国产在线观看精品一区二区三区| 欧美一级片在线播放| 国产精品久久在线观看| 日韩在线视频线视频免费网站| 中文字幕成人在线| 欧美黑人国产人伦爽爽爽| 中文字幕精品网| 欧美精品videossex性护士| 亚洲精品mp4| 亚洲韩国青草视频| 国产精品高清网站| 精品日韩视频在线观看| 国产一区二区欧美日韩| 日韩动漫免费观看电视剧高清| 国产精品视频永久免费播放| 久久久久久有精品国产| 亚洲精品资源美女情侣酒店| 91亚洲永久免费精品| 在线看国产精品| 久久久电影免费观看完整版| 久久精品国产久精国产思思| 日本高清+成人网在线观看| 欧美日韩国产一区二区| 精品久久香蕉国产线看观看亚洲| 色综合导航网站| 国内精品一区二区三区四区| 欧美精品做受xxx性少妇| 91av免费观看91av精品在线| 九九久久久久久久久激情| 国产精品自在线| 亚洲人成电影网站色…| 成人中心免费视频| 亚洲欧洲美洲在线综合| 亚洲精品白浆高清久久久久久| 久久久国产一区二区三区| 日韩欧美高清在线视频| 日韩有码视频在线| 亚洲欧美日韩图片| 91深夜福利视频| 国产成+人+综合+亚洲欧美丁香花| 欧美孕妇孕交黑巨大网站| 欧美视频中文在线看| 在线电影欧美日韩一区二区私密| 欧美中文字幕在线播放| 亚洲欧洲成视频免费观看| 一本色道久久综合狠狠躁篇怎么玩| 亚洲精品国产精品国自产观看浪潮| 日本中文字幕成人| 国产亚洲日本欧美韩国| 最近2019中文字幕mv免费看| 欧美成人在线影院| 欧美激情亚洲国产| 视频直播国产精品| 国产成人久久久精品一区| 精品视频偷偷看在线观看| 欧美亚洲视频在线观看| 亚洲人午夜精品| 国产91精品最新在线播放| 久久久91精品国产一区不卡| 亚洲欧美日韩精品久久亚洲区| 亚洲午夜未满十八勿入免费观看全集| 国产精品视频免费在线观看| 中文字幕精品国产| 欧美精品精品精品精品免费| 爱福利视频一区| 色综合久久久久久中文网| 精品成人久久av| 欧美日韩性视频| 国产成人亚洲综合| 午夜精品久久久99热福利| 欧美丰满少妇xxxxx| 久久成人综合视频| 久久亚洲精品视频| 国产精品免费一区二区三区都可以| 亚洲欧美综合另类中字| 丝袜美腿精品国产二区| 97av在线视频免费播放| 亚州精品天堂中文字幕| 欧美性猛交xxxx黑人| 亚洲www永久成人夜色| 欧美乱大交xxxxx| 国产a∨精品一区二区三区不卡| 青草热久免费精品视频| www.亚洲一二| 亚洲激情中文字幕| 中文字幕在线精品| 欧美大片网站在线观看| 国产午夜精品免费一区二区三区| 97成人超碰免| 中文字幕精品久久久久| 久久人91精品久久久久久不卡| 91国自产精品中文字幕亚洲| 97在线看免费观看视频在线观看| 中文字幕久热精品视频在线| 国产精品成人观看视频国产奇米| 欧美视频中文字幕在线| 91精品国产91久久久久| 91免费福利视频| 欧美人成在线视频| 人九九综合九九宗合| 日本欧美一二三区| 久久精品中文字幕免费mv| 欧美黑人狂野猛交老妇| 国产精品久久久久影院日本| 久久伊人精品视频| 国产一区二区免费| 欧洲成人性视频| 国产性猛交xxxx免费看久久| 久久久日本电影| 国产亚洲视频在线观看| 亚洲第一免费播放区| 日韩精品一区二区视频| 韩国国内大量揄拍精品视频| 91亚洲一区精品| 久久综合国产精品台湾中文娱乐网| 亚洲成色999久久网站| 亚洲第一福利网站| 亚州国产精品久久久| 国内精品视频久久| 国产主播喷水一区二区| 欧美日韩一区免费| 国产偷国产偷亚洲清高网站| 久久久视频免费观看| 欧美激情精品久久久久久大尺度| 欧美日韩中文字幕综合视频| 精品一区二区三区三区| 91精品国产自产在线老师啪| 欧美综合国产精品久久丁香| 欧洲成人免费aa|