Vue(8)列表渲染v-for「建议收藏」

Vue(8)列表渲染v-for「建议收藏」循环在模板中可以用v-for指令来循环数组,对象等。循环数组我们可以用v-for指令基于一个数组来渲染一个列表。v-for指令需要使用iteminitems形式的特殊语法,其中it

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

循环

在模板中可以用v-for指令来循环数组,对象等。
 

循环数组

我们可以用 v-for 指令基于一个数组来渲染一个列表。v-for 指令需要使用 item in items形式的特殊语法,其中 items 是源数据数组,而 item 则是被迭代的数组元素的别名。

<div id="app">
<ul>
  <li v-for="item in items">{{item.message}}</li>
</ul>
</div>
<script>
  const app = new Vue({
    el: "#app",
    data: {
      items: [
        {message: 'Hello'},
        {message: 'World'},
      ]
    }
  })
</script>

结果:

Hello
World

 
v-for 还支持一个可选的第二个参数,即当前项的索引。

<div id="app">
<ul>
  <li v-for="(item, index) in items">{{index+1}}.{{item.message}}</li>
</ul>
</div>

注意:索引index是放在item之后
结果:

1.Hello
2.World

你也可以用 of 替代 in 作为分隔符,因为它更接近 JavaScript 迭代器的语法:

<div v-for="item of items"></div>

 

循环对象

循环对象跟循环数组是一样的。并且都可以在循环的时候使用接收多个参数。示例代码如下:

<div id="app">
    <div v-for="value in person">
        {{value}}
    </div>
</div>
<script>
    let vm = new Vue({
        el: "#app",
        data: {
            person: {
                "username": "甲壳虫",
                "age": 18,
                "homepage": "https://www.cnblogs.com/jiakecong/"
            }
        }
    });
</script>

结果:

甲壳虫
18
https://www.cnblogs.com/jiakecong/

你也可以提供第二个的参数为 property 名称 (也就是键名):

<div v-for="(value, key) in person">
  {{key}}:{{value}}
</div>

结果:

username:甲壳虫
age:18
homepage:https://www.baidu.com/

还可以用第三个参数作为索引:

<div v-for="(value, key, index) in person">
  {{index}}.{{key}}:{{value}}
</div>

结果:

0.username:甲壳虫
1.age:18
2.homepage:https://www.baidu.com/

 

保持状态:

循环出来的元素,如果没有使用key元素来唯一标识,如果后期的数据发生了更改,默认是会重用的,并且元素的顺序不会跟着数据的顺序更改而更改。比如:

<div id="app">
  <div v-for="book in books">
    <label for="book">{{book}}</label>
    <input type="text" :placeholder="book">
  </div>
  <button @click="changeBooks">更换图书</button>
</div>
<script>
  let vm = new Vue({
    el: "#app",
    data: {
      books: ['三国演义','水浒传','红楼梦','西游记']
    },
    methods: {
      changeBooks: function(event){
        this.books.sort((x,y) => {
          return 5 - parseInt(Math.random()*10)
        });
      }
    }
  });
</script>

我们会发现,如果我们在input标签中输入了值,然后点击更换图书,你会发现即使数据更改了,input并不会跟着数据的更改而更改
Vue(8)列表渲染v-for「建议收藏」
这时候我们只需要在v-for的时候加上一个key属性就可以了。示例代码如下:

<div v-for="(book,index) in books" v-bind:key="book">
    <label for="book">{{book}}</label>
    <input type="text" v-bind:placeholder="book">
</div>

Vue(8)列表渲染v-for「建议收藏」
注意,key只能是整形,或者是字符串类型,不能为数组或者对象。
 

触发视图更新:

Vue对一些方法进行了包装和变异,以后数组通过这些方法进行数组更新,会出发视图的更新。这些方法如下:

1.push():添加元素的方法。

this.books.push("甲壳虫")

2.pop():删除数组最后一个元素。

 this.books.pop()

3.shift():删除数组的第一个元素

this.books.shift()

4.unshift(item):在数组的开头位置添加一个元素

this.books.unshift("甲壳虫")

5.splice(start: number, deleteCount: number, ...items: T[]):向数组中添加或者删除或者替换元素

  • start参数代表从第几个下标开始
  • deleteCount代表删除几个数,可以为0代表不删
  • items代表增加的对象
 // 向books第0个位置添加元素
 this.books.splice(0,0,"甲壳虫")
 // 下标从0开始,删除2个元素
 this.books.splice(0,2)
 // 下标从0开始,替换2个元素
 this.books.splice(0,2,'甲壳虫','aaaa')

 

6.sort(function):排序

 this.books.sort(function(x,y){
     // 取两个随机数排序
     a = Math.random();
     b = Math.random();
     return a-b;
 });

7.reverse():将数组元素进行反转

this.books.reverse();

还有一些Vue没有包装的方法,比如filterconcatslice,如果使用这些方法修改了数组,那么只能把修改后的结果重新赋值给原来的数组才能生效。比如:

this.books = this.books.filter(function(x){
    return x.length>3?false:true;
})

 

视图更新注意事项

1.直接修改数组中的某个值是不会出发视图更新的。比如:

this.books[0] = '甲壳虫';

这种情况应该改成用splice或者是用Vue.set方法来实现:

Vue.set(this.books,0,'甲壳虫');

2.如果动态的给对象添加属性,也不会触发视图更新。只能通过Vue.set来添加。比如:

<div id="app">
<ul>
  <li v-for="(value,name) in person" @click="changePerson">{{name}}:{{value}}</li>
</ul>
</div>
<script>
  let app = new Vue({
    el: "#app",
    data: {
      person: {"username": '甲壳虫'}
    },
    methods: {
      changePerson: function(event){
        // 直接修改this.person.age是没有效果的
        // this.person.age = 18;
        Vue.set(this.person,'age',18)
      }
    }
  });
</script>
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/166105.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 软件测试-因果图与判定表「建议收藏」

    软件测试-因果图与判定表「建议收藏」因果图简介等价类划分法和边界值法都是着重考虑到了输入条件,但是没有考虑到输入条件的组合与输入条件的相互制约关系。这样有可能忽视了很多错误如果测试时考虑到了各种组合,测试所有组合将是一个天文数字,因此需要考虑采用一种适用与多种条件组合相应产生多种动作的形式来进行测试用例的设计,这就需要因果图(逻辑模型)因果图思想一些程序的功能可以用判定表的形式来表示,根据输入条件的组合情况来规定相应的操作…

    2022年8月14日
    8
  • (精华)转:RDD:创建的几种方式(scala和java)

    (精华)转:RDD:创建的几种方式(scala和java)转:https://blog.csdn.net/weixin_38750084/article/details/82769600下面开始初始化sparkspark程序需要做的第一件事情,就是创建一个SparkContext对象,它将告诉spark如何访问一个集群,而要创建一个SparkContext对象,你首先要创建一个SparkConf对象,该对象访问了你的应用程序的信息比如下面的代码是运行在spark模式下 publicclasssparkTestCon{ …

    2022年6月3日
    41
  • 0x80ff0000解决方法_蓝屏代码0x0000050修复

    0x80ff0000解决方法_蓝屏代码0x0000050修复问题描述:在F盘新建文件夹或文件的时候提示0x8000FFFF灾难性错误;解决方法:1、在F盘的位置,右击选择属性2、在弹出的窗口中选择工具,点击检查3、根据系统提示进行响应的驱动扫描与修复,就酱紫咯…

    2022年9月25日
    0
  • 零拷贝详解_深拷贝和浅拷贝如何实现

    零拷贝详解_深拷贝和浅拷贝如何实现一、概念1、用户态与内核态⽤户态和内核态是操作系统的两种运⾏状态。(1)内核态:处于内核态的CPU可以访问任意的数据,包括外围设备,⽐如⽹卡、硬盘等,处于内核态的CPU可以从⼀个程序切换到另外⼀个程序,并且占⽤CPU不会发⽣抢占情况,⼀般处于特权级0的状态我们称之为内核态。(2)⽤户态:处于⽤户态的CPU只能受限的访问内存,并且不允许访问外围设备,⽤户态下的CPU不允许独占,也就是说CPU能够被其他程序获取。注意:1)为什么要有⽤户态和内核态呢?  这个主要是访问能⼒的限制

    2022年9月13日
    2
  • 字符串数组转化为list_字符串 java list

    字符串数组转化为list_字符串 java listpublicclassTest{publicstaticvoidmain(String[]args){String[]animals={“dog”,”cat”,”rabbit”,”fish”};ListanimalList=Arrays.asList(animals);for(Stringstr:animalList){System.out.println(str…

    2022年8月23日
    5
  • FreeSync是什么

    FreeSync是什么FreeSync由AMD开发,是一种动态刷新率功能,通过嵌入式和外部DisplayPort面板实现,部分AMDGPU中的FreeSync技术解决了处理器和显示器之间的通信问题,消除了图像撕裂和波动,从而轻松实现流畅的游戏体验。于2014年首次宣布与Nvidia的专有G-Sync竞争。AMD已与VESA(视频电子标准协会)合作,将DisplaySync的支持添加到DisplayPort1.2a标准,以及后来的HDMI,然后将其用于FreeSync技

    2022年6月10日
    283

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号