时间:2021-05-25
vue实现加载并展示后台数据的tab选项卡
vue用于渲染页面
jquery用于方法实现动态效果
<div class="content"> <!-- change方法, 数值改变触发 --> <select v-on:change="getData()" name="" id="dataSelect"> <option value="" v-bind:name="index" v-for="(value, index) in items">{{value.date}}</option> </select> <!-- 为name属性添加当前索引值 --> <ul v-on:click="toFlow($event)" v-bind:name="i" class="flowData" v-for="(flow, i) in flows"> <li class="li1"> {{flow.name.fullName}}<br> {{flow.name.time}} </li> <li class="li2"> {{flow.val1}} </li> <li class="li3"> {{flow.val2}} </li> <li class="li4"> {{flow.val3}} </li> </ul> </div><script> var vm = new Vue({ el: "#app", data: { user: {}, items: [], flows: [] }, methods: { // 根据option数值替换数据 getData: function() { var optionIndex = $('#dataSelect option:selected').attr("name"); //选中的值 vm.flows = vm.items[optionIndex].flowsMonth; }, toFlow: function(event) { // 点击li获取当前li父辈ul的name属性值 var flowIndex = event.target.parentNode.getAttribute("name"); var flow = (vm.flows[flowIndex]); $.ajax({ url: 'php/test.php', type: 'POST', dataType: "json", data: { flow: flow }, success: function(data) { console.log(data); } }) } } }) $(function(){ $.ajax({ url: 'json/items.json', type: 'GET', dataType: "json", success: function(data) { vm.user = data.user; vm.items = data.flows; // 初始数据 vm.flows = vm.items[0].flowsMonth; } }) })</script>{ "flows": [ { "date": "2017年5月", "flowsMonth": [ { "name": { "fullName": "xxx 10G", "time": "当月有效" }, "val1": "200", "val2": "1.3", "val3": "2300" }, { "name": { "fullName": "xxx 10G", "time": "当月有效" }, "val1": "1", "val2": "2", "val3": "3" }, { "name": { "fullName": "xxx 10G", "time": "当月有效" }, "val1": "1", "val2": "2", "val3": "3" } ] }, { "date": "2017年6月", "flowsMonth": [ { "name": { "fullName": "xxx 10G", "time": "当月有效" }, "val1": "200", "val2": "1.3", "val3": "2300" }, { "name": { "fullName": "xxx 10G", "time": "当月有效" }, "val1": "1", "val2": "22", "val3": "33" }, { "name": { "fullName": "xxx 10G", "time": "当月有效" }, "val1": "12", "val2": "32", "val3": "13" } ] } , { "date": "2017年8月", "flowsMonth": [ { "name": { "fullName": "xxx 10G", "time": "当月有效" }, "val1": "200", "val2": "1.3", "val3": "2300" }, { "name": { "fullName": "xxx 10G", "time": "当月有效" }, "val1": "61", "val2": "542", "val3": "63" }, { "name": { "fullName": "xxx 10G", "time": "当月有效" }, "val1": "51", "val2": "22", "val3": "34" } ] } ]}以上这篇使用vue点击li,获取当前点击li父辈元素的属性值方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
整理文档,搜刮出一个vue如何获取点击事件源的方法,稍微整理精简一下做下分享。vueclick事件获取当前元素对象点击当前行获取下一行li2li3newVue(
主要分为三个部分,1:获取li元素2:如何填写对应的日期3:如何获取点击li元素的事件。1:通过节点间关系的属性children获取li元素(两个for循坏遍历
点击每个li节点,都弹出其文本值1,获取所有的li节点varliNodes=document.GetElementsByTagName("li");2,使用fo
排它思想:清除其它所有的没有选中元素的样式,只设置当前选中元素的样式html代码Title我是第1个li我是第2个li我是第3个li我是第4个li我是第5个li
有如下代码:复制代码代码如下:第1个li元素第2个li元素第3个li元素第4个li元素第5个li元素第6个li元素第7个li元素第8个li元素但是页面只显示前5