今天用兩種方法實(shí)現(xiàn)了動(dòng)態(tài)的給select添加option的功能.
第一種是用jquery.
// html
<select id="drag-pointList"></select>
// js
$('#drag-pointList').children('option').remove(); // 清空之前的option
let list = res.data.list ; // res是ajax請(qǐng)求成功返回的結(jié)果
let len = list.length;
let start = new Date();
if(len > 0){for( let i = 0; i < len; i++) {let item = list[i];let option ={id: item.pointId,name: item.pointName + " - " + item.pointId,}let domOp = '<option value="' + option.id + '"> ' + option.name + '</option>'$('#drag-pointList').append(domOp);}this.form.render('select'); // 使用layui更新select,let end = new Date();console.log('數(shù)據(jù):', len, '條 ', '耗時(shí):', end - start, '毫秒');
}
下面是使用ng-repeat的方法實(shí)現(xiàn)動(dòng)態(tài)的添加select
// html
<select id="drag-pointList"><option value="item.id" ng-repeat='item in dragPointList'>{{item.name}}</option>
</select>
// js
$('#drag-pointList').children('option').remove(); // 清空之前的option
let list = res.data.list ; // res是ajax請(qǐng)求成功返回的結(jié)果
let len = list.length;
let start = new Date();
if(len > 0){for( let i = 0; i < len; i++) {let item = list[i];let option ={id: item.pointId,name: item.pointName + " - " + item.pointId,}this.$scope.dragPointList.push(option); // Angular ($scope掛在了this.$scope上..)}this.form.render('select'); // 使用layui更新select,let end = new Date();console.log('數(shù)據(jù):', len, '條 ', '耗時(shí):', end - start, '毫秒');
}
Angular效果如下:
可以看見使用Angular更新渲染select明顯要快…
得出結(jié)論利用Jquery生成dom的方式添加select可能比較耗時(shí),應(yīng)當(dāng)適當(dāng)減少對(duì)dom的操作…
總結(jié)
以上是生活随笔為你收集整理的javascrpt --- 使用jquery添加dom元素和Angular ng-repeat生成select性能比较的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。