10、AngularJs使用ng-model-options设置数据同步时机提高网站性能

阅读() @2019-05-12 11:46:36

之前讲过ng-model可以实时改变数据,实现双向数据绑定,但是如果数据是联通后台的,那么当就会实时与后台进行交互,肯定会增加后台的压力,影响性能,比如以下代码:

<input type="text" ng-model="data" />
<p>{{data}}</p>

因为它的数据是实时更新的,这里可以用一个指令:ng-model-options来解决。

第一种:ng-model-options="{updateOn:'blur'}",当鼠标失去焦点的时候才更新数据:

<input type="text" ng-model="data" ng-model-options="{'updateOn':'blur'}" />

第二种:ng-model-options="{debounce:3000}",指定几秒之后才更新数据:

<input type="text" ng-model="data" ng-model-options="{'debounce':3000}" />

第三种:结合以上两种情况一块儿使用:

<input type="text" ng-model="data" ng-model-options="{'updateOn':'default blur', 'debounce':{'default':3000, 'blur':0}}" />

这样可以极高的提升网站性能!

微信二维码