目录
day02
一、今日学习目标
1.指令补充
2.computed计算属性
3.watch侦听器
4.综合案例 (演示)
二、指令修饰符
1.什么是指令修饰符?
2.按键修饰符
3.v-model修饰符
4.事件修饰符
三、v-bind对样式控制的增强-操作class
1.语法:
2.对象语法
3.数组语法
4.代码练习
四、京东秒杀-tab栏切换导航高亮
1.需求:
2.准备代码:
3.思路:
五、v-bind对有样式控制的增强-操作style
1.语法
2.代码练习
3.进度条案例
六、v-model在其他表单元素的使用
1.讲解内容:
2.代码准备
七、computed计算属性
1.概念
2.语法
3.注意
4.案例
5.代码准备
八、computed计算属性 VS methods方法
1.computed计算属性
2.methods计算属性
3.计算属性的优势
4.总结
九、计算属性的完整写法
十、综合案例-成绩案例
十一、watch侦听器(监视器)
1.作用:
2.语法:
3.侦听器代码准备
十二、翻译案例-代码实现
十三、watch侦听器
1.语法
2.需求
3.代码实现
4.总结
十四、综合案例
指令修饰符
v-bind对样式增强的操作
v-model应用于其他表单元素
基础语法
计算属性vs方法
计算属性的完整写法
成绩案例
基础写法
完整写法
渲染 / 删除 / 修改数量 / 全选 / 反选 / 统计总价 / 持久化
所谓指令修饰符就是通过“.”指明一些指令后缀 不同的后缀封装了不同的处理操作 —> 简化代码
@keyup.enter —>当点击enter键的时候才触发
代码演示:
@keyup.enter → 监听键盘回车事件
v-model.trim —>去除首位空格
v-model.number —>转数字
@事件名.stop —> 阻止冒泡
@事件名.prevent —>阻止默认行为
@事件名.stop.prevent —>可以连用 即阻止事件冒泡也阻止默认行为
为了方便开发者进行样式控制, Vue 扩展了 v-bind 的语法,可以针对 class 类名 和 style 行内样式 进行控制 。
:class = "对象/数组">这是一个div
当class动态绑定的是对象时,键就是类名,值就是布尔值,如果值是true,就有这个类,否则没有这个类
适用场景:一个类名,来回切换
当class动态绑定的是数组时 → 数组中所有的类,都会添加到盒子上,本质就是一个 class 列表
使用场景:批量添加或删除类
黑马程序员黑马程序员
当我们点击哪个tab页签时,哪个tab页签就高亮
1.基于数据,动态渲染tab(v-for)
2.准备一个下标 记录高亮的是哪一个 tab
3.基于下标动态切换class的类名
50%
常见的表单元素都可以用 v-model 绑定关联 → 快速 获取 或 设置 表单元素的值
它会根据 控件类型 自动选取 正确的方法 来更新元素
输入框 input:text ——> value 文本域 textarea ——> value 复选框 input:checkbox ——> checked 单选框 input:radio ——> checked 下拉菜单 select ——> value ...
小黑学习网
姓名:
是否单身:
性别: 男 女
所在城市:
自我描述:
基于现有的数据,计算出来的新属性。 依赖的数据变化,自动重新计算。
声明在 computed 配置项中,一个计算属性对应一个函数
使用起来和普通属性一样使用 {{ 计算属性名}}
computed配置项和data配置项是同级的
computed中的计算属性虽然是函数的写法,但他依然是个属性
computed中的计算属性不能和data中的属性同名
使用computed中的计算属性和使用data中的属性是一样的用法
computed中计算属性内部的this依然指向的是Vue实例
比如我们可以使用计算属性实现下面这个业务场景
小黑的礼物清单
名字 数量 {{ item.name }} {{ item.num }}个 礼物总数:? 个
作用:封装了一段对于数据的处理,求得一个结果
语法:
写在computed配置项中
作为属性,直接使用
js中使用计算属性: this.计算属性
模板中使用计算属性:{{计算属性}}
作用:给Vue实例提供一个方法,调用以处理业务逻辑。
语法:
写在methods配置项中
作为方法调用
js中调用:this.方法名()
模板中调用 {{方法名()}} 或者 @事件名=“方法名”
缓存特性(提升性能)
计算属性会对计算出来的结果缓存,再次使用直接读取缓存,
依赖项变化了,会自动重新计算 → 并再次缓存
methods没有缓存特性
通过代码比较
小黑的礼物清单?
名字 数量 {{ item.name }} {{ item.num }}个 礼物总数:{{ totalCount }} 个
1.computed有缓存特性,methods没有缓存
2.当一个结果依赖其他多个值时,推荐使用计算属性
3.当处理业务逻辑时,推荐使用methods方法,比如事件的处理函数
既然计算属性也是属性,能访问,应该也能修改了?
计算属性默认的简写,只能读取访问,不能 "修改"
如果要 "修改" → 需要写计算属性的完整写法
完整写法代码演示
姓: + 名: =
功能描述:
1.渲染功能
2.删除功能
3.添加功能
4.统计总分,求平均分
思路分析:
1.渲染功能 v-for :key v-bind:动态绑定class的样式
2.删除功能 v-on绑定事件, 阻止a标签的默认行为
3.v-model的修饰符 .trim、 .number、 判断数据是否为空后 再添加、添加后清空文本框的数据
4.使用计算属性computed 计算总分和平均分的值
监视数据变化,执行一些业务逻辑或异步操作
watch同样声明在跟data同级的配置项中
简单写法: 简单类型数据直接监视
完整写法:添加额外配置项
data: { words: '苹果', obj: { words: '苹果' } }, watch: { // 该方法会在数据变化时,触发执行 数据属性名 (newValue, oldValue) { 一些业务逻辑 或 异步操作。 }, '对象.属性名' (newValue, oldValue) { 一些业务逻辑 或 异步操作。 } }
翻译成的语言:⌨️文档翻译mela
完整写法 —>添加额外的配置项
deep:true 对复杂类型进行深度监听
immdiate:true 初始化 立刻执行一次
data: { obj: { words: '苹果', lang: 'italy' }, }, watch: {// watch 完整写法 对象: { deep: true, // 深度监视 immdiate:true,//立即执行handler函数 handler (newValue) { console.log(newValue) } } }
当文本框输入的时候 右侧翻译内容要时时变化
当下拉框中的语言发生变化的时候 右侧翻译的内容依然要时时变化
如果文本框中有默认值的话要立即翻译
watch侦听器的写法有几种?
1.简单写法
watch: { 数据属性名 (newValue, oldValue) { 一些业务逻辑 或 异步操作。 }, '对象.属性名' (newValue, oldValue) { 一些业务逻辑 或 异步操作。 } }
2.完整写法
watch: {// watch 完整写法 数据属性名: { deep: true, // 深度监视(针对复杂类型) immediate: true, // 是否立刻执行一次handler handler (newValue) { console.log(newValue) } } }
购物车案例
需求说明:
渲染功能
删除功能
修改个数
全选反选
统计 选中的 总价 和 总数量
持久化到本地
实现思路:
1.基本渲染: v-for遍历、:class动态绑定样式
2.删除功能 : v-on 绑定事件,获取当前行的id
3.修改个数 : v-on绑定事件,获取当前行的id,进行筛选出对应的项然后增加或减少
4.全选反选
必须所有的小选框都选中,全选按钮才选中 → every
如果全选按钮选中,则所有小选框都选中
如果全选取消,则所有小选框都取消选中
声明计算属性,判断数组中的每一个checked属性的值,看是否需要全部选
5.统计 选中的 总价 和 总数量 :通过计算属性来计算选中的总价和总数量
6.持久化到本地: 在数据变化时都要更新下本地存储 watch