您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了angular使用原生拖拽頁面卡頓及表單控件輸入延遲怎么辦,內容簡而易懂,希望大家可以學習一下,學習完之后肯定會有收獲的,下面讓小編帶大家一起來看看吧。
說明
之前有一個angular項目,頁面上表單不算多,也就一百來個(這個不固定,有的地方多,有的地方少),但是再輸入的時候會造成輸入延遲,反應不靈敏,對用戶體驗極其不好。還有一個功能就是拖拽功能(原生,沒有使用官方中的拖拽功能),從左邊拖到右邊區域,拖拽區域少的時候還挺流暢,但一旦有幾百上千的時候反應極其的慢
原因(?)
上面兩個問題其實都和angular
的機制有關。一個雙向綁定一個拖拽歸根結底都是因為angular
的變化檢測
angular的雙向綁定主要是臟數據檢查,如果大量的檢查,效率比較低。(雙向綁定時向zone掛載一個異步函數,對數據改變是做處理,及時將變化反饋顯示在頁面上)可能就會輸入延遲
拖拽(也是向zone掛載異步函數)則是因為angular
對每個可移動像素的元素進行檢測而且還可能涉及對dom的操作,當拖拽區域數量較為多時,綁定的函數就越多,angular
需要檢測的元素區域就越來越多,處理起來就越力不從心(即使元素隱藏也不代表不會進行變化檢測)
解決
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));
對頻繁的操作(如dragover)不去觸發變更檢測。使用NgZone
中的runOutsideAngular
方法,angular
不會對里面的變化進行跟蹤。
ps:下面看下Angular 元素拖拽
1. 安裝 ng2-drag-drop
npm install ng2-drag-drop --save
2. 模板中配置可拖拽元素
// drag.component.html <div> <a href="javascript:;" rel="external nofollow" *ngFor="let item of sysData" draggable [dragData]="item" [dragScope]="'system'">{{ item.name }}</a> </div>
3. 模板中配置拖拽元素所拖拽的目的地
// drag.component.ts <div droppable (onDrop)="onItemDrop($event)" [dropScope]="'system'"></div>
4. ts文件
// drag.component.ts export class DragComponent { const sysData = [ {id: '1', name: '拖動元素1'}, {id: '2', name: '拖動元素2'}, {id: '3', name: '拖動元素3'}, {id: '4', name: '拖動元素4'} ]; } onItemDrop(e: any) { // data為拖拽時傳遞的數據 - item const data = e.dragData; }
以上就是關于angular使用原生拖拽頁面卡頓及表單控件輸入延遲怎么辦的內容,如果你們有學習到知識或者技能,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。