如何从v-for(vue.js)中读取数据?

问题描述 投票:1回答:2

鉴于下一个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对象中。

javascript vue.js vue-component vuex vue-router
2个回答
1
投票

你必须传递索引键,使用是从结果的位置获取。

将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);
     });
     }
   });


0
投票

要在结果数组中获取要访问的数据,可以在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

© www.soinside.com 2019 - 2024. All rights reserved.