javascript - 數組的過濾和渲染
問題描述
var data = [{
label: ’分類一’, value: ’0’}, { label: ’分類二’, value: ’1’}, { label: ’分類三’, value: ’2’}, { label: ’分類四’, value: ’3’}, { label: ’分類五’, value: ’4’}, { label: ’分類六’, value: ’5’}]
<p class='text'>
<span>0</span><span>1</span><span>2</span><span>3</span><span>4</span><span>5</span>
</p>
求教,請問如何能夠最簡單的根據數據里的value值在 dom 里渲染出相應的label值??數據是不定的,可能里面會有十幾二十個
問題解答
回答1:樓上的的方式可以做到,但是這樣就相當于每次都生命一個變量,每一次都往.text里面添加了span節點,操作了DOM,造成很大的開銷!我個人建議用下面這個方式。
var opText= document.querySelector(’.text’),var _text='';data.forEach(function(item){ //把每一次遍歷的label加上節點,再儲存在_text上。 _text += ’<span>’+item.label+’</span>’;});//最后直接把_text賦值到opText.innerHTML上。opText.innerHTML=_text ;回答2:
var container = document.querySelector(’.text’)data.forEach(function(item){ var span = document.createElement(’span’) span.innerHTML = item.label span.setAttribute(’value’, item.value) container.appendChild(span)})回答3:
樓上的方法都是可行的,不過前兩中方法在火狐跟chrome下的性能各有優缺點,現在普遍做法上通過創建一個新的空白的文檔片段( DocumentFragment)。
const $container = document.querySelector(’.text’);const fragment = document.createDocumentFragment();data.map(item => { let span = document.createElement('span'); span.textContent = item; fragment.appendChild(span);});$container.appendChild(fragment);回答4:
var data = [{ label: ’分類一’, value: ’0’}, { label: ’分類二’, value: ’1’}]// 根據value獲取dataList中對應的項function getLabelByValue(dataList, value) { return dataList.find(function (item) { return item.value === value // 這里使用的強等,根據情況可選 == })}// 省略DOM操作let label = getLabelByValue(data, ’0’) // 分類一
相關文章:
1. android - 分享到微信,如何快速轉換成字節數組2. angular.js - Beego 與 AngularJS的模板格式沖突,該怎么解決?3. javascript - 能否讓vue-cli的express修改express重啟服務4. 解決Android webview設置cookie和cookie丟失的問題5. node.js - npm一直提示proxy有問題6. phpstorm 沒有安裝Emmet怎么還有Emmet的相關功能啊7. python - flask template file not found8. mysql怎么多表刪除啊?9. javascript - 有沒有iOS微信中可以在背景播放視頻的方法?10. python - 網頁title中包含換行,如何用正則表達式提取出來?
