vue.js基于v-for實(shí)現(xiàn)批量渲染 Json數(shù)組對(duì)象列表數(shù)據(jù)示例
本文實(shí)例講述了vue.js基于v-for實(shí)現(xiàn)批量渲染 Json數(shù)組對(duì)象列表數(shù)據(jù)。分享給大家供大家參考,具體如下:
Vuejs的出現(xiàn)減輕了對(duì)DOM的直接操作,同時(shí)它提供的 v-for 渲染列表數(shù)據(jù)也給我們提供了很大的方便。即使是復(fù)雜的 Json數(shù)組對(duì)象,也可以使用 多層嵌套的 v-for 實(shí)現(xiàn),格式如下:
<div v-for="(item,index) in items"> <div v-for="(list,index) in item.lists"></div> <div>
假設(shè)當(dāng)前的HTML,VUE 文本格式如下:
<div id="app" class="columns">
<div class="column">
<div class="card">
<div class="card-content">
<div id="data" class="columns is-multiline ">
<div class="column is-half">
<div class="media">
<div class="media-content">
<p class="has-text-weight-bold">職業(yè)知識(shí)</p>
<p class="help">生涯樹提供的職業(yè)數(shù)據(jù)框架,可以從職業(yè)能力、知識(shí)、技能、活動(dòng)、內(nèi)容方面進(jìn)行探索和規(guī)劃</p>
</div>
</div>
<div class="message-body">
<div class="field buttons">
<a>興趣:</a>
<span>常見的任務(wù)和環(huán)境的偏好</span>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
需要渲染的JSON數(shù)組對(duì)象格式如下:
var allData = [
{
"id":"職業(yè)知識(shí)",
"name":"關(guān)于各行業(yè)職業(yè)信息的分析,主要因素分析",
"lists":[
{
"title":"興趣",
"describe":"常見的任務(wù)和環(huán)境的偏好"
},
{
"title":"價(jià)值觀",
"describe":"個(gè)人滿意度的關(guān)鍵方面"
},
{
"title":"技能",
"describe":"學(xué)習(xí)發(fā)展、組織協(xié)作和資源管理的發(fā)達(dá)能力"
}
]
},
{
"id":"職業(yè)擴(kuò)展",
"name":"提供除本職業(yè)之外的擴(kuò)展知識(shí)等各個(gè)方面",
"lists":[
{
"title":"活動(dòng)",
"describe":"常見的工作行為類型"
},
{
"title":"內(nèi)容",
"describe":"工作性質(zhì)的物理和社會(huì)因素"
},
{
"title":"能力",
"describe":"個(gè)人基本持久屬性"
}
]
}
];
使用VUE操作渲染列表,先對(duì)文本分配對(duì)應(yīng)的字段值,格式如下:
<div class="column is-half" v-for="(item, index) in items">
<div class="media">
<div class="media-content">
<p class="has-text-weight-bold">{{ item.id }}</p>
<p class="help">{{ item.name }}</p>
</div>
</div>
<div class="message-body" v-for="(list, index) in item.lists">
<div class="field buttons" >
<a>{{ list.title}}:</a>
<span>{{ list.describe}}</span>
</div>
</div>
</div>
JS操作,引入 vuejs,創(chuàng)建實(shí)例渲染到指定對(duì)象(引入鏈接請(qǐng)移步到官網(wǎng) https://cn.vuejs.org/)
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.16/dist/vue.js"></script>
var vm = new Vue({ el: '#app', data: { items:allData }})
VUE渲染列表數(shù)據(jù)完成,就是這么簡(jiǎn)單。接下來看看 原生JS 是如何渲染列表數(shù)據(jù)的:
原生JS操作數(shù)組取值:循環(huán)。使用 for in 直接操作對(duì)象,或者 for循環(huán)直接取值,格式如下:
for(var key in values){};for(var i=0;i<values.length;i++){},根據(jù)情況取任意一種方式,以為演示兩種方式的使用
function Id(id) {
return document.getElementById(id); //獲取模塊的ID
}
function getData(allData) {
var data = Id("data");
var html='';
for(var i in allData){ //外層循環(huán)獲取標(biāo)志信息
var list = '';
for(var j=0;j<allData[i].lists.length;j++){ //內(nèi)層循環(huán)渲染詳細(xì)列表項(xiàng)
list+='<div class="message-body">'+
'<div class="field buttons">'+
'<a class=" ">'+allData[i].lists[j].title+':</a>'+
'<span>'+allData[i].lists[j].describe+'</span>'+
'</div>'+
'</div>';
}
html+='<div class="column is-half">'+
'<div class="media">'+
'<div class="media-content">'+
'<p class="has-text-weight-bold">'+allData[i].id+'</p>'+
'<p class="help">'+allData[i].name+'</p>'+
'</div>'+
'</div>'+list+ //將內(nèi)層渲染好的列表項(xiàng)模塊添加到外層大模塊中
'</div>';
}
data.innerHTML = html; //像指定的ID模塊追加內(nèi)容
}
//調(diào)用渲染數(shù)據(jù)方法并傳遞參數(shù) JSON數(shù)組對(duì)象
getData(allData);
最終,VUE ,原生JS 渲染出來的列表數(shù)據(jù)效果均如下:

希望本文所述對(duì)大家vue.js程序設(shè)計(jì)有所幫助。
相關(guān)文章
Vue動(dòng)態(tài)組件component的深度使用說明
這篇文章主要介紹了Vue動(dòng)態(tài)組件component的深度使用說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
Vue resource三種請(qǐng)求格式和萬能測(cè)試地址
這篇文章主要介紹了Vue-resource三種請(qǐng)求格式和萬能測(cè)試地址,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09
Vue循環(huán)遍歷選項(xiàng)賦值到對(duì)應(yīng)控件的實(shí)現(xiàn)方法
這篇文章主要介紹了Vue-循環(huán)遍歷選項(xiàng)賦值到對(duì)應(yīng)控件的實(shí)現(xiàn)方法啊,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06
vue實(shí)現(xiàn)element上傳多張圖片瀏覽刪除功能
這篇文章主要介紹了vue實(shí)現(xiàn)element上傳多張圖片瀏覽刪除功能,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-10-10
Vue路由之JWT身份認(rèn)證的實(shí)現(xiàn)方法
這篇文章主要介紹了Vue路由之JWT身份認(rèn)證的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
vue項(xiàng)目如何使用$router.go(-1)返回時(shí)刷新原來的界面
這篇文章主要介紹了vue項(xiàng)目如何使用$router.go(-1)返回時(shí)刷新原來的界面問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09

