Vue.js高效前端开发 • 【Vue列表渲染】
文章目录
一、v-for指令
1、v-for指令使用
v-for指令
基于一个数组
来重复渲染元素。v-for指令
通常用于显示列表
和表格数据
。v-for指令
需要使用“item in items”
形式的特殊语法,其中items
是源数据数组
,而item
则是被迭代的数组元素
的别名。在v-for块
中,开发者可以访问父作用域
的属性。v-for
还支持一个可选的第二个参数
,即当前项的索引
。- 为了给Vue一个提示,以便它能跟踪每个行的
数据
,从而重用和重新排序现有元素
,v-for指令需要为每项提供一个唯一key属性
。
示例:
使用v-for显示员工信息列表
<!-- HTML代码: -->
<div id="app" style="margin:20px auto;width:600px">
<ul>
<li v-for="(item,index) in items" :key="index">
<a href="">{{ index }}.{{ item }}</a>
</li>
</ul>
</div>
// JavaScript代码:
var vm = new Vue({
el: "#app",
data: {
items:["部门管理","员工管理","职务管理"]
}
})
示例:
使用v-for指令显示单个员工信息
<!-- HTML代码: -->
<div id="app" style="margin:20px auto;width:600px">
<div v-for="(value,name,index) in emp">
{{ index }}.{{ name }} : {{ value }}
</div>
</div>
// JavaScript代码:
var vm = new Vue({
el: "#app",
data: {
emp:{
user:"赵五",
age:20,
job:"项目经理"
}
}
});
v-for指令还可以遍历一个对象的属性,其中,
v-for指令
可以提供第二个的参数为property名称
(也就是键名),还可以用第三个参数作为索引
。
当Vue正在更新使用v-for渲染的元素列表时,它默认使用
“就地更新”
的策略。如果数据项的顺序被改变,Vue将不会移动DOM元素
来匹配数据项
的顺序,而是就地更新每个元素,并且确保它们在每个索引位置
正确渲染。这个默认的模式是高效的,但是只适用于不依赖子组件状态
或`临时DOM状态``(例如:表单输入值)的列表渲染输出。
说明:
建议尽可能在使用v-for时提供`key属性`,除非遍历输出的DOM内容非常简单,或者是刻意依赖默认行为以获取性能上的提升。
注意:
不要使用对象或数组之类的非基本类型值作为v-for的key。请用字符串或数值类型的值。
2、实践练习(待更新)
二、计算属性
1、计算属性创建和使用
- 模板内的表达式非常便利,但是设计它们的初衷是用于简单运算的。在模板中放入太多的逻辑会让模板过重且难以维护。
例如
<div id="example">
{{ message.split('').reverse().join('') }}
</div>
在这个地方,模板不再是简单的声明式逻辑。你必须看一段时间才能意识到,这里是想要显示变量
message
的翻转字符串
。当你想要在模板中多次引用此处的翻转字符串时,就会更加难以处理。所以,对于任何复杂逻辑,都应当使用
计算属性
。在计算属性里可以完成各种复杂的逻辑,包括运算、函数调用等,最终会返回结果。
计算属性还可以依赖多个Vue实例的数据,只要其中任一数据变化,计算属性就会重新执行,视图也会更新。
所有的计算属性都以函数的形式写在Vue实例内的computed选项内,最终返回计算后的结果。
示例:
使用计算属性实现将英文语句按字母翻转
<!-- HTML代码: -->
<div id="app" style="margin:20px auto;width:600px">
<p>原字符串: "{{ message }}"</p>
<p>字符串转换后: "{{ reversedMessage }}"</p>
</div>
// JavaScript代码:
var vm = new Vue({
el: "#app",
data: {
message:"Failure is the mother of success."
},
computed: {
reversedMessage:function(){
return this.message.split("").reverse().join("");
}
}
})
示例的功能也可以使用Vue实例的选项
methods方法
实现,methods方法与计算属性区别是计算属性支持缓存
,所以对遍历大数组或做大量计算时,计算属性更高效。
示例:
使用计算属性实现对字符串数组根据关键字查找功能
<!-- HTML代码: -->
<div id="app" style="margin:20px auto;width:600px">
<span>字符串关键字:</span>
<input type="text" placeholder="请输入关键字..." v-model="wordKey"/>
<ul>
<li v-for="item in findItems" :key="item">
{{ item }}
</li>
</ul>
</div>
// JavaScript代码:
...
el: "#app",
data: {
items:[...],
wordKey:""
},
computed: {
findItems:function(){
var _this=this;
//根据条件过滤数组中的数据
return _this.items.filter(function(val){
return val.indexOf(_this.wordKey)!=-1;
})
}
2、实践练习(待更新)
三、侦听属性
1、侦听属性创建和使用
- Vue提供了一种更通用的方式来观察和响应Vue实例上的
数据变动
:侦听属性。当有一些数据需要随着其他数据变动而变动时,就可以使用侦听属性watch
。 - watch是一个对象,其中watch对象的属性是需要侦听的目标,一般是
data
中的某个数据项
,而watch对象的属性值是一个函数,是被侦听的数据项发生变化时,需要执行的函数,这个函数有两个形参
,第一个
是当前值
,第二个
是更新后的值
。
示例:
使用watch侦听添加商品信息输入框,根据值的变化显示不同提示效果
<!-- HTML代码: -->
<div id="app" style="margin:20px auto;width:600px">
<div class="prod">
<h1>商品信息</h1>
<p>
<p><label for="title">商品标题:</label>
<input type="text" v-model="title" />
<span :class="{ warn:!titleValid}">商品标题输入不能为空!</span></p>
<p><label for="price">商品单价:</label>
…</p>
<p><label for="amount">商品数量:</label>
…</p>
<p>{{ title }}》商品购买了{{ amount }}本,总计¥{{ total }}元</p></p>
</div>
</div>
// JavaScript代码:
var vm = new Vue({
el: "#app",
data: {
title:"JavaScript权威指南",
price:"40",
amount:"10",
total:"0",
titleValid:true,
priceValid:true,
amountValid:true
},
watch: {
title: function(newVal, oldVal){ … },
price: function(newVal, oldVal){ … },
amount: function(newVal, oldVal){ … },
},
})
watch选项参数中包含侦听了
商品标题(title)
、商品价格(price)
和商品数量(amount)
的值的变化的函数
watch的一个特点是,最初绑定的时候是不会执行的,要等到商品单价和商品数量改变时才执行监听计算
如果想要一开始让最初绑定的时候就执行,就需要watch中使用
handler方法
和immediate属性
:
handler()方法:
其值是一个回调函数。即监听到变化时应该执行的函数。
immediate属性:
其值是true或false;确认是否以当前的初始值执行handler的函数。
示例:
修改上一个示例的watch中的price()如下代码
// JavaScript代码:
price:{
// 之前写的watch的函数,其实默认写的就是handler
handler:function(newVal, oldVal){
…
},
// 代表如果在wacth里声明了price之后,就会立即先去执行里面的handler方法
immediate:true
}
- 如果模型数据是一个对象时,Vue默认并不能侦听
对象属性
的变化,watch里面还有一个deep属性
,默认值是false
,代表是否深度侦听需要使用。- 当
deep属性
为ture
时,就能侦听对象属性
的变化。
2、实践练习(待更新)
四、综合案例
1、商品信息管理
下面结合Vue的基础知识来实现
商品信息的管理功能
,其中包含包含以下功能:
- 添加商品信息。
- 显示全部商品信息列表。
- 根据商品标题查询商品信息列表。
- 删除商品信息。
本节只使用
JavaScript
、CSS
和HTML
实现前端部分,不涉及服务器端功能
和数据库部分
。
实现添加商品信息功能
- 创建视图
- 定义模型
- 定义添加方法
// JavaScript代码:
var vm = new Vue({
el: "#app",
data: {
...省略代码...
},
methods: {
createProd: function () {
this.products.push(this.newProduct);
// 添加完newProduct对象后,重置newProduct对象
this.newProduct = {
name: "",
price: 0,
category: "手机/数码",
}
}
}
});
实现显示全部商品信息列表
<!-- HTML代码: -->
<table>
<thead>
<tr>
<th>名称</th>
<th>价格</th>
<th>类别</th>
<th>删除</th>
</tr>
</thead>
<tbody>
<tr v-for="(prod,index) in findProdList">
<td>{{ prod.name }}</td>
<td>{{ prod.price | priceFormat }}</td>
<td>{{ prod.category }}</td>
<td class="“text-center”"><button @click="deleteProd(index)">删除</button></td>
</tr>
</tbody>
</table>
// JavaScript代码:
var vm = new Vue({
el: "#app",
data: {
...省略代码...
},
// 为了正确显示价格采用过滤器进行格式处理
methods: {
...省略代码...
},
filters: {
priceFormat: function (val) { // 创建价格格式过滤器
return "¥" + parseInt(val).toFixed(2) + "元";
}
}
});
实现根据商品标题查询商品信息列表
<!-- HTML代码: -->
<div id="app">
...省略代码...
<div class="form-group">
<label>查询关键字:</label>
<input type="text" v-model="key" placeholder="请输入查询关键字...." />
</div>
...省略代码...
</div>
// JavaScript代码:
computed: {
findProdList:function(){
var _this=this;
return _this.products.filter(function(prod){
return prod.name.indexOf(_this.key)!=-1;
});
}
}
实现删除商品信息功能
// JavaScript代码:
var vm = new Vue({
el: “#app”,
data: {...省略代码...},
filters: {...省略代码...},
methods: {...省略代码...
//添加deleteProd()方法
deleteProd: function (index) {
if (confirm("删除当前商品信息吗?")) {
// 删除一个数组元素
this.products.splice(index, 1);
}
}
},
computed: {...省略代码...}
});
2、 实践练习(待更新)
总结
- 在一般的项目中,经常需要将信息用
表格
或列表显示
出来。在Vue中提供了v-for指令
来对循环列表功能提供支持。
计算属性
避免在模板中加入过重的业务逻辑
,保证模板的结构清晰
和可维护性
- 当有一些数据需要随着其他数据变动而变动时,就可以使用侦听属性
watch
。
Vue.js高效前端开发 • 【Vue列表渲染】的更多相关文章
- Vue.js高效前端开发知识 • 【目录】
持续更新中- 章节 内容 实践练习 Vue.js高效前端开发 • (实践练习) 第1章 Vue.js高效前端开发 • [ 一.初识Vue.js ] 第2章 Vue.js高效前端开发 • [ 二.Vue ...
- Vue.js高效前端开发 • 【初识Vue.js】
全部章节 >>>> 文章目录 一.Vue概述 1.Web前端框架介绍 2.MVC和MVVM 3.Vue介绍 4.安装Vue 二.Vue使用 1.第一个Vue应用 2.Vue的双 ...
- Vue.js高效前端开发 • 【Ant Design of Vue框架基础】
全部章节 >>>> 文章目录 一.Ant Design of Vue框架 1.Ant Design介绍 2.Ant Design of Vue安装 3.Ant Design o ...
- Vue.js高效前端开发 • 【Vue基本指令】
全部章节 >>>> 文章目录 一.Vue模板语法 1.插值 2.表达式 3.指令概述 4.实践练习 二.Vue绑定类样式和内联样式 1.Vue绑定类样式 2.Vue绑定内联样式 ...
- Vue.js高效前端开发 • 【Vue组件】
全部章节 >>>> 文章目录 一.Vue组件介绍 1.组件概述 2.组件使用步骤 3.实践练习 一.Vue组件使用 1.组件注册 2.组件注册语法糖 3.使用script或te ...
- Vue.js高效前端开发 • 【Ant Design of Vue框架进阶】
全部章节 >>>> 文章目录 一.栅格组件 1.栅格组件介绍 2.栅格组件使用 3.实践练习 二.输入组件 1.输入框组件使用 2.选择器组件使用 3.单选框组件使用 4.实践 ...
- vue.js组件化开发实践
前言 公司目前制作一个H5活动,特别是有一定统一结构的活动,都要码一个重复的轮子.后来接到一个基于模板的活动设计系统的需求,便有了下面的内容.借油开车. 组件化 需求一到,接就是怎么实现,技术选型自然 ...
- 公司内部技术分享之Vue.js和前端工程化
今天主要的核心话题是Vue.js和前端工程化.我将结合我这两年多的工作学习经历来谈谈这个,主要侧重点是前端工程化,Vue.js侧重点相对前端工程化,比重不是特别大. Vue.js Vue.js和Rea ...
- 前端开发 vue,angular,react框架对比1
转载自:https://www.cnblogs.com/hubgit/p/6633214.html 首先,我们先了解什么是MVX框架模式? MVX框架模式:MVC+MVP+MVVM 1.MVC:Mod ...
随机推荐
- java中的collection小结
Collection 来源于Java.util包,是非常实用常用的数据结构!!!!!字面意思就是容器.具体的继承实现关系如下图,先整体有个印象,再依次介绍各个部分的方法,注意事项,以及应用场景. ...
- Can static functions be virtual in C++?
In C++, a static member function of a class cannot be virtual. For example, below program gives comp ...
- linux如何安装缺失依赖
这里要提到一个网站https://pkgs.org/,他是linux系统的一个相关网站,里面都是相关内容 Warning: RPMDB altered outside of yum. ** Found ...
- Java资源下载
tomcat http://mirror.bit.edu.cn/apache/tomcat/tomcat-8/v8.5.49/bin/apache-tomcat-8.5.49.tar.gz s ...
- dom4j解析XML学习
原理:把dom与SAX进行了封装 优点:JDOM的一个智能分支.扩充了其灵活性增加了一些额外的功能. package com.dom4j.xml; import java.io.FileNotFoun ...
- kubernetes list/watch设计原理
overview kubernetes的设计里面大致上分为3部分: API驱动型的特点 (API-driven) 控制循环(control loops)与 条件触发 (Level Trigger) A ...
- Taro 微信小程序 上传文件到minio
小程序前端上传文件不建议直接引用minio的js npm包,一来是这个包本身较大,会影响小程序的体积,二来是ak sk需要放到前端存储,不够安全,因此建议通过请求后端拿到签名数据后上传. 由于小程序的 ...
- 保留重复项(Power Query 之 M 语言)
数据源: "姓名""基数""个人比例""个人缴纳""公司比例""公司缴纳"&qu ...
- 小迪安全 Web安全 基础入门 - 第十天 - 信息打点-APP&小程序篇&抓包封包&XP框架&反编译&资产提取
一.本节知识点思维导图 二.APP-外在资产收集 1.将APP安装在模拟器中,修改模拟器代理设置,使用Fiddler.Burpsuite.Charles等抓包工具抓取APP访问的http协议数据包,抓 ...
- WebApi的前端调用
WebApi前端调用 HTML代码: <!DOCTYPE html><html> <head> <meta charset="utf-8" ...