国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > 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

總結

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 长岛县| 澎湖县| 含山县| 正阳县| 遂溪县| 西宁市| 碌曲县| 什邡市| 烟台市| 沙雅县| 原阳县| 巴南区| 丰都县| 木里| 夏津县| 思茅市| 白朗县| 濮阳市| 闵行区| 聂拉木县| 柳林县| 积石山| 罗山县| 滦平县| 永福县| 南阳市| 贺兰县| 来凤县| 富宁县| 泰兴市| 安仁县| 新沂市| 泗阳县| 克拉玛依市| 玉树县| 桂林市| 吉水县| 镇康县| 开江县| 墨江| 永靖县|