解決angular 使用原生拖拽頁(yè)面卡頓及表單控件輸入延遲問(wèn)題
說(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è))
解決
- 對(duì)于雙向綁定造成的輸入延遲,停止使用雙向綁定,改用單向綁定
- 拖拽過(guò)程angular一直檢測(cè)頁(yè)面變化,所以頁(yè)面卡頓。我們需要做的就是設(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 元素拖拽
- 拖動(dòng)元素到指定區(qū)域
- 拖放的同時(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)過(guò)程中將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; }
總結(jié)
到此這篇關(guān)于angular 中使用原生拖拽頁(yè)面卡頓,表單控件輸入延遲的文章就介紹到這了,更多相關(guān)angular 中使用原生拖拽頁(yè)面卡頓,表單控件輸入延遲內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
AngularJS 實(shí)現(xiàn)彈性盒子布局的方法
本文給大家?guī)?lái)一段簡(jiǎn)短代碼實(shí)現(xiàn)angularjs彈性布局效果,非常實(shí)用,對(duì)angularjs彈出布局知識(shí)感興趣的朋友可以參考下2016-08-08Angular2表單自定義驗(yàn)證器的實(shí)現(xiàn)
本文給大家介紹angular2表單自定義驗(yàn)證器的實(shí)現(xiàn),本文給大家介紹的非常詳細(xì),具有參考借鑒價(jià)值,感興趣的朋友一起看看吧2016-10-10Angular.js前臺(tái)傳list數(shù)組由后臺(tái)spring MVC接收數(shù)組示例代碼
這篇文章主要給大家介紹了關(guān)于Angular.js前臺(tái)傳list數(shù)組之后,由后臺(tái)spring MVC接收數(shù)組的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-07-07Angular父子組件通過(guò)服務(wù)傳參的示例方法
這篇文章主要介紹了Angular父子組件通過(guò)服務(wù)傳參的示例方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-10-10基于AngularJS實(shí)現(xiàn)iOS8自帶的計(jì)算器
這篇文章的主要內(nèi)容是使用angularjs實(shí)現(xiàn)一個(gè)計(jì)算器,是一個(gè)仿iOS8風(fēng)格的計(jì)算器,功能基本和iOS自帶的計(jì)算器是一致的。有需要的朋友們可以參考借鑒。2016-09-09ng2學(xué)習(xí)筆記之bootstrap中的component使用教程
現(xiàn)在angular2已經(jīng)除了集成的angular-cli,建議大家可以基于這個(gè)來(lái)快速開發(fā)ng2的項(xiàng)目,不用自己再搭建環(huán)境。接下來(lái)通過(guò)本文給大家介紹 bootstrap中的component使用教程,需要的朋友可以參考下2017-03-03