国产精品久av福利在线观看_亚洲一区国产精品_亚洲黄色一区二区三区_欧美成人xxxx_国产精品www_xxxxx欧美_国产精品久久婷婷六月丁香_国产特级毛片

錦州市廣廈電腦維修|上門維修電腦|上門做系統(tǒng)|0416-3905144熱誠服務,錦州廣廈維修電腦,公司IT外包服務
topFlag1 設為首頁
topFlag3 收藏本站
 
maojin003 首 頁 公司介紹 服務項目 服務報價 維修流程 IT外包服務 服務器維護 技術文章 常見故障
錦州市廣廈電腦維修|上門維修電腦|上門做系統(tǒng)|0416-3905144熱誠服務技術文章
Object.defineProperty()詳解

作者: 佚名  日期:2024-01-16 11:29:23   來源: 本站整理

         在園子里看到一篇講解Object.defineProperty()的非常好的博文,我把他轉(zhuǎn)載過來,給自己留個筆記。原文出處https://www.cnblogs.com/junjun-001/p/11761252.html#commentform

  菜菜: “老大,那個, Object.defineProperty 是什么鬼?”

  假設我們有個對象 user ; 我們要給它增加一個屬性 name , 我們會這么做  

1 var user = {}; 2 user.name="狂奔的蝸牛"; 3 console.log(user);//{name: "狂奔的蝸牛"}

  如果想要增加一個sayHi方法叻?  

1 user.sayHi=function () { console.log("Hi !") }; 2 console.log(user);//{name: "狂奔的蝸牛", sayHi: ƒn}

  Object.defineProperty 就是做這個的

  那么Object.defineProperty 怎么用?

  Object.defineProperty 需要三個參數(shù)(object , propName , descriptor)

  1 object 對象 => 給誰加
2 propName 屬性名 => 要加的屬性的名字 【類型:String】
3 descriptor 屬性描述 => 加的這個屬性有什么樣的特性【類型:Object】

  那么descriptor這個是個對象 ,他有那些屬性呢 ? 別著急我們一個一個說;

  既然可以給一個對象增加屬性,那么我們用它來做一下給 user添加 name屬性,代碼是這樣的  

1 var user = {}; 2 Object.defineProperty(user,"name",{ 3  value:"狂奔的蝸牛"
4 }) 5 console.log(user);//{name: "狂奔的蝸牛"}

  說明 是的還是那個經(jīng)典的value屬性,他就是設置屬性值的。

  等等,屬性值只能為字符串嗎?我們的 number function Object boolean 等呢?  

 1 var user = {};  2 Object.defineProperty(user,"name",{  3  value:"狂奔的蝸牛"
 4 })  5 Object.defineProperty(user,"isSlow",{  6  value:true
 7 })  8 Object.defineProperty(user,"sayHi",{  9  value:function () { console.log("Hi !") } 10 }) 11 Object.defineProperty(user,"age",{ 12  value:12
13 }) 14 Object.defineProperty(user,"birth",{ 15  value:{ 16   date:"2018-06-29", 17   hour:"15:30"
18  } 19 }) 20 console.log(user);

   

   說明 事實證明任何類型的數(shù)據(jù)都是可以的哦~

  問題又來了,如果 user對象已經(jīng)有了name屬性,我們可以通過Object.defineProperty改變這個值嗎?

  我們來試試

1 var user = {}; 2 Object.defineProperty(user,"name",{ 3  value:"狂奔的蝸牛"
4 }) 5 console.log(user); 6 user.name="新=>狂奔的蝸牛"
7 console.log(user);

  咦??為什么我改了沒作用勒??

  原因:上邊說了descriptor有很多屬性,除了value屬性還有個 writable【顧名思義屬性是否可以被重新賦值】接受數(shù)據(jù)類型為 boolean(默認為false) true => 支持被重新賦值 false=>只讀

  哦哦,原來如果我沒設置writable值的時候就默認只讀啊,所以才改不掉

  那我們看看,設置為true,是不是就可以改掉了。

1 var user = {}; 2 Object.defineProperty(user,"name",{ 3  value:"狂奔的蝸牛", 4  writable:true
5 }) 6 console.log(user); 7 user.name="新=>狂奔的蝸牛"
8 console.log(user);

 

  這個descriptor還有其他的屬性嗎?enumerable【顧名思義屬性是否可以被枚舉】接受數(shù)據(jù)類型為 boolean(默認為false) true => 支持被枚舉 false=>不支持

 

  額。。。枚舉??什....什么意思?

  假設我們想知道這個 user對象有哪些屬性我們一般會這么做   

 1 var user ={  2  name:"狂奔的蝸牛",  3  age:25
 4 } ;  5  
 6 //es6
 7 var keys=Object.keys(user)  8 console.log(keys);// ['name','age']
 9 //es5
10 var keys=[]; 11 for(key in user){ 12  keys.push(key); 13 }  14 console.log(keys);// ['name','age'] 

  如果我們使用 Object.的方式定義屬性會發(fā)生什么呢?我們來看下輸出

 1 var user ={  2  name:"狂奔的蝸牛",  3  age:25
 4 } ;  5 //定義一個性別 可以被枚舉
 6 Object.defineProperty(user,"gender",{  7  value:"男",  8  enumerable:true
 9 }) 10  
11 //定義一個出生日期 不可以被枚舉
12 Object.defineProperty(user,"birth",{ 13  value:"1956-05-03", 14  enumerable:false
15 }) 16  
17 //es6
18 var keys=Object.keys(user) 19 console.log(keys); 20 // ["name", "age", "gender"]
21  
22 console.log(user); 23 // {name: "狂奔的蝸牛", age: 25, gender: "男", birth: "1956-05-03"}
24 console.log(user.birth); 25 // 1956-05-03 

  說明 很明顯,我們定義為 enumerable=falsebirth屬性并沒有被遍歷出來,遍歷 => 其實就是枚舉(個人理解啦,不喜勿噴哦~)

  總結 enumerable 屬性取值為 布爾類型 true | false 默認值為 false,為真屬性可以被枚舉;反之則不能。此設置不影響屬性的調(diào)用和 查看對象的值。

  configurable 是接下來我們要講的一個屬性,這個屬性有兩個作用:

  1 屬性是否可以被刪除
2 屬性的特性在第一次設置之后可否被重新定義特性

 1 var user ={  2  name:"狂奔的蝸牛",  3  age:25
 4 } ;  5 //定義一個性別 不可以被刪除和重新定義特性
 6 Object.defineProperty(user,"gender",{  7  value:"男",  8  enumerable:true,  9  configurable:false
10 }) 11  
12 //刪除一下
13 delete user.gender; 14 console.log(user);//{name: "狂奔的蝸牛", age: 25, gender: "男"}
15  
16 //重新定義特性
17 Object.defineProperty(user,"gender",{ 18  value:"男", 19  enumerable:true, 20  configurable:true
21 }) 22 // Uncaught TypeError: Cannot redefine property: gender
23 //會報錯,如下圖

  

 

 

   設置為 true

 1 var user ={  2  name:"狂奔的蝸牛",  3  age:25
 4 } ;  5 //定義一個性別 可以被刪除和重新定義特性
 6 Object.defineProperty(user,"gender",{  7  value:"男",  8  enumerable:true,  9  configurable:true
10 }) 11  
12 //刪除前
13 console.log(user); 14 // {name: "狂奔的蝸牛", age: 25, gender: "男"}
15  
16 //刪除一下
17 delete user.gender; 18 console.log(user); 19 // {name: "狂奔的蝸牛", age: 25}
20  
21 //重新定義特性
22 Object.defineProperty(user,"gender",{ 23  value:"男", 24  enumerable:true, 25  configurable:false
26 }) 27  
28 //刪除前
29 console.log(user); 30 // {name: "狂奔的蝸牛", age: 25, gender: "男"}
31 //刪除一下 刪除失敗
32 delete user.gender; 33 console.log(user); 34 // {name: "狂奔的蝸牛", age: 25, gender: "男"}

  總結 configurable設置為 true 則該屬性可以被刪除和重新定義特性;反之屬性是不可以被刪除和重新定義特性的,默認值為false(Ps.除了可以給新定義的屬性設置特性,也可以給已有的屬性設置特性哈

  最后我們來說說,最重要的兩個屬性 setget(即存取器描述:定義屬性如何被存取),這兩個屬性是做什么用的呢?我們通過代碼來看看

 1 var user ={  2  name:"狂奔的蝸牛"
 3 } ;  4 var count = 12;  5 //定義一個age 獲取值時返回定義好的變量count
 6 Object.defineProperty(user,"age",{  7  get:function(){  8   return count;  9  } 10 }) 11 console.log(user.age);//12
12  
13 //如果我每次獲取的時候返回count+1呢
14 var user ={ 15  name:"狂奔的蝸牛"
16 } ; 17 var count = 12; 18 //定義一個age 獲取值時返回定義好的變量count
19 Object.defineProperty(user,"age",{ 20  get:function(){ 21   return count+1; 22  } 23 }) 24 console.log(user.age);//13

  接下來我不用解釋了吧,你想在獲取該屬性的時候?qū)χ底鍪裁措S你咯~

  來來來,我們看看 set,不多說上代碼

 1 var user ={  2  name:"狂奔的蝸牛"
 3 } ;  4 var count = 12;  5 //定義一個age 獲取值時返回定義好的變量count
 6 Object.defineProperty(user,"age",{  7  get:function(){  8   return count;  9  }, 10  set:function(newVal){ 11   count=newVal; 12  } 13 }) 14 console.log(user.age);//12
15 user.age=145; 16 console.log(user.age);//145
17 console.log(count);//145
18  
19 //等等,如果我想設置的時候是 自動加1呢?我設置145 實際上設置是146
20  
21 var user ={ 22  name:"狂奔的蝸牛"
23 } ; 24 var count = 12; 25 //定義一個age 獲取值時返回定義好的變量count
26 Object.defineProperty(user,"age",{ 27  get:function(){ 28   return count; 29  }, 30  set:function(newVal){ 31   count=newVal+1; 32  } 33 }) 34 console.log(user.age);//12
35 user.age=145; 36 console.log(user.age);//146
37 console.log(count);//146

  說明 注意:當使用了getter或setter方法,不允許使用writable和value這兩個屬性(如果使用,會直接報錯滴)

  get 是獲取值的時候的方法,類型為 function ,獲取值的時候會被調(diào)用,不設置時為 undefined

  set 是設置值的時候的方法,類型為 function ,設置值的時候會被調(diào)用,undefined

  get或set不是必須成對出現(xiàn),任寫其一就可以

 1 var user ={  2  name:"狂奔的蝸牛"
 3 } ;  4 var count = 12;  5 //定義一個age 獲取值時返回定義好的變量count
 6 Object.defineProperty(user,"age",{  7  get:function(){  8   console.log("這個人來獲取值了!!");  9   return count; 10  }, 11  set:function(newVal){ 12   console.log("這個人來設置值了!!"); 13   count=newVal+1; 14  } 15 }) 16 console.log(user.age);//12
17 user.age=145; 18 console.log(user.age);//146

  

 

   【完結】

  Object.defineProperty方法直接在一個對象上定義一個新屬性,或者修改一個已經(jīng)存在的屬性, 并返回這個對象



熱門文章
  • 如何在Windows中查看進程啟動時間?...
  • Window清除mysql注冊表
  • 如何設置 JavaScript 日期格式
  • Object.defineProperty()詳解
  • 理解HTTP協(xié)議頭中的Vary
  • js逆向·找到登錄時目標網(wǎng)站的加密...
  • 個人總結 – JS逆向解析[通俗易懂]...
  • 利用Promise自定義一個GET請求的函...
  • 電腦黑屏按ctrl+alt+delete沒反應怎...
  • 開機電腦沒反應只有鼠標能動的解決...
  • 停車后發(fā)動機艙異響是什么原因,解...
  • Win11右鍵怎么恢復原來的模樣?圖文...
  • 錦州廣廈電腦上門維修

    報修電話:13840665804  QQ:174984393 (聯(lián)系人:毛先生)   
    E-Mail:174984393@qq.com
    維修中心地址:錦州廣廈電腦城
    ICP備案/許可證號:遼ICP備2023002984號-1
    上門服務區(qū)域: 遼寧錦州市區(qū)
    主要業(yè)務: 修電腦,電腦修理,電腦維護,上門維修電腦,黑屏藍屏死機故障排除,無線上網(wǎng)設置,IT服務外包,局域網(wǎng)組建,ADSL共享上網(wǎng),路由器設置,數(shù)據(jù)恢復,密碼破解,光盤刻錄制作等服務

    技術支持:微軟等
    精品国产91乱高清在线观看| 91免费观看视频| 精品久久中文字幕久久av| 国产精品91久久久| 国产在视频线精品视频| 国产农村妇女毛片精品久久| 欧美亚洲系列| 精品久久久久久最新网址| 中文av字幕在线观看| 成人在线免费看| 欧美日韩一区二区三区在线 | 久久无码精品丰满人妻| 热re99久久国产精品| 亚洲a∨精品一区二区三区导航| 国产曰批免费观看久久久| 久久精品视频在线| 欧美一区二区三区爽大粗免费| 天天躁日日躁狠狠躁喷水| 试看120秒一区二区三区| 在线观看91视频| 欧美,日韩,国产在线| 欧美色欧美色| 亚洲午夜精品一区 二区 三区| 亚洲国产精品一区二区三区| 人妻互换一二三区激情视频| julia中文字幕久久亚洲蜜臀| 三级亚洲高清视频| 97久久久久久| 成人精品免费在线观看| 国产乱妇乱子在线播视频播放网站| 日韩成人影音| 日韩欧美在线视频| a级免费在线观看| 精品一区二区三区免费站| 欧美日韩一区二区国产| 国产亚洲精品久久久久久777 | 欧美精品三级日韩久久| 欧美一区观看| 四虎精品成人a在线观看| 国产精品久久观看| 国模私拍一区二区三区| 日本学生初尝黑人巨免费视频| 国产成人精品一区二区三区免费| 欧美日韩国产一区二区三区| 青青视频在线播放| 色视频在线看| 91豆麻精品91久久久久久| 成人中文字幕av| 黄在线免费观看| 亚洲精品视频观看| 国产理论在线播放| a毛片在线看免费观看| 精品福利一区二区三区| 久草国产精品视频| 亚洲成人三区| 麻豆精品传媒视频| 又黄又爽无遮挡| 色欧美乱欧美15图片| 国产18无套直看片| 国产九一精品| 成人黄色在线免费观看| 任你操在线观看| 中文字幕一区视频| 国精产品视频一二二区| 色在线免费观看| 久久久久国产精品免费| 91久久久久久久久久久久| 久久99国内| 日韩欧美在线观看强乱免费| 一级毛片高清视频| 91精品国产aⅴ一区二区| 日本妇乱大交xxxxx| 国产精一品亚洲二区在线视频| 香蕉视频网站入口| 久久九九热re6这里有精品| 久久一区二区三区av| 黄页网址大全在线观看| 精品香蕉在线观看视频一| 亚洲国产日韩成人综合天堂| 亚洲女人小视频在线观看| 免费一级片视频| av不卡在线观看| 黑鬼狂亚洲人videos| 欧美日韩国产亚洲一区| 日本一区二区在线视频| 91av久久| 韩国一区二区三区美女美女秀| 欧美成人高清在线| 国产精品视频xxxx| 国内外激情在线| 亚洲一区二区三区香蕉| 九色福利视频| 91国产高清在线| 亚洲s色大片| 国产精品久久久久久av福利| 三级在线播放| 欧美制服第一页| 国产区在线看| 国产精品入口免费| 91国内外精品自在线播放| 欧美精品亚洲| 欧美五码在线| 99日在线视频| 欧美在线网站| 国产福利短视频| 黑人精品欧美一区二区蜜桃| 欧美成人精品激情在线视频| 国产日韩欧美一区二区三区乱码| 成人性生活毛片| 久久人人97超碰com| 欧美 亚洲 另类 激情 另类| 亚洲成人av一区二区三区| 日韩视频www| 欧美亚洲综合网| 野外性xxxxfreexxxxx欧美| 日韩av网站导航| 亚洲有码转帖| 精品视频在线观看| 国产美女精品写真福利视频| 一区二区不卡视频| 一区二区中文| 三上悠亚作品在线观看| 一区二区三区欧美久久| 2018亚洲男人天堂| 久久久精品视频成人| av网站免费在线观看| 日本精品久久久久久久久久| 亚洲午夜激情在线| 国产成人无码av| 日韩精品一区二区三区视频 | 在线成人小视频| 成年人视频在线看| 青青草视频国产| 国产精品88av| 久久亚洲国产中v天仙www| 57pao国产精品一区| 日韩成人av在线资源| a级在线免费观看| 亚洲九九爱视频| 一级片免费看| 无码日本精品xxxxxxxxx| 国产盗摄一区二区三区| 777琪琪电影午夜理伦片| 日韩美女写真福利在线观看| 精品国产乱码久久久久久1区2匹| avtt天堂在线| 最近2019中文免费高清视频观看www99| 欧美va在线观看| 色偷偷www8888| 国产一区二区三区直播精品电影| 免费精品一区| 男人的天堂一区| 国产亚洲欧洲在线| 一区三区在线欧| 亚洲中文字幕在线观看| 性视频1819p久久| 欧美日韩福利| 一区二区三区在线|网站| 国产欧美日韩在线播放| 亚洲最新色图| 国内精品免费视频精选在线观看| 国产精品高潮视频| 久久九九国产| 激情美女网站| 欧美日韩第二页| 色婷婷综合久久久| 色成人综合网| 国产日韩在线观看一区| 91视频婷婷| 国产日韩欧美不卡在线| 欧美日本高清| 国产精品69久久久久孕妇欧美| 欧美va在线播放| 欧美电影在线观看免费| 色一情一乱一乱一区91av| 一区二区三区四区| 夜色激情一区二区| 视频91a欧美| 色妇色综合久久夜夜| 久久久久久久香蕉| 日韩一区国产二区欧美三区| 91麻豆精品激情在线观看最新| 熟妇人妻av无码一区二区三区| 九九久久九九久久| 亚洲乱码国产乱码精品精的特点| av在线电影院| 欧美性猛交xxxx乱大交hd| 欧美日韩在线精品| 日韩一区二区三区在线观看| 欧美88av| 免费一级在线观看| 久久这里只有精品9| 亚洲成人自拍视频| 亚洲国产欧美一区二区三区同亚洲| 国产精品视区| av毛片在线免费看| 亚洲黄色免费观看| 日本欧美色综合网站免费| 欧美精品一区二区三区蜜桃| 久久精品国产成人一区二区三区 |