這篇文章主要為大家展示了angular使用原生拖拽頁(yè)面卡頓及表單控件輸入延遲怎么辦,內(nèi)容簡(jiǎn)而易懂,希望大家可以學(xué)習(xí)一下,學(xué)習(xí)完之后肯定會(huì)有收獲的,下面讓小編帶大家一起來(lái)看看吧。
成都創(chuàng)新互聯(lián)公司基于分布式IDC數(shù)據(jù)中心構(gòu)建的平臺(tái)為眾多戶提供成都電信服務(wù)器托管 四川大帶寬租用 成都機(jī)柜租用 成都服務(wù)器租用。說(shuō)明
之前有一個(gè)angular項(xiàng)目,頁(yè)面上表單不算多,也就一百來(lái)個(gè)(這個(gè)不固定,有的地方多,有的地方少),但是再輸入的時(shí)候會(huì)造成輸入延遲,反應(yīng)不靈敏,對(duì)用戶體驗(yàn)極其不好。還有一個(gè)功能就是拖拽功能(原生,沒(méi)有使用官方中的拖拽功能),從左邊拖到右邊區(qū)域,拖拽區(qū)域少的時(shí)候還挺流暢,但一旦有幾百上千的時(shí)候反應(yīng)極其的慢
原因(?)
上面兩個(gè)問(wèn)題其實(shí)都和angular
的機(jī)制有關(guān)。一個(gè)雙向綁定一個(gè)拖拽歸根結(jié)底都是因?yàn)?code>angular的變化檢測(cè)
angular的雙向綁定主要是臟數(shù)據(jù)檢查,如果大量的檢查,效率比較低。(雙向綁定時(shí)向zone掛載一個(gè)異步函數(shù),對(duì)數(shù)據(jù)改變是做處理,及時(shí)將變化反饋顯示在頁(yè)面上)可能就會(huì)輸入延遲
拖拽(也是向zone掛載異步函數(shù))則是因?yàn)?code>angular對(duì)每個(gè)可移動(dòng)像素的元素進(jìn)行檢測(cè)而且還可能涉及對(duì)dom的操作,當(dāng)拖拽區(qū)域數(shù)量較為多時(shí),綁定的函數(shù)就越多,angular
需要檢測(cè)的元素區(qū)域就越來(lái)越多,處理起來(lái)就越力不從心(即使元素隱藏也不代表不會(huì)進(jìn)行變化檢測(cè))
解決
this.ngZone.runOutsideAngular(() => { this.dragEnter = this.rd.listen(spanDom, 'dragenter', this.dragenterHandler.bind(this)); this.dragOver = this.rd.listen(spanDom, 'dragover', (e) => { e.preventDefault(); }); this.dragLeave = this.rd.listen(spanDom, 'dragleave', this.dragLeaveHandle.bind(this)); }); this.dragDrop = this.rd.listen(spanDom, 'drop', this.dropHandler.bind(this));
本文題目:angular使用原生拖拽頁(yè)面卡頓及表單控件輸入延遲怎么辦-創(chuàng)新互聯(lián)
URL分享:http://jinyejixie.com/article36/dpeosg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)、商城網(wǎng)站、品牌網(wǎng)站設(shè)計(jì)、搜索引擎優(yōu)化、關(guān)鍵詞優(yōu)化、電子商務(wù)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容