我在整理javascript高級程式設(shè)計的筆記的時候看到物件導(dǎo)向設(shè)計那章,講到物件屬性分為資料屬性和存取器屬性,我們平時用的js物件90%以上都只是用到資料屬性;我們向來講解下資料屬性和存取器屬性到底是什麼?
資料屬性:資料屬性包含一個資料值的位置,在這個位置可以讀取和寫入值.
存取器屬性:存取器屬性不包含資料值;他們包含一對getter和setter函數(shù)在讀取存取器屬性時,會呼叫g(shù)etter函數(shù),這個函數(shù)負責(zé)傳回有效的值,在寫入存取器屬性時,會呼叫setter函數(shù)並傳入新值.
這裡介紹的重點是訪問器屬性,設(shè)定物件的存取器屬性只能用es5的Object.defineProrerty()方法,如下例子:
var book={ _year:2004, edition:1 }; Object.defineProperty(book,"year",{ get:function () { return this._year }, set:function (newValue) { if(newValue>2004){ this._year=newValue; this.edition+=newValue-2004; } } }); book.year=2005; alert(book.edition);//2 console.log(book.year);//2005
也就是當(dāng)執(zhí)行book.year=2005的時候其實是執(zhí)行了year中的set方法,當(dāng)執(zhí)行book.year的時候執(zhí)行了year的get方法;
var book={ _year:2004, edition:1 }; Object.defineProperty(book,"year",{ get:function () { console.log("year get") return this._year }, set:function (newValue) { console.log("year set") if(newValue>2004){ this._year=newValue; this.edition+=newValue-2004; } } }); book.year=2005; alert(book.year);
控制臺的提示是:
這個原理就是vue雙向資料綁定的原理,我們在vue組件中的data宣告屬性資料的時候其實在物件中的已經(jīng)將這個屬性封裝成了存取器屬性.
每個屬性都有g(shù)et和set方法,在做雙向的資料的控制都在get和set方法中,因為無論你是在ready(2.0是mounted了)或是在view中改變值都會觸發(fā)set方法,將新值複製進去,在重新在view中匹配值,當(dāng)然你們有更複雜的控制操作, get方法著是讓ready中取得的這個屬性值一直保存最新值.
angular1的雙向資料綁定是髒資料監(jiān)測,簡單點說就是監(jiān)測新值和舊值有沒有變化,這種方式就要定時監(jiān)測了咯.兩種性能的消耗感覺不在一個層次上的啊.
就好比用html5 Sockets做後臺主動消息推送前端和用js定時器每個5秒發(fā)送請求到後臺捕獲消息的性能差距一樣.
一直以為vue的data層其實就是個擺設(shè),但在api發(fā)現(xiàn)computed屬性之後data層完全可以實現(xiàn)發(fā)送ajax取數(shù)功能,沒必要在全都放到ready(2.0是mounted了)裡面,這個ready(2.0是mounted了)可以只負責(zé)資料格式出來,或控制頁面的動態(tài)效果而已.這js的結(jié)構(gòu)就像後臺MVC那樣層次功能分明清晰.這也只是我突然想到的思路還沒真正應(yīng)用到實際專案中,只是給在用vue的朋友提供個思路.
import data from '../assets/js/data' export default{ data(){ return{ menu:data.menu, inde:"", row:"", clomu:"" } }, computed:{ isfull:function () { alert(111); return 11; } }, mounted(){ }, methods:{ domclick:function (i) { if(this.inde===i){ this.inde=""; }else { this.inde = i; } }, subclick:function (i,o) { this.row=i; this.clomu=o; } } }

熱AI工具

Undress AI Tool
免費脫衣圖片

Undresser.AI Undress
人工智慧驅(qū)動的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6
視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Angular.js是一種可自由存取的JavaScript平臺,用於建立動態(tài)應(yīng)用程式。它允許您透過擴展HTML的語法作為模板語言,以快速、清晰地表示應(yīng)用程式的各個方面。 Angular.js提供了一系列工具,可協(xié)助您編寫、更新和測試程式碼。此外,它還提供了許多功能,如路由和表單管理。本指南將討論在Ubuntu24上安裝Angular的方法。首先,您需要安裝Node.js。 Node.js是一個基於ChromeV8引擎的JavaScript運行環(huán)境,可讓您在伺服器端執(zhí)行JavaScript程式碼。要在Ub

angular中怎麼使用monaco-editor?以下這篇文章記錄下最近的一次業(yè)務(wù)中用到的 m??onaco-editor 在 angular 中的使用,希望對大家有幫助!

隨著網(wǎng)路的快速發(fā)展,前端開發(fā)技術(shù)也不斷改進與迭代。 PHP和Angular是兩種廣泛應(yīng)用於前端開發(fā)的技術(shù)。 PHP是一種伺服器端腳本語言,可以處理表單、產(chǎn)生動態(tài)頁面和管理存取權(quán)限等任務(wù)。而Angular是一種JavaScript的框架,可以用來開發(fā)單一頁面應(yīng)用程式和建構(gòu)元件化的網(wǎng)頁應(yīng)用程式。本篇文章將介紹如何使用PHP和Angular進行前端開發(fā),以及如何將它們

這篇文章繼續(xù)Angular的學(xué)習(xí),帶大家了解Angular中的元數(shù)據(jù)和裝飾器,簡單了解一下他們的用法,希望對大家有幫助!

這篇文章帶大家深入了解angular的狀態(tài)管理器NgRx,介紹一下NgRx的使用方法,希望對大家有幫助!

你知道 Angular Universal 嗎?可以幫助網(wǎng)站提供更好的 SEO 支援哦!

這篇文章跟大家分享一個Angular實戰(zhàn),了解一下angualr 結(jié)合 ng-zorro 如何快速開發(fā)一個後臺系統(tǒng),希望對大家有幫助!

身份驗證是任何網(wǎng)路應(yīng)用程式中最重要的部分之一。本教程討論基於令牌的身份驗證系統(tǒng)以及它們與傳統(tǒng)登入系統(tǒng)的差異。在本教程結(jié)束時,您將看到一個用Angular和Node.js編寫的完整工作演示。傳統(tǒng)身份驗證系統(tǒng)在繼續(xù)基於令牌的身份驗證系統(tǒng)之前,讓我們先來看看傳統(tǒng)的身份驗證系統(tǒng)。使用者在登入表單中提供使用者名稱和密碼,然後點擊登入。發(fā)出請求後,透過查詢資料庫在後端驗證使用者。如果請求有效,則使用從資料庫中獲取的使用者資訊建立會話,然後在回應(yīng)頭中傳回會話訊息,以便將會話ID儲存在瀏覽器中。提供用於存取應(yīng)用程式中受
