ホームページ  >  記事  >  ウェブフロントエンド  >  Javascript のゲッターとセッターの基本入門

Javascript のゲッターとセッターの基本入門

巴扎黑
巴扎黑オリジナル
2017-08-18 10:52:561546ブラウズ

最近仕事でゲッターとセッターに遭遇しました。ゲッターは属性値を取得するメソッドであり、セッターは属性値を設定するメソッドです。以下の記事ではJavaScriptのゲッターとセッターに関する情報を中心に紹介していますので、必要な方はぜひ参考にしてみてください。

はじめに

この記事では、主に Javascript のゲッターとセッターに関連する内容を紹介します。私がこのことについて初めて聞いたのは、データがバインドされている限り、です。オブジェクト属性の変更は自動的に DOM にフィードバックされます。これは、ドキュメントの後半で、実装によってオブジェクトのゲッターとセッターが定義され、元の属性が上書きされることもわかりました。これら 2 つの使用法を簡単にまとめてみましょう。以下では詳しく説明しませんので、詳細な紹介を見てみましょう。

原則

Object.definePropertyを使用してオブジェクトのプロパティをゲッターとセッターとして書き換え、ゲッターとセッターを通じてバインドされた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 の例を使用して、小さなメソッドとタイマーのデモを書きました


<!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 = &#39;z:bind&#39;;
    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 === &#39;INPUT&#39;){
            ele.value = value;
          }else{
            ele.innerHTML = value;
          }
          data[argKey] = value;
        }
      });
      arg[argKey] = arg[argKey];
    });
    var key = ele.getAttribute(bindAttributeName);
    if((ele.tagName === &#39;INPUT&#39; || ele.tagName === &#39;TEXTAREA&#39;) && arg[key]){
      ele.addEventListener(&#39;input&#39;, function(e){
        data[key] = ele.value;
      });
    }
  }


  /*
  例子很简单,直接改变对象属性,就直接
  反馈到了DOM上,就好像是一个钩子,改变
  这个对象的属性,这个属性的钩子把它绑
  定的DOM的数据进行修改
   */ 
  var start = (new Date()).getTime();
  var now;
  var b = {time: &#39;0s&#39;};
  bind_data(document.getElementById(&#39;testTime&#39;), b);
  setInterval(function(){
    var now = (new Date()).getTime();
    b.time = ((now - start)/1000) + &#39;s&#39;
  }, 1);

</script>
</body>
</html>

以上がJavascript のゲッターとセッターの基本入門の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。