js根据name获取value_Vue.js中vfor列表渲染指令的使用

点击蓝字750e0cfcfe65ac983e8f8091c4dbd3bc.png关注我们!每天获取最新的编程小知识!

源 / php中文网      源 / www.php.cn

本篇文章将给大家介绍如何循环数组并在vuejs渲染项目列表,希望对需要的朋友有所帮助!

fdf2e94dc1ac3a124e595b7ccaeb3829.png

(查看原文请点击本文末尾左下角:

v-for指令

Vuejs为我们提供了一个v-for指令,用于将项目列表渲染到dom中。

v-for指令的语法

v-for="user in users"

示例

  for="user in users">{{user.name}}

 export default{

     data:function(){

         return{

             users:[

                 {id:1,name:"king"},

                 {id:2,name:"gowtham"},

                 {id:3,name:"ooops"},

             ]

         }

     }

 }

在上面的代码中,我们使用v-for指令循环遍历users数组,这样在每次循环中user变量都指向数组中出现的不同对象。

a7d229f0260dfa06f7c87244f758a860.png

key属性

当使用v-for指令时,我们需要向该元素添加一个key属性,因为vuejs需要根据提供的key跟踪列表项。

注意:密钥应该是唯一的

让我们将key属性添加到模板中。

  for="user in users" :key="user.id">

    {{user.name}}

 export default{

     data:function(){

         return{

             users:[

                 {id:1,name:"king"},

                 {id:2,name:"gowtham"},

                 {id:3,name:"ooops"},

             ]

         }

     }

 }

users数组中,id属性对每个对象都是唯一的,因此我们将它传递给key属性。

我们还可以访问数组中每个项的索引。

  for="(user,index) in users" :key="user.id">

    {{user.name}} {{index}}

遍历对象

我们还可以通过使用v-for指令循环JavaScript对象。

    for="(value, key) in person" :key="key">

      {{key}} : {{ value }}

export default {

  data: function() {

    return {

      person: {

        firstName: "Rim",

        lastName: "Doe",

        age: 20,

        eyeColor: "blue"

      }

    };

  }

};

1abc1bb112420552cfa771136966994a.png

注意:在对象中,我们需要先提取value,然后是key

本篇文章就是关于Vue.js中v-for列表渲染指令的使用介绍,希望对需要的朋友有所帮助!

a93abfbadb84462cf79d8f15ad64c9fe.gif

-END-

声明:本文选自「 php中文网 」,搜索「 phpcnnew 」即可关注!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,您的问题是关于Vue.js实现前端列表多条件筛选的问题,同时涉及Vue的key属性的重复问题。 对于实现前端列表多条件筛选,一种常见的做法是使用计算属性来过滤列表数据。具体来说,可以定义一个包含各种筛选条件的data对象,然后在计算属性根据这些条件来过滤原始的列表数据。例如: ``` <template> <div> <label>关键字:</label> <input v-model="filter.keyword"> <label>状态:</label> <select v-model="filter.status"> <option value="">全部</option> <option value="1">已完成</option> <option value="0">未完成</option> </select> <ul> <li v-for="item in filteredList" :key="item.id">{{ item.name }}</li> </ul> </div> </template> <script> export default { data() { return { list: [ { id: 1, name: '任务1', status: 1 }, { id: 2, name: '任务2', status: 0 }, { id: 3, name: '任务3', status: 1 } ], filter: { keyword: '', status: '' } } }, computed: { filteredList() { return this.list.filter(item => { return item.name.indexOf(this.filter.keyword) !== -1 && (this.filter.status === '' || item.status.toString() === this.filter.status) }) } } } </script> ``` 在上面的代码,我们定义了一个包含列表数据和筛选条件的data对象,其filter对象包含了关键字和状态两个筛选条件。然后,在计算属性filteredList,我们使用filter函数来过滤原始列表数据,其关键字筛选使用了JavaScript的字符串indexOf方法,状态筛选则使用了三目运算符来判断是否需要进行状态筛选。 在这个例子,我们没有显式地使用key属性来指定每个列表项的唯一标识符。这是因为Vue.js默认会使用每个列表项的下标作为其key。然而,如果列表数据是动态的,那么可能会出现某些列表项的下标发生变化的情况,从而导致Vue.js无法正确地更新DOM。为了解决这个问题,我们可以显式地指定每个列表项的唯一标识符,例如使用item.id作为key。这样可以确保每个列表项的key始终唯一,从而避免出现更新DOM时的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值