内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

angular使用原生拖拽頁面卡頓及表單控件輸入延遲怎么辦-創(chuàng)新互聯(lián)

這篇文章主要為大家展示了angular使用原生拖拽頁面卡頓及表單控件輸入延遲怎么辦,內(nèi)容簡而易懂,希望大家可以學(xué)習(xí)一下,學(xué)習(xí)完之后肯定會有收獲的,下面讓小編帶大家一起來看看吧。

成都創(chuàng)新互聯(lián)公司基于分布式IDC數(shù)據(jù)中心構(gòu)建的平臺為眾多戶提供成都電信服務(wù)器托管 四川大帶寬租用 成都機柜租用 成都服務(wù)器租用。

說明

之前有一個angular項目,頁面上表單不算多,也就一百來個(這個不固定,有的地方多,有的地方少),但是再輸入的時候會造成輸入延遲,反應(yīng)不靈敏,對用戶體驗極其不好。還有一個功能就是拖拽功能(原生,沒有使用官方中的拖拽功能),從左邊拖到右邊區(qū)域,拖拽區(qū)域少的時候還挺流暢,但一旦有幾百上千的時候反應(yīng)極其的慢

原因(?)

上面兩個問題其實都和angular的機制有關(guān)。一個雙向綁定一個拖拽歸根結(jié)底都是因為angular的變化檢測

angular的雙向綁定主要是臟數(shù)據(jù)檢查,如果大量的檢查,效率比較低。(雙向綁定時向zone掛載一個異步函數(shù),對數(shù)據(jù)改變是做處理,及時將變化反饋顯示在頁面上)可能就會輸入延遲

拖拽(也是向zone掛載異步函數(shù))則是因為angular對每個可移動像素的元素進行檢測而且還可能涉及對dom的操作,當(dāng)拖拽區(qū)域數(shù)量較為多時,綁定的函數(shù)就越多,angular需要檢測的元素區(qū)域就越來越多,處理起來就越力不從心(即使元素隱藏也不代表不會進行變化檢測)

解決

  1. 對于雙向綁定造成的輸入延遲,停止使用雙向綁定,改用單向綁定
  2. 拖拽過程angular一直檢測頁面變化,所以頁面卡頓。我們需要做的就是設(shè)置對某些操作不跟蹤變化
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使用原生拖拽頁面卡頓及表單控件輸入延遲怎么辦-創(chuàng)新互聯(lián)
URL分享:http://www.rwnh.cn/article36/dpeosg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號、商城網(wǎng)站品牌網(wǎng)站設(shè)計、搜索引擎優(yōu)化、關(guān)鍵詞優(yōu)化電子商務(wù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

手機網(wǎng)站建設(shè)
水富县| 平和县| 石阡县| 永平县| 喀喇沁旗| 乌兰县| 陆川县| 台山市| 西畴县| 西青区| 广元市| 南靖县| 兰考县| 博罗县| 六盘水市| 安塞县| 内乡县| 商洛市| 班玛县| 宿州市| 衡阳市| 马关县| 奇台县| 仁布县| 丹巴县| 延边| 宾阳县| 高平市| 筠连县| 凤台县| 营口市| 榆社县| 武功县| 开原市| 台前县| 呼玛县| 万盛区| 石家庄市| 昌都县| 平南县| 鹿泉市|