久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

javascript - 數(shù)組的過濾和渲染

瀏覽:184日期:2023-06-07 17:34:39

問題描述

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>

求教,請問如何能夠最簡單的根據(jù)數(shù)據(jù)里的value值在 dom 里渲染出相應(yīng)的label值??數(shù)據(jù)是不定的,可能里面會有十幾二十個

問題解答

回答1:

樓上的的方式可以做到,但是這樣就相當(dāng)于每次都生命一個變量,每一次都往.text里面添加了span節(jié)點(diǎn),操作了DOM,造成很大的開銷!我個人建議用下面這個方式。

var opText= document.querySelector(’.text’),var _text='';data.forEach(function(item){ //把每一次遍歷的label加上節(jié)點(diǎn),再儲存在_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下的性能各有優(yōu)缺點(diǎn),現(xiàn)在普遍做法上通過創(chuàng)建一個新的空白的文檔片段( 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’}]// 根據(jù)value獲取dataList中對應(yīng)的項(xiàng)function getLabelByValue(dataList, value) { return dataList.find(function (item) { return item.value === value // 這里使用的強(qiáng)等,根據(jù)情況可選 == })}// 省略DOM操作let label = getLabelByValue(data, ’0’) // 分類一

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 淄博市| 民乐县| 祁连县| 玛曲县| 仙居县| 新津县| 辰溪县| 崇义县| 丰县| 台安县| 亚东县| 浦江县| 景泰县| 崇阳县| 手机| 昌邑市| 南郑县| 柏乡县| 兴山县| 洞口县| 龙里县| 镇原县| 海宁市| 夏津县| 三台县| 从江县| 阳朔县| 德州市| 乌拉特后旗| 天水市| 襄樊市| 霞浦县| 额尔古纳市| 定南县| 道真| 马山县| 历史| 云和县| 察雅县| 洪泽县| 阿瓦提县|