「1分鐘--前端01」vue雙向綁定

vue雙向綁定.png

目錄

⊙常見雙向綁定的實(shí)現(xiàn)方法

⊙基于數(shù)據(jù)劫持雙向綁定的優(yōu)點(diǎn)

⊙基于Object.defineProperty雙向綁定的兩個(gè)缺點(diǎn)

Proxy實(shí)現(xiàn)雙向綁定的特點(diǎn)


一.常見雙向綁定的方法

1.KnockoutJS基于觀察者模式的雙向綁定络拌;

2.Ember基于數(shù)據(jù)模型春贸;

3.Angular基于臟檢查的雙向綁定遗遵,使用主動(dòng)遍歷

4.基于數(shù)據(jù)劫持的雙向綁定

(1)Vue現(xiàn)在使用的Object.defineProperty

(2)ES6新增的Proxy,尤大也說Vue3.0換成這個(gè)了允粤。


二.數(shù)據(jù)劫持的優(yōu)點(diǎn)

1.無需顯示調(diào)用

data.name = '懸筆e絕';就能直接觸發(fā)變更

不用像react使用setState顯示調(diào)用类垫;

2.精確得到變化數(shù)據(jù)

劫持屬性的setter,變化時(shí)可以得到newVal悉患;

否則只知道數(shù)據(jù)變了榆俺,具體需要大量的diff才能找出變化值


三.Object.defineProperty的缺點(diǎn)

1.無法監(jiān)聽數(shù)組的變化

根本原因:數(shù)組沒有setter和getter

因?yàn)閿?shù)組的長度不確定茴晋,可能會(huì)很大,出于性能考慮就沒有setter和getter市袖。

注:vue文檔說可以檢測數(shù)組變化掀虎,其實(shí)是使用了奇技淫巧付枫,

感興趣的話阐滩,我之后再補(bǔ)充。

2.只能劫持對(duì)象的屬性

我們需要對(duì)每個(gè)對(duì)象的每個(gè)屬性進(jìn)行遍歷掂榔,如果屬性值也是對(duì)象症杏,就要深度遍歷了厉颤。

所以下面要放大招了~


四.Proxy的特點(diǎn)

嚴(yán)格講proxy叫做代理穴豫,提供了一種機(jī)制能對(duì)外界訪問進(jìn)行過濾和改寫精肃,簡單理解Proxy是Object.defineProperty的全方位加強(qiáng)版

優(yōu)點(diǎn)

(1)直接監(jiān)聽整個(gè)對(duì)象帜乞,而不是屬性

(2)可以監(jiān)聽數(shù)組的變化

(3)Proxy有多達(dá)13種攔截方法,很多都是Object.defineProperty不具備的习柠。

(4)返回一個(gè)新的對(duì)象,不是像Object.defineProperty那樣直接修改對(duì)象屬性资溃;符合immortal思想烈炭;

(5)新標(biāo)準(zhǔn)的性能紅利,會(huì)受到瀏覽器廠商重點(diǎn)持續(xù)的心性能優(yōu)化

缺點(diǎn)

兼容性問題,且無法用polyfill磨平卑惜,所以尤大才說要等到大版本3.0再用Proxy重寫了。


PS:前端程序員一枚更米,熱愛分享web技術(shù),新媒體音視頻毫痕,航拍攝影知識(shí)征峦;公眾號(hào)“懸筆e絕”

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末迟几,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子栏笆,更是在濱河造成了極大的恐慌类腮,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,036評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蛉加,死亡現(xiàn)場離奇詭異蚜枢,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)针饥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門厂抽,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人丁眼,你說我怎么就攤上這事∶晔兀” “怎么了吗伤?”我有些...
    開封第一講書人閱讀 164,411評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵礁阁,是天一觀的道長。 經(jīng)常有香客問我丹鸿,道長,這世上最難降的妖魔是什么门怪? 我笑而不...
    開封第一講書人閱讀 58,622評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮护锤,結(jié)果婚禮上烙懦,老公的妹妹穿的比我還像新娘修陡。我一直安慰自己,他們只是感情好癣朗,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蠢熄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪饥追。 梳的紋絲不亂的頭發(fā)上但绕,一...
    開封第一講書人閱讀 51,521評(píng)論 1 304
  • 那天,我揣著相機(jī)與錄音草丧,去河邊找鬼。 笑死懂拾,一個(gè)胖子當(dāng)著我的面吹牛岖赋,可吹牛的內(nèi)容都是我干的唐断。 我是一名探鬼主播脸甘,決...
    沈念sama閱讀 40,288評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼翁垂,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼枚荣!你這毒婦竟也來了橄妆?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,200評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎儒陨,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體笛园,經(jīng)...
    沈念sama閱讀 45,644評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了虱肄。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,953評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡翰灾,死狀恐怖纸淮,靈堂內(nèi)的尸體忽然破棺而出咽块,到底是詐尸還是另有隱情侈沪,我是刑警寧澤亭罪,帶...
    沈念sama閱讀 35,673評(píng)論 5 346
  • 正文 年R本政府宣布燥筷,位于F島的核電站袍祖,受9級(jí)特大地震影響捐凭,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評(píng)論 3 329
  • 文/蒙蒙 一惋嚎、第九天 我趴在偏房一處隱蔽的房頂上張望鼻百。 院中可真熱鬧,春花似錦、人聲如沸琐鲁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽苹支。三九已至晴埂,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間琅锻,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評(píng)論 1 269
  • 我被黑心中介騙來泰國打工僵芹, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人荷辕。 一個(gè)月前我還...
    沈念sama閱讀 48,119評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像蟆盐,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容