真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

js中g(shù)etter和setter用法實(shí)例分析

本文實(shí)例講述了js中g(shù)etter和setter用法。分享給大家供大家參考,具體如下:

創(chuàng)新互聯(lián)專業(yè)提供多線服務(wù)器托管服務(wù),為用戶提供五星數(shù)據(jù)中心、電信、雙線接入解決方案,用戶可自行在線購(gòu)買多線服務(wù)器托管服務(wù),并享受7*24小時(shí)金牌售后服務(wù)。

在學(xué)習(xí)Vue計(jì)算屬性時(shí),有一句“計(jì)算屬性默認(rèn)只有 getter ,不過在需要時(shí)你也可以提供一個(gè) setter”。

getter和setter到底是什么?于是我查找了資料:

在Es5中可以使用getter和setter部分改寫默認(rèn)操作,但是只能應(yīng)用在單個(gè)屬性上,無法應(yīng)用在整個(gè)對(duì)象上。getter是一個(gè)隱藏函數(shù),會(huì)在獲取屬性值時(shí)調(diào)用。setter也是一個(gè)隱藏屬性,會(huì)在設(shè)置屬性值時(shí)調(diào)用。

例子:

var myObject = {
  get a(){
    return 2
  }
  };
  Object.defineProperty(
  myObject,       //目標(biāo)對(duì)象
  "b",          //屬性名
  {  //描述符
    //給b設(shè)置一個(gè)getter
    get:function(){
    return this.a*2
     },
    //確保b會(huì)出現(xiàn)在對(duì)象的屬性列表中
    enumerable:true
  }
);
console.log(myObject.a) //2
console.log(myObject.b) //4

這里使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun,測(cè)試結(jié)果如下:

js中g(shù)etter和setter用法實(shí)例分析

不管是對(duì)象文字語法中的get a( ) { ...... },還是defineProperty(......)中的顯式定義,二者都會(huì)在對(duì)象中創(chuàng)建一個(gè)不包含值的屬性,對(duì)于這個(gè)屬性的訪問會(huì)自動(dòng)調(diào)用一個(gè)隱藏函數(shù),它的返回值會(huì)被當(dāng)作屬性訪問的返回值。(也就是說myObject.a不用加執(zhí)行括號(hào),vue中計(jì)算屬性默認(rèn)有getter,調(diào)用計(jì)算屬性不用在后面加"( )")

var obj = {
  //給a定義一個(gè)getter
  get a(){
  return 2;
  }
};
obj.a = 3;
console.log(obj.a); //2

使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun,測(cè)試結(jié)果如下:

js中g(shù)etter和setter用法實(shí)例分析

由于對(duì)a只定義了getter,所以對(duì)a的set操作會(huì)忽略賦值操作,不會(huì)拋錯(cuò)。而且即便有合法的setter,由于我們自定義的getter只會(huì)返回2,所以set操作是沒有意義的。

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript常用函數(shù)技巧匯總》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。


網(wǎng)頁(yè)題目:js中g(shù)etter和setter用法實(shí)例分析
文章位置:http://weahome.cn/article/ighegs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部