溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

angular使用原生拖拽頁面卡頓及表單控件輸入延遲怎么辦

發(fā)布時(shí)間:2020-08-01 11:59:40 來源:億速云 閱讀:329 作者:小豬 欄目:web開發(fā)

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

說明

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

原因(?)

上面兩個(gè)問題其實(shí)都和angular的機(jī)制有關(guān)。一個(gè)雙向綁定一個(gè)拖拽歸根結(jié)底都是因?yàn)?code>angular的變化檢測(cè)

angular的雙向綁定主要是臟數(shù)據(jù)檢查,如果大量的檢查,效率比較低。(雙向綁定時(shí)向zone掛載一個(gè)異步函數(shù),對(duì)數(shù)據(jù)改變是做處理,及時(shí)將變化反饋顯示在頁面上)可能就會(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ū)域就越來越多,處理起來就越力不從心(即使元素隱藏也不代表不會(huì)進(jìn)行變化檢測(cè))

解決

  1. 對(duì)于雙向綁定造成的輸入延遲,停止使用雙向綁定,改用單向綁定
  2. 拖拽過程angular一直檢測(cè)頁面變化,所以頁面卡頓。我們需要做的就是設(shè)置對(duì)某些操作不跟蹤變化
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));

對(duì)頻繁的操作(如dragover)不去觸發(fā)變更檢測(cè)。使用NgZone中的runOutsideAngular方法,angular不會(huì)對(duì)里面的變化進(jìn)行跟蹤。

ps:下面看下Angular 元素拖拽

  1. 拖動(dòng)元素到指定區(qū)域
  2. 拖放的同時(shí)傳遞數(shù)據(jù)

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>
  • draggable - 表明此元素時(shí)可拖拽的
  • [dragData] = 'item' - 在拖動(dòng)過程中將item數(shù)據(jù)從draggable到droppable
  • [dragScope]="'system'" - 拖拽范圍,和第三步[dropScope]="'system'"相對(duì)應(yīng);

3. 模板中配置拖拽元素所拖拽的目的地

// drag.component.ts
 <div droppable (onDrop)="onItemDrop($event)" [dropScope]="'system'"></div>
  • droppable - 第二步中拖拽的元素都將拖拽到有droppable指令的元素內(nèi);
  • (onDrop) - 當(dāng)拖拽元素至此區(qū)域內(nèi)后(鼠標(biāo)釋放后),觸發(fā)onItemDrop方法,其中$event就是第二步中[dragData] = 'item'的item參數(shù)
  • [dropScope]="'system'" - 和第二步的[dragScope]="'system'"對(duì)應(yīng),[dragScope]="'system'"的拖拽元素只能拖拽到 [dropScope]="'system'"元素內(nèi);

4. ts文件

// drag.component.ts
export class DragComponent {

 const sysData = [
  {id: '1', name: '拖動(dòng)元素1'},
  {id: '2', name: '拖動(dòng)元素2'},
  {id: '3', name: '拖動(dòng)元素3'},
  {id: '4', name: '拖動(dòng)元素4'}
 ];

}

onItemDrop(e: any) {
 // data為拖拽時(shí)傳遞的數(shù)據(jù) - item
 const data = e.dragData;
}

以上就是關(guān)于angular使用原生拖拽頁面卡頓及表單控件輸入延遲怎么辦的內(nèi)容,如果你們有學(xué)習(xí)到知識(shí)或者技能,可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI