溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Javascript中的getter和setter初識(shí)

發(fā)布時(shí)間:2020-10-19 20:06:22 來源:腳本之家 閱讀:145 作者:zzliux 欄目:web開發(fā)

前言

本文主要給大家介紹的關(guān)于Javascript中g(shù)etter和setter的相關(guān)內(nèi)容,第一次聽說這個(gè)東西的時(shí)候是vue.js里面的數(shù)據(jù)綁定,只要綁定了數(shù)據(jù),修改對(duì)象屬性可以自動(dòng)反饋到dom上,很神奇,后面也看到了文檔里面實(shí)現(xiàn)是對(duì)對(duì)象定義了getter和setter并覆蓋原屬性,索性就來總結(jié)這兩者的用法,下面話不多說了,來一起看看詳細(xì)的介紹吧。

原理

利用Object.defineProperty來重寫對(duì)象屬性為getter和setter,通過getter和setter順便改變綁定DOM節(jié)點(diǎn)的值

例子

摘自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 }]

利用這個(gè)MDN例子小小的寫了個(gè)方法并寫了個(gè)計(jì)時(shí)器的DEMO

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
</head>
<body>
  <h2 id="testTime" z:bind="time">0s</h2>
<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;
      });
    }
  }


  /*
  例子很簡單,直接改變對(duì)象屬性,就直接
  反饋到了DOM上,就好像是一個(gè)鉤子,改變
  這個(gè)對(duì)象的屬性,這個(gè)屬性的鉤子把它綁
  定的DOM的數(shù)據(jù)進(jìn)行修改
   */ 
  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

深入響應(yīng)式原理 — Vue.js

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對(duì)億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI