日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Object.defineProperty 详解

發布時間:2023/12/13 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Object.defineProperty 详解 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

最近想了解一下Vue是怎么實現數據雙向綁定的,了解到是基于Object.definProperty,在此記錄一下。

Object.defineProperty  顧名思義,就是給對象定義一個屬性,總共有這么幾種:

  • value  屬性的值
  • writable  是否可改寫,如果為false,就為只讀,不能重新賦值,和const差不多
  • enumerable  能否枚舉,如果設置為false則不能在for……in中出現  
  • configurable   ’配置‘,顧名思義,一旦為false,就不能再設置他的(value,writable,configurable)
  • 不能同時設置訪問器 (get 和 set) 和 wriable 或 value,否則會錯,就是說(get 和 set)和(wriable 或 value中的任何一個)只能取其一

  • get  讀取時調用這個方法
  • set  賦值時調用這個方法

?隨便寫點東西

<script>var c = {year:2017};Object.defineProperty(c,'a',{
     // 注意這里不能直接不能對a直接賦值,否則會無限回調set:
function(val){console.log(`I set the value ${val}`);},get:function(){return this}})</script>

?分別賦值和取值:

?

set的時候正確的調用了方法,但是取值的時候如果寫return this.a

就會報錯,棧溢出。看上面的圖我們就明白了,a的值指向自身,如果直接打印就會無限回調,雖然我們不能取到a,但我們能通過a取到其他屬性

修改get:

set:function(val){this.year = val }, get:function(e){return this.year }

  

 

轉載于:https://www.cnblogs.com/lastnigtic/p/6800330.html

總結

以上是生活随笔為你收集整理的Object.defineProperty 详解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。