鉴于下一个v-for:
<div class="container-fluid" id="networdapp" style="display:none;">
<div class="row" >
<div v-for="result in results" class="col-sm-6" >
<div class="card m-3 h-240 bg-light" >
<div class="card-header text-center" > {{ result.title }} </div>
<div class="card-body" style="height:200px" >
<p class="card-text" v-html="result.prevDesc"></p>
</div>
<div class="card-footer bg-transparent border-info">
<a href="/details" class="btn btn-info" @click="getData(result)" >Details</a>
</div>
</div>
</div>
</div>
</div>
以及下一个Vue.js脚本:
<script type="text/javascript">
const vm = new Vue({
el: '#networdapp',
data: {
results:[]
},
methods: {
getData: function(result){
window.alert($(this).parents("#networdapp").find(".card-header.text-center").outerHTML);
window.alert(document.getElementsByClassName("card-header").outerHTML);
window.alert(result.outerHTML);
}
},
mounted() {
axios.get('/getJson')
.then(response => {
this.results = response.data;
})
.catch( e => {
console.log(e);
});
}
});
</script>
我想从特定的迭代中获取数据,假设我单击v-for中第3个div的“Details”按钮,我想从第3个中获取{{result.title}}数据。是否可能?我一直在阅读Vue.js文档,但我没有找到任何关于从DOM读取数据的内容。如果不可能,那么如果没有Vue.js我怎么能这样做?还有其他选择吗?主要目标是获取此数据并将其放入将其传递到另一个网页的js对象中。
你必须传递索引键,使用是从结果的位置获取。
将for循环div更改为
<div v-for="(result,i) in results" :key="i" class="col-sm-6" >
还可以更改方法参数
<a href="/details" class="btn btn-info" @click="getData(i)" >Details</a>
并且该方法将获取索引键,在这里我使用控制台来查看您想要的result.title。你可以随意使用它。
getData: function(key){
console.log(this.results[key].title)
}
所以鉴于下一个v-for:
<div class="container-fluid" id="networdapp" style="display:none;">
<div class="row" >
<div v-for="(result,i) in results" :key="i" class="col-sm-6" >
<div class="card m-3 h-240 bg-light" >
<div class="card-header text-center" > {{ result.title }} </div>
<div class="card-body" style="height:200px" >
<p class="card-text" v-html="result.prevDesc"></p>
</div>
<div class="card-footer bg-transparent border-info">
<a href="/details" class="btn btn-info" @click="getData(i)" >Details</a>
</div>
</div>
</div>
</div>
以及下一个Vue.js脚本:
<script type="text/javascript">
const vm = new Vue({
el: '#networdapp',
data: {
results:[]
},
methods: {
getData: function(key){
console.log(this.results[key].title)
}
},
mounted() {
axios.get('/getJson')
.then(response => {
this.results = response.data;
})
.catch( e => {
console.log(e);
});
}
});
要在结果数组中获取要访问的数据,可以在v-for循环中使用索引
v-for="(result, index) in results"
你可以在这里检查文件https://vuejs.org/v2/guide/list.html
我还强烈建议您在v-for之后添加一个键属性,以帮助vue.js跟踪每个结果,请参阅https://vuejs.org/v2/guide/list.html#key