您好,登录后才能下订单哦!
这篇文章主要介绍了Vue的指令v-for怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue的指令v-for怎么使用文章都会有所收获,下面我们一起来看看吧。
在data中定义普通数组
data:{ list:[1,2,3,4,5,6] }
在html中使用 v-for 指令渲染
<p v-for="(item,i) in list">--索引值--{{i}} --每一项--{{item}}</p>
在data中定义对象数组
data:{ list:[1,2,3,4,5,6], listObj:[ {id:1, name:'zs1'}, {id:2, name:'zs2'}, {id:3, name:'zs3'}, {id:4, name:'zs4'}, {id:5, name:'zs5'}, {id:6, name:'zs6'}, ] }
在html中使用 v-for 指令渲染
<p v-for="(user,i) in listObj">--id--{{user.id}} --姓名--{{user.name}}</p>
在data中定义对象
data:{ user:{ id:1, name:'托尼.贾', gender:'男' } }
在html中使用 v-for 指令渲染
<p v-for="(val,key) in user">--键是--{{key}}--值是--{{val}}</p>
<!-- 注意:如果使用v-for迭代数字的话,前面 count 的值从 1 开始--> <p v-for="count in 10">这是第{{count}}次循环</p>
完整代码:
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> </head> <body> <div id='app'> <!--v-for循环普通数组--> <p v-for="(item,i) in list">--索引值--{{i}} --每一项--{{item}}</p> <br/> <!--v-for循环对象数组--> <p v-for="(user,i) in listObj">--id--{{user.id}} --姓名--{{user.name}}</p> <br/> <!--注意,在遍历对象的键值对的时候,除了有 val 和 key,在第三个位置还有一个索引--> <p v-for="(val,key) in user">--键是--{{key}} --值是--{{val}}</p> <br/> <!-- in 后面我们放过数组、对象数组、对象,还可以放数字--> <!-- 注意:如果使用v-for迭代数字的话,前面 count 的值从 1 开始--> <p v-for="count in 10">这是第{{count}}次循环</p> </div> </body> <script src="vue.min.js"></script> <script> var vm = new Vue({ el:'#app', data:{ list:[1,2,3,4,5,6], listObj:[ {id:1, name:'zs1'}, {id:2, name:'zs2'}, {id:3, name:'zs3'}, {id:4, name:'zs4'}, {id:5, name:'zs5'}, {id:6, name:'zs6'}, ], user:{ id:1, name:'托尼.贾', gender:'男' } } }); </script> </html>
截图:
在vuejs中,v-for 的使用是比较常见的,它允许您在模板代码中编写for循环。那么在使用v-for的时候,可曾思考过使用这个指令的一些技巧吗?
在介绍它的使用技巧之前,我先介绍下它的基本用法吧,在vue中v-for可以遍历数组、对象、字符串,但是用的最多的还是遍历数组,基本方法如下:
<div id="app"> <ul> <li v-for='item in list'> {{ item.name }} </li> </ul> </div>
可能有些初学者在使用的过程中,不会考虑太多的使用技巧,直接遍历定义在data中的数据,其实vue在设计的初衷,也考虑到了这个问题,如果频繁使用data中的数据,可能会造成一些性能上的消耗,是相当不友好的。
在本篇文章中,我将介绍六种方法来使你的 v-for 代码更加精确,可预测和强大。
建议在遍历数据的时候,都尽可能的加上key,设置一个惟一的键属性,它可以确保组件以您期望的方式工作。有些时候,可能使用索引index也可以,但是在一些特定的场景下,比如多场景登录下,如果不使用key来标识当前使用的登录方式,那么可能会造成数据的紊乱问题,如果数据量比较大, 页面的数据更新时会造成渲染数据消耗很大的性能甚至出现不可预测的bug,如果我们对每个元素都有唯一的键引用,那么我们就可以更好地准确地预测DOM将如何操作,就可以避免很多不必要的问题出现。
<div id="app"> <ul> <li v-for='item in list' :key='item.id'> {{ item.name }} </li> </ul> </div>
一个超级常见的错误是使用 v-if 来过滤 v-for 循环的数据。Vuejs优先考虑 v-for 而不是 v-if,这意味着组件将循环遍历每个元素,然后检查 v-if 条件以确定是否应渲染。因此,实际上,无论条件是什么,都将遍历数组。尽管这看起来很直观,但它会导致一个巨大的性能问题
/*千万不要这样写,切记切记*/ <div id="app"> <ul> <li v-for='item in list' :key='item.id' v-if="item.price<50" > {{ item.name }} </li> </ul> </div>
为避免上述问题,我们应该在遍历模板中的数据之前对其进行过滤。有两种非常相似的方法
使用计算属性
使用过滤方法
首先,我们只需要设置一个计算属性,为了获得与之前的v-if相同的功能,代码应如下所示。
<div id="app"> <ul> <li v-for='item in underPrice' :key='item.id' > {{ item.name }} </li> </ul> </div>
<script> export default { data () { return { list: [] } }, computed: { underPrice: function () { return this.list.filter(item=> item.price < 50) } } } </script>
计算属性是作为属性使用的,并不是方法。使用computed,可以将数据做缓存处理,在每次渲染数据的时候,会优先在缓存在找该数据,如果有了直接从缓存中取出渲染,如果没有的话再重新获取。这样也大大的提高了性能。
或者可以使用方式来进行变量的筛选以及处理再做遍历
<div id="app"> <ul> <li v-for='item in underPriceHandle(50)' :key='item.id' > {{ item.name }} </li> </ul> </div>
<script> export default { data () { return { list: [] } }, methods: { underPriceHandle: function (price) { return this.list.filter(item=> item.price < price) } } } </script>
尽管大多数情况下,v-for 用于遍历数组或对象,但在某些情况下,我们肯定只希望循环执行一定次数。
例如,假设我们正在为在线商店创建一个分页系统,而我们只希望每页显示10个产品。使用一个变量来跟踪当前的页码,我们可以像这样处理分页。
<ul> <li v-for='index in 10' :key='index'> {{ books[page * 10 + index] }} </li> </ul>
除了遍历数组和访问每个元素之外,我们还可以跟踪每个项的索引。
为此,我们必须在项目后添加一个索引值,它非常简单,可用于分页,显示列表索引,显示排名等。
<ul> <li v-for='(item, index) in products' :key='item.id' > {{ index }}----{{ item.name }} </li> </ul>
我们也可以使用v-for轻松地遍历对象的键值对。
与访问元素的索引类似,我们必须向循环中添加另一个值。如果我们用一个参数遍历一个对象,我们将遍历所有的项。
如果我们添加另一个参数,我们将获得items 和 key,如果添加第三个,我们还可以访问 v-for 循环的索引。
<ul> <li v-for='(list, index) in lists' :key='list.id' > <span v-for='(item, key, index) in list' :key='key'> {{ item }} </span> </li> </ul>
关于“Vue的指令v-for怎么使用”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Vue的指令v-for怎么使用”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。