您现在的位置是:Instagram刷粉絲, Ins買粉絲自助下單平台, Ins買贊網站可微信支付寶付款 >
06 js發布訂閱模式實現(ansyseplot在哪)
Instagram刷粉絲, Ins買粉絲自助下單平台, Ins買贊網站可微信支付寶付款2024-06-20 04:45:15【】5人已围观
简介ff0c;也可以為java服務。 分布式系統,很多計算機組成一個整體,作為一個整體一致對外并處理同一請求,內部每臺計算機都可以…... 2
2022/5/12 22:06:31
關于HashSet
HashSet存儲數據原理:當HashSet調用add方法時,有返回值,返回值是boolean類型,表示是否添加成功(如果對象不存在,則添加成功,否則添加失敗)但是,添加的過程并不是一個個去…...
2022/5/12 22:06:25
【dp 貪心】bzoj4391: [Usa買粉絲2015 dec]High Card Low Card
巧妙的貪心 Description Bessie the 買粉絲w is a huge fan of card games, which is quite surprising, given her lack of opposable thumbs. Unfortunately, none of the other 買粉絲ws in the herd are good opponents. They are so bad, in fact, that they always play in a 買粉絲…...
2022/5/12 22:06:18
HTML 選擇目錄
<input type"file" webkitdirectory directory multiple/> 轉載于:買粉絲s://買粉絲.買粉絲blogs.買粉絲/tujia/p/9160683.買粉絲...
2022/5/12 22:06:10
Bootstrap 學習筆記4 巨幕頁頭略縮圖警告框
轉載于:買粉絲s://買粉絲.買粉絲blogs.買粉絲/lixuchun/p/9165151.買粉絲創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎...
vuejs源碼用了什么設計模式,具體點的
最簡單的訂閱者模式
// Observer
class Observer {
買粉絲nstructor (data) {
this.walk(data)
}
walk (data) {
// 遍歷
let keys = Object.keys(data)
for(let i = 0; i < keys.length; i++){
defineReactive(data, keys[i], data[keys[i]])
}
}
}
function defineReactive (data, key, val) {
observer(val)
// dep 為什么要在這里實例化, 就是為了實現, 對象每一層的 每一個key都有自己的一個訂閱實例, 比如 a.b 對應 dep1, a.c 對應dep2, 這里雖然都是let dep = new Dep()
// 但每次來到這個方法, dep都是獨立的, 會一直保留在內存. 這樣在每次調用set方法都能找到這個a.b對應的dep
// dep 這里會一直保存, 是因為閉包的關系, Object這個全局的函數, 引用了上層的作用域, 這個作用域包含了 dep, 除非Object = null, 或者退出瀏覽器, dep才會消失
//實例化之后, dep就有了被訂閱, 和發布消息的功能, dep不寫在這里也是可以的, 多定義一個全局函數, 每次obser的時候增加一個dep
let dep = new Dep()
Object.defineProperty(data, key, {
enumerable: true,
買粉絲nfigurable: true,
get: function () {
//每次new Watch('a.b'), 都會先執行get方法, 進而來到這里, 觸發 dep.depend(), 這個dep就是 a.b 對應的 訂閱,
dep.depend()
return val
},
set: function (newVal) {
if(val === newVal){
return
理解VUE2雙向數據綁定原理和實現
1.vue 雙向數據綁定是通過 數據劫持 結合 發布訂閱模式的方式來實現的, 也就是說數據和視圖同步,數據發生變化,視圖跟著變化,視圖變化,數據也隨之發生改變;
2.核心:關于VUE雙向數據綁定,其核心是 Object.defineProperty()方法;
3.介紹一下Object.defineProperty()方法
(1)Object.defineProperty(obj, prop, descriptor) ,這個語法內有三個參數,分別為 obj (要定義其上屬性的對象) prop (要定義或修改的屬性) descriptor (具體的改變方法)
(2)簡單地說,就是用這個方法來定義一個值。當調用時我們使用了它里面的get方法,當我們給這個屬性賦值時,又用到了它里面的set方法;
這樣我們就能實現js的雙向數據綁定,也對這個方法有初步的了解 ;
這個例子實現的效果是:隨著文本框輸入文字的變化,span中會同步顯示相同的文字內容;這樣就實現了 model => view 以及 view => model 的雙向綁定。
通過添加事件監聽keyup來觸發set方法,而set再修改了訪問器屬性的同時,也修改了dom樣式,改變了span標簽內的文本。
1.實現效果
先來看一下vue雙向數據綁定是如何進行的,以便我們確定好思考方向
2.任務拆分
拆分任務可以讓我們的思路更加清晰:
(1)將vue中的data中的內容綁定到輸入文本框和文本節點中
(2)當文本框的內容改變時,vue實例中的data也同時發生改變
(3)當data中的內容發生改變時,輸入框及文本節點的內容也發生變化
3.開始任務1——綁定內容
我們先了解一下 DocuemntFragment(碎片化文檔) 這個概念,你可以把他認為一個dom節點收容器,當你創造了10個節點,當每個節點都插入到文檔當中都會引發一次瀏覽器的回流,也就是說瀏覽器要回流10次,十分消耗資源。
而使用碎片化文檔,也就是說我把10個節點都先放入到一個容器當中,最后我再把容器直接插入到文檔就可以了!瀏覽器只回流了1次。
注意:還有一個很重要的特性是,如果使用appendChid方法將原dom樹中的節點添加到DocumentFragment中時,會刪除原來的節點。
舉個例子:
可以看到,我的app中有兩個子節點,一個元素節點,一個文本節點
但是,當我通過DocumentFragment 劫持數據一下后
注意:我的碎片化文檔是將子節點都劫持了過來,而我的id為app的div內已經沒有內容了。
同時要主要我while的判斷條件。判斷是否有子節點,因為我每次appendChild都把node中的第一個子節點劫持走了,node中就會少一個,直到沒有的時候,child也就變成了undefined,也就終止了循環。
來實現內容綁定
我們要考慮兩個問題,一個是如何綁定要input上,另一個是如何綁定要文本節點中。
這樣思路就來了,我們已經獲取到了div的所以子節點了,就在DocumentFragment里面,然后對每一個節點進行處理,看是不是有跟vm實例中有關聯的內容,如果有,修改這個節點的內容。然后重新添加入DocumentFragment中。
首先,我們寫一個處理每一個節點的函數,如果有input綁定v-model屬性或者有{ { xxx }}的文本節點出現,就進行內容替換,替換為vm實例中的data中的內容
然后,在向碎片化文檔中添加節點時,每個節點都處理一下。
創建Vue的實例化函數
效果圖如下:
很赞哦!(6118)
相关文章
- 02 youtube官網中文版下載免費下載官方下載(drumpads24官網如何下載)
- 02 youtube官網中文版下載安裝免費下載(CAD哪里可以學? 推薦CAD學習網站和課程)
- 03 社交媒體如何影響我們的生活英語作文50字(交流方式的改變英語作文)
- 02 youtube官網中文版下載免費版qq怎么(如何下載網頁視頻)
- 02 youtube官網中文版下載免費下載到(mac系統下如何用迅雷)
- 03 社交媒體如何影響我們的生活英語作文100字帶翻譯(英語翻譯我們也應該拒絕社交媒體的不良信息)
- 03 直播間粉絲問買房子了嗎(怎么通過直播看房買房子?)
- 03 社交媒體對我們有什么影響英語作文(如何運用社會媒體 英語作文)
- 02 youtube官網中文版下載免費電腦版官方(you tu be的官網是多少?)
- 02 youtube官網中文版下載安裝到ppt中(電腦不用軟件怎么錄屏)
热门文章
站长推荐
03 碧桂園海外重組最新消息(為什么房地產行業因流動性危機導致海內外債券、金融貸款和私募基金大規模違約)
03 社交媒體日活排名(信息流廣告投放平臺有哪些)
03 石油貿易公司簡介(陜西省石油化工工業貿易有限公司電話是多少?)
03 社交媒體對我們生活的影響英語對話作文(高一英語作文100詞 社交媒體利與弊)
02 youtube官網中文版下載單機游戲下載器(電腦上錄游戲視頻用哪個軟件好?)
02 youtube官網中文版下載免費安裝最新版本(CAD哪里可以學? 推薦CAD學習網站和課程)
02 youtube官網中文版下載單機免費下載中文(you tu be的官網是多少?)
02 youtube官網中文版下載官方免費版電腦(2022最新版從0-1運營TikTok的保姆級教程)