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

首頁 > 編程 > JavaScript > 正文

Javascript中的getter和setter初識

2019-11-19 15:45:55
字體:
來源:轉載
供稿:網友

前言

本文主要給大家介紹的關于Javascript中getter和setter的相關內容,第一次聽說這個東西的時候是vue.js里面的數據綁定,只要綁定了數據,修改對象屬性可以自動反饋到dom上,很神奇,后面也看到了文檔里面實現是對對象定義了getter和setter并覆蓋原屬性,索性就來總結這兩者的用法,下面話不多說了,來一起看看詳細的介紹吧。

原理

利用Object.defineProperty來重寫對象屬性為getter和setter,通過getter和setter順便改變綁定DOM節點的值

例子

摘自MDN

function Archiver() { var temperature = null; var archive = []; Object.defineProperty(this, 'temperature', {  get: function() {   console.log('get!');   return temperature;  },  set: function(value) {   temperature = value;   archive.push({ val: temperature });  } }); this.getArchive = function() { return archive; };}var arc = new Archiver();arc.temperature; // 'get!'arc.temperature = 11;arc.temperature = 13;arc.getArchive(); // [{ val: 11 }, { val: 13 }]

利用這個MDN例子小小的寫了個方法并寫了個計時器的DEMO

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <title>Document</title></head><body>  <h1 id="testTime" z:bind="time">0s</h1><script>  // 雙向綁定  function bind_data(ele, arg){    var bindAttributeName = 'z:bind';    var data = JSON.parse(JSON.stringify(arg)) || {};    Object.keys(arg).forEach(function(argKey, index, array){      Object.defineProperty(arg, argKey, {        get: function(){          return data[argKey];        },        set: function(value){          if(ele.getAttribute(bindAttributeName) !== argKey) {            return;          }          if(ele.tagName === 'INPUT'){            ele.value = value;          }else{            ele.innerHTML = value;          }          data[argKey] = value;        }      });      arg[argKey] = arg[argKey];    });    var key = ele.getAttribute(bindAttributeName);    if((ele.tagName === 'INPUT' || ele.tagName === 'TEXTAREA') && arg[key]){      ele.addEventListener('input', function(e){        data[key] = ele.value;      });    }  }  /*  例子很簡單,直接改變對象屬性,就直接  反饋到了DOM上,就好像是一個鉤子,改變  這個對象的屬性,這個屬性的鉤子把它綁  定的DOM的數據進行修改   */   var start = (new Date()).getTime();  var now;  var b = {time: '0s'};  bind_data(document.getElementById('testTime'), b);  setInterval(function(){    var now = (new Date()).getTime();    b.time = ((now - start)/1000) + 's'  }, 1);</script></body></html>

參考

Object.defineProperty() - JavaScript | MDN

深入響應式原理 ― Vue.js

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩在线观看你懂的| 欧美日韩国产一区二区三区| 日韩成人激情在线| 日韩精品视频在线免费观看| 欧美大尺度在线观看| xxx一区二区| 色噜噜国产精品视频一区二区| 日韩欧美中文在线| 伊人一区二区三区久久精品| 亚洲国产日韩欧美在线99| 91wwwcom在线观看| 欧美性20hd另类| 久久久之久亚州精品露出| 欧美做受高潮1| 国产精选久久久久久| 国产女精品视频网站免费| 国产日韩精品一区二区| 国产日韩在线亚洲字幕中文| xxxx欧美18另类的高清| 亚洲色图13p| 精品国产自在精品国产浪潮| 国产在线日韩在线| 黄色一区二区在线观看| 久久久精品久久久| 国产人妖伪娘一区91| 欧美日韩精品在线播放| 美女撒尿一区二区三区| 26uuu久久噜噜噜噜| 久久av红桃一区二区小说| 91久久精品视频| 久久久久久久激情视频| 亚洲国产成人精品一区二区| 7777kkkk成人观看| 黑丝美女久久久| 国产91精品视频在线观看| 亚洲第一视频在线观看| 久久久天堂国产精品女人| xxx一区二区| 欧美黄色片免费观看| 欧美性xxxxxxxxx| 国产剧情久久久久久| 国产精品福利小视频| 国语自产精品视频在线看一大j8| 国产成人拍精品视频午夜网站| 欧美激情视频网站| 国产精品2018| 色偷偷888欧美精品久久久| 亚洲欧洲日产国码av系列天堂| 欧美日韩国产精品一区二区不卡中文| 欧美在线观看视频| 日韩精品一区二区三区第95| 久久久久国产一区二区三区| 国产精品88a∨| 国产91热爆ts人妖在线| 日本欧美爱爱爱| 欧美色欧美亚洲高清在线视频| 国产偷亚洲偷欧美偷精品| 日本伊人精品一区二区三区介绍| 欧美大学生性色视频| 国产精品美女久久久久av超清| 日韩不卡在线观看| 91久久夜色精品国产网站| 丰满岳妇乱一区二区三区| 中文字幕在线亚洲| 欧美一级片在线播放| 国产精品夜色7777狼人| 久久欧美在线电影| 日韩精品免费视频| 日本国产高清不卡| www.日韩不卡电影av| 欧美日本高清视频| 亚洲午夜激情免费视频| 亚洲欧美日韩精品久久奇米色影视| 国产精品激情av电影在线观看| 色综合影院在线| 欧美日韩性生活视频| 久久视频在线观看免费| 欧美激情视频一区二区三区不卡| 亚洲大胆人体视频| 久久精品视频播放| 成人免费视频网址| 亚洲成人精品av| 欧美剧在线观看| 欧美性猛交丰臀xxxxx网站| 中文字幕国产亚洲2019| 国产日韩欧美综合| 亚洲精品理论电影| 欧美劲爆第一页| 国产一区二区三区在线观看视频| 91av在线不卡| 不卡av电影在线观看| 欧美亚洲日本黄色| 午夜精品视频网站| 亚洲一区二区中文| 日韩国产精品亚洲а∨天堂免| 日韩久久精品成人| 中文字幕av一区中文字幕天堂| 欧美国产日韩一区二区在线观看| 精品国产精品三级精品av网址| 亚洲免费电影在线观看| 国产精品久久久久久av福利| 欧美视频中文在线看| 啊v视频在线一区二区三区| 亚洲石原莉奈一区二区在线观看| 亚洲成人av片| 成人在线小视频| 狠狠色狠色综合曰曰| 久久久久久久久久久免费| 国产亚洲精品久久久| 久久国内精品一国内精品| 国产精品三级美女白浆呻吟| 欧美日韩国产va另类| 欧美激情一级精品国产| 欧美丝袜第一区| 国产玖玖精品视频| 国产亚洲人成网站在线观看| 亚洲视频视频在线| 羞羞色国产精品| 亚洲国产黄色片| 亚洲色图激情小说| 国产精品亚洲аv天堂网| 色偷偷av一区二区三区乱| 亚洲成人中文字幕| 红桃视频成人在线观看| 麻豆精品精华液| 欧美中文字幕视频在线观看| 久久久视频精品| 国产98色在线| 欧美性猛交99久久久久99按摩| 国产激情视频一区| 欧美极品少妇xxxxⅹ喷水| 成人写真视频福利网| 97视频在线观看免费高清完整版在线观看| 91精品国产高清久久久久久| 最近中文字幕mv在线一区二区三区四区| 日韩av三级在线观看| 久久精品国产亚洲精品| 久久伊人91精品综合网站| 亚洲人成电影网站色xx| 4438全国亚洲精品在线观看视频| 黑人与娇小精品av专区| 国产精品日韩电影| 成人亚洲激情网| 国产精品永久免费观看| 亚洲成人动漫在线播放| 日韩激情第一页| 亚洲精品久久久久久久久| 中文字幕综合一区| 精品福利视频导航| 亚洲黄在线观看| 日韩高清电影免费观看完整版| 亚洲男人天堂2024| 久久97久久97精品免视看| 欧美亚洲国产成人精品| 久久久久久中文字幕| 久久影院在线观看| 91热精品视频| 91影院在线免费观看视频| 国产精品海角社区在线观看| 欧美精品激情blacked18| 国产欧美最新羞羞视频在线观看| 久久国产精品首页| 亚洲跨种族黑人xxx| 日韩男女性生活视频|