vue指令之v-forkey属性

一、 v-for

1. v-for遍历数组

<div id="app">
<h3>好饿,我好想吃~~~~</h3>
<ul v-for="menu in list">
<li>{{menu}}</li>
</ul>
</div>
<script>
var vm = new Vue({
el: '#app',
data: {
list:['鸭血粉丝','螺蛳粉','大碗米线','黄焖鸡','地锅鸡']
}
})
</script>

来吧展示:



如果需要索引,则给v-for传入一个参数,index表示的是索引(名称任意取)

<div id="app">
<h3>好饿,我好想吃~~~~</h3>
<ul v-for="(menu,index) in list">
<li>安排一下啵:{{index}}--------{{menu}}</li>
</ul>
</div>

2. v-for循环数组对象 01



传入多个对象:

<div id="app">
<h3>好饿,我好想吃~~~~</h3>
<!-- <ul v-for="(menu,index) in list">-->
<!-- <li>安排一下啵:{{index}}--------{{menu}}</li>-->
<!-- </ul>-->
<ul v-for="(menu,index) in list">
<li>第{{menu.num}}好吃--------{{menu.name}}-------索引{{index}}</li>
</ul>
</div>
<script>
var vm = new Vue({
el: '#app',
data: {
// list:['鸭血粉丝','螺蛳粉','大碗米线','黄焖鸡','地锅鸡']
list:[
{num:1,name:'鸭血粉丝'},
{num:2,name:'螺蛳粉'},
{num:3,name:'大碗米线'},
{num:4,name:'黄焖鸡'},
{num:5,name:'地锅鸡'}
]
}
})
</script>

2. v-for循环数组对象 02

<div id="app">
<ul>
<li v-for="(val,key,i) in menu">键:{{key}} ----- 值:{{val}} ----- 索引下标:{{i}}</li>
</ul>
</div>
<script>
var vm = new Vue({
el: '#app',
data: {
menu:{
num:1,
name:'小米椒爱上小公鸡',
message:'噢~~~这该死的美味'
}
}
})
</script>

3.v-for循环数值

<p v-for="(item,i) in 10">这是数值:{{item}}-----这是索引:{{i}}</p>

二、key属性的使用

通过一个案例来引入key

<body>
<div id="app">
<div>
<label>Id:
<input type="text" v-model="num">
</label>
<label>Name:
<input type="text" v-model="name">
</label> <input type="button" value="添加" @click="add">
</div>
<ul>
<li v-for="(menu,i) in list">
<input type="checkbox"/>排名:{{menu.num}}------美味:{{menu.name}}
</li>
</ul>
</div>
<script>
var vm = new Vue({
el: '#app',
data: {
num: '',
name: '',
list:[
{num:1,name:'鸭血粉丝'},
{num:2,name:'螺蛳粉'},
{num:3,name:'大碗米线'},
{num:4,name:'黄焖鸡'},
{num:5,name:'地锅鸡'}
]
},
methods: {
add() { // 添加方法
this.list.unshift({ num: this.num, name: this.name })
}
}
})
</script>
</body>

来吧展示:

问题:

当选中状态的时候取添加元素,我们发现,选中的状态自动跳到下一个input中取,并没有保持它原来的元素的状态

原因:在默认情况下,我们从data把一个数组渲染到页面上的时候,就不会再关注这个状态了

解决方法:

给元素绑定一个key属性 v-bind:key="里面是唯一的标识符"

这个状态和当前循环的数值做了一个绑定关系,所以状态会存在

所以只要涉及到v-for循环,建议给循环的每一项都加上:key这个属性

 <li v-for="(menu,i) in list"  :key="menu.num">

来吧展示:

vue学习笔记(一) ---- vue指令(v-for 和 key 属性)的更多相关文章

  1. 【Vue学习笔记】—— vue的基础语法 { }

    学习笔记 作者:oMing vue v-on: 简称 @ <div id='app'> <button v-on:click='Show1'> </button> ...

  2. vue学习笔记(二)vue的生命周期和钩子函数

    前言 通过上一章的学习,我们已经初步的了解了vue到底是什么东西,可以干什么,而这一篇博客主要介绍vue的生命周期和它常用的钩子函数,如果有学过java的园友可能有接触到在学习servlet的时候学过 ...

  3. vue学习笔记:vue的认识与特点与获取

    Vue了解 Vue:读作 view Vue是一个渐进式框架 与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计. Vue 的核心库只关注视图层,并且非常容易学习,非常容易与其它库或已有项目整 ...

  4. Vue学习笔记之Vue指令系统介绍

    所谓指令系统,大家可以联想咱们的cmd命令行工具,只要我输入一条正确的指令,系统就开始干活了. 在vue中,指令系统,设置一些命令之后,来操作我们的数据属性,并展示到我们的DOM上. OK,接下来我们 ...

  5. vue学习笔记—bootstrap+vue用户管理

    vue,读音view,简单易用的前端框架.特点如下: 1.一个mvvm的前端框架,内部做好了html中dom对象和后台用js语言定义的变量的双向绑定 2.中国人尤雨溪维护的个人项目,中文资料多,和go ...

  6. VUE学习笔记之vue cli 构建项目

    一.环境搭建: 1.安装node.js 从node.js官网下载并安装node,安装过程很简单,一路"下一步"就可以了.安装完成之后,打开命令行工具(win+r,然后输入cmd), ...

  7. Vue学习笔记之Vue知识点补充

    0x00 修饰符 .lazy 在默认情况下,v-model 在每次 input 事件触发后将输入框的值与数据进行同步 .你可以添加 lazy 修饰符,从而转变为使用 change 事件进行同步: &l ...

  8. Vue学习笔记之Vue学习前的准备工作

    0x00 起步 1.扎实的HTML/CSS/Javascript基本功,这是前置条件. 2.不要用任何的构建项目工具,只用最简单的<script>,把教程里的例子模仿一遍,理解用法.不推荐 ...

  9. Vue学习笔记之Vue组件

    0x00 前言 vue的核心基础就是组件的使用,玩好了组件才能将前面学的基础更好的运用起来.组件的使用更使我们的项目解耦合.更加符合vue的设计思想MVVM. 那接下来就跟我看一下如何在一个Vue实例 ...

  10. Vue学习笔记之Vue的使用

    0x00 安装 对于新手来说,强烈建议大家使用<script>引入 0x01 引入vue.js文件 我们能发现,引入vue.js文件之后,Vue被注册为一个全局的变量,它是一个构造函数. ...

随机推荐

  1. java判断手机号三大运营商归属的工具类

    package com.tymk.front.third; import java.util.regex.Pattern; public class OperatorsUtil { /** * 中国电 ...

  2. jdk线程池ThreadPoolExecutor工作原理解析(自己动手实现线程池)(一)

    jdk线程池ThreadPoolExecutor工作原理解析(自己动手实现线程池)(一) 线程池介绍 在日常开发中经常会遇到需要使用其它线程将大量任务异步处理的场景(异步化以及提升系统的吞吐量),而在 ...

  3. Linux *.service文件详解

    什么是systemd service? systemd service是一种以.service 结尾的配置文件,是一个专用于Linux操作系统的系统与服务管理器.简单来说,用于后台以守护精灵(daem ...

  4. element-ui 对话框dialog里使用echarts,报错'dom没有获取到'?

    给el-dialog添加@open="open()" 在刚进入页面的时候对话框是关闭的,echarts不进行获取dom,当点击对话框出来的时候,有个opened事件,在这个事件里边 ...

  5. Datawhale组队学习_Task04:详读西瓜书+南瓜书第5章

    第5章 神经网络 5.1 神经元模型 基本定义:神经网络是由具有适应性的简单单元组成的广泛并行互联的网络,它的组织能够模拟生物神经系统对真实世界物体所做出的交互反应. M-P神经元模型:   在此模型 ...

  6. Fastjson漏洞+复现

    1.漏洞介绍 ​​FastJson在解析json的过程中,支持使用autoType来实例化某一个具体的类,并调用该类的set/get方法来访问属性.通过查找代码中相关的方法,即可构造出一些恶意利用链. ...

  7. 【Java SE】Day09 继承、super、this、抽象类

    一.继承 1.概述 多个类具有相同属性和行为,共性抽取到一个类中(父类) 父类更通用,子类更具体 2.继承后的成员变量 本类:this.成员变量名 父类:super.成员变量名 3.继承后的成员方法 ...

  8. pandas中groupby的使用

    一.缘由 在爬取大量的数据之后,需要对数据进行分组的处理,于是就使用了groupby,但是我需要的并不是分组之后数据的聚合分析,我需要的是原生的某些数据.但是却找不到网上的相关案例.于是,我就自己尝试 ...

  9. 重学c#系列——linq(1) [二十七]

    前言 简单介绍一下linq,linq很多人其实用的很熟练了,但是有些人不知道自己用的是linq. 正文 在介绍linq 之前,先介绍一下集合. public interface ICollection ...

  10. 精华推荐 |【深入浅出Sentinel原理及实战】「原理探索专题」完整剖析Alibaba微服务架构体系之轻量级高可用流量控制组件Sentinel(1)

    Sentinel是什么?不要概念混淆啊! 注意:本Sentinel与Redis服务Sentinel是两回事,压根不是一个概念,请大家不要混肴. Alibaba的Sentinel Sentinel是由阿 ...