Vue3全家桶 - Vue3 - 【3】模板语法(指令+修饰符 + v-model语法糖)

一、模板语法

  • 主要还是记录一些指令的使用和vue2的区别;
  • vue3指令导航;

1.1 v-text 和 v-html

  • 指令的区别:
    • v-text:
      • 更新元素的文本内容;
      • v-text 通过设置元素的 textContent 属性来工作,因此它将覆盖元素中所有现有的内容。如果你需要更新 textContent 的部分,应该使用 mustache interpolations 代替。
      • 不能解析标签;
    • v-html:
      • 更新元素的innerHTML
      • v-html 的内容直接作为普通 HTML 插入—— Vue 模板语法是不会被解析的。如果你发现自己正打算用 v-html 来编写模板,不如重新想想怎么使用组件来代替。
      • 可以解析标签;
      • 在单文件组件,scoped 样式将不会作用于 v-html 里的内容,因为 HTML 内容不会被 Vue 的模板编译器解析。如果你想让 v-html 的内容也支持 scoped CSS,你可以使用 CSS modules 或使用一个额外的全局 <style> 元素,手动设置类似 BEM 的作用域策略。
  • vue2:这两个指令的使用的时候,没什么需要注意的地方,即使标签里面有内容,也可以正常使用和在浏览器中正常显示内容;
  • vue3:绑定指令的元素必须是空标签,如果该标签里面有内容或其他标签,都会报错;
    • 相比vue2,vue3源码在这两个指令绑定的时候去做了进一步的处理;
      image.png

1.2 v-model

  • 注意
    • 一般情况下,v-model指令用在表单元素中;
    • 文本类型的 input、textarea 会绑定元素的 value 属性并侦听 input 事件;
    • 单选和复选 radio、checkbox 会绑定元素的 checked 属性,并侦听 change 事件;
    • 下拉菜单 select 会绑定元素的 value 属性,并侦听 change 事件;
      • 指令绑定在 select元素 上,给 子元素option 设置 value属性;
  • 示例展示:
    <script setup>import { ref, reactive, toRef, toRefs, onMounted } from 'vue';let text = ref('111')let textarea = ref('222')let radio = ref('man')let open = ref(true)let determine = ref('确定')let checkbox = ref(['YMQ'])let select = ref('B')let selects = ref(['苏C', '苏B'])onMounted(() => {});
    </script><template><h4>单行文本框</h4><input type="text" v-model="text"><hr><h4>多行文本框</h4><input type="textarea" v-model="textarea"><hr><h4>单选框</h4><input type="radio" value="man" v-model="radio"><input type="radio" value="woman" v-model="radio"><hr><h4>默认复选框</h4><input type="checkbox" name="" id="" v-model="open"><h4>自定义复选框的值</h4><!-- 默认状态下,复选框的值是 true / false ,既 open 的值为 true / false--><input type="checkbox" true-value="确定" false-value="不确定" v-model="determine"> 是否确定<!-- true-value - 表示选中状态下,既 determine 的值false-value - 表示未选中状态下,表示选中状态下,既 determine 的值--><hr><h4>复选框</h4><input type="checkbox" value="LQ" v-model="checkbox"> 篮球<input type="checkbox" value="ZQ" v-model="checkbox"> 足球<input type="checkbox" value="YMQ" v-model="checkbox"> 羽毛球<input type="checkbox" value="PPQ" v-model="checkbox"> 乒乓球<hr><h4>单选下拉菜单</h4>证书等级:<select v-model="select"><option value="C">初级</option><option value="B">中级</option><option value="A">高级</option></select><hr><h4>多选下拉菜单</h4>去过的城市:<select multiple v-model="selects"><!--NOTEmultiple - 规定可同时选择多个选项值 - 布尔值(写该属性表示true,不写表示false)--><option value="苏A">南京</option><option value="苏B">无锡</option><option value="苏C">徐州</option><option value="苏D">常州</option></select>
    </template>
    

1.3 v-if 和 v-for 的 优先级

  • vue2:
    • v-for > v-if
  • vue3:
    • v-if > v-for

1.4 v-for 循环 数组 和 对象

  • 这块和 vue2 没啥区别,主要是我自己在 vue2 里面主要是配合数组使用(很少循环对象);
  • 使用 v-for 的时候,记得添加 key
  • 循环数组
    • 写法一:
      • v-for = "item in arr"
      • item:数组的每一项元素;
      • arr:需要循环的数组;
    • 写法二:
      • v-for = "(item, index) in arr"
      • item:数组的每一项元素;
      • index:每一项元素对应的索引;
      • arr:需要循环的数组;
  • 循环对象
    • 使用 v-for 来遍历一个对象的所有属性,遍历的顺序 会基于该对象调用 Object.keys()返回值 来决定;
    • 写法一:
      • v-for = "value in object"
      • value:属性值;
      • object:需要循环的对象;
    • 写法二:
      • v-for = "(value, name) in object"
      • value:属性值;
      • name:属性名;
      • object:需要循环的对象;
    • 写法三:
      • v-for = "(value, name, index) in object"
      • value:属性值;
      • name:属性名;
      • index:索引(Object.keys()的返回值中 name 对应的索引);
      • object:需要循环的对象;
    • 示例展示:
      <script setup>import { reactive } from 'vue'let student = reactive({styNum: '007', // 学号name: 'Jack', // 名字age: 18 //年龄})
      </script><template><h6>Object.keys() 的 返回值</h6><span>{{ Object.keys(student) }}</span><!-- value in objectvalue:属性值object:循环的对象--><h6>v-for 渲染对象, v-for="value in object"</h6><ul><li v-for="value in student" :key="value">{{ value }}</li></ul><hr><!-- (value, name) in objectvalue:属性值name:属性名object:循环的对象--><h6>v-for 渲染对象, v-for="(value, name) in object"</h6><ul><li v-for="(value, name) in student" :key="name">属性名:{{ name }} --- 属性值: {{ value }}</li></ul><hr><!-- (value, name, index) in objectvalue:属性值name:属性名index: 索引object:循环的对象--><h6>v-for 渲染对象, v-for="(value, name, index) in object"</h6><ul><li v-for="(value, name, index) in student" :key="name">属性名:{{ name }} --- 属性值: {{ value }} --- 索引:{{ index }}</li></ul>
      </template>
      
    • 效果展示:
      image.png
  • 通过 key 提高更新性能:
    • 当列表的数据变化时,默认情况下,vue会尽可能的复用已存在的DOM元素,从而提升渲染的性能;但这种默认的性能优化策略,会导致有状态的列表无法被正确更新;
    • 为了给vue一个提示,以便它能跟踪每个节点的身份,从而在保证有状态的列表被正确更新的前提下,提升渲染的性能;此时,需要为每项提供一个唯一的key属性:
    • key的注意事项:
      • key的类型 只能Number/String
      • key值必须具有 唯一性
      • 建议循环的列表有一个属性当 key(该属性的值在此列表中唯一);
      • 不使用 索引 当 key
      • 🔺 使用 v-for 指令时一定要指定 key 的值;
    • 示例展示:
      <script setup>import { ref } from 'vue'// 课程let subject = ref([{ id: 1, name: 'Vue' },{ id: 2, name: 'Java' },{ id: 3, name: 'Hadoop' }])// 添加课程function addSubject() {// (数组最前面)添加subject.value.unshift({ id: 4, name: 'Python' })}
      </script><template><button @click.once="addSubject">添加课程(数组最前面)</button><h3>不使用key值</h3><ul><li v-for="sub in subject"><input type="checkbox">{{ sub }}</li></ul><hr><h3>使用索引当key值</h3><ul><li v-for="(sub, index) in subject" :key="index"><input type="checkbox">{{ sub }}</li></ul><hr><h3>使用列表属性当key值(该属性必须再此列表中唯一)</h3><ul><li v-for="sub in subject" :key="sub.id"><input type="checkbox">{{ sub }}</li></ul>
      </template>
      
    • 效果展示:
      • 观察 不使用key + 使用索引作为key 的变化(会导致有状态的列表无法被正确的更新);
        image.png

1.5 键盘按键修饰符

  • 这块和 vue2 没啥区别,主要是我自己在 vue2 里面就知道那么几个修饰符,所以在这里记录了一下;
  • 按键别名:.enter.tab.esc.space.up.down.left.right.delete (捕获DeleteBackspace两个按键);
  • 系统修饰符:.ctrl.alt.shift.meta
  • 准确的修饰符:.exact(添加了对应键位的修饰符,就必须按下对应的键位,否则事件不生效)(见【示例展示】);
  • 示例展示:
    <script setup>// 弹出消息function showMessage(message) {window.alert(message)}
    </script><template>按下的键中包含 Enter 键事件: <input type="text" @keydown.enter="showMessage('你按下了 Enter 键')"><hr>按下的键中包含 Shift Enter 键事件:<input type="text" @keydown.enter.shift="showMessage('你按下了 Shift + Enter 键')"/><hr>按下的键只有 Shift Enter 键事件:<input type="text" @keydown.enter.shift.exact="showMessage('你只有按下了 Shift + Enter 键,这个事件才会触发')"/>
    </template>
    

1.6 鼠标按键修饰符

  • 这块和 vue2 没啥区别,主要是我自己在 vue2 里面基本没遇到过,所以在这里记录了一下;
  • 鼠标按键修饰符:
    • .left:鼠标左键;
    • .middle:鼠标中键(滚轮键);
    • .right:鼠标右键;
  • 示例展示:
    <!-- 脚本区域 -->
    <script setup>function showTest(text) {window.alert(text)}
    </script><!-- 视图区域 -->
    <template><!-- 鼠标右键按下 --><button @mousedown.right="showTest('按下的是鼠标右键')">鼠标右键按下</button><hr><!-- 点击时,采用的是鼠标中键 --><button @click.middle="showTest('按下的是鼠标中键')">点击时,采用的是鼠标中键</button><hr><!-- 鼠标左键按下 --><button @mousedown.left="showTest('按下的是鼠标左键')">鼠标左键按下</button>
    </template><!-- 样式区域 -->
    <style>button {border: none;padding: 15px 20px;}button:active {box-shadow: 0 0 5px grey;}
    </style>
    

二、vue2 和 vue3 v-model语法糖 区别

  • vue3官网(组件 v-model);
  • vue2v-mode 语法糖 简写的代码:
    • texttextarea<Son :value="msg" @input="msg=$event.target.value" />
    • radiocheckbox<Son :checked="msg" @change="msg=$event.target.checked" />
  • vue3v-model 语法糖 有所调整:
    • <Son :modelValue="msg" @update:modelValue="msg=$event" />
  • 示例展示:
    • 父组件:
      <script setup>import { ref } from 'vue'// NOTE 在使用 setup 语法糖的 单文件 里面导入组件的时候,无需注册,直接使用即可// TODO 导入组件import SonComponent from '@/components/SonComponent.vue'let searchText = ref('禁止摆烂-才浅')
      </script><template><!-- <son-component :modelValue="searchText" @update:modelValue="newVal => searchText = newVal"></son-component> --><son-component v-model="searchText"></son-component>
      </template>
      
    • 子组件:
      <script setup>// NOTE 接受父组件传递的数据 - 接收数据有两种形式(数组 + 对象)defineProps({modelValue: {type: String,required:  true}})
      </script><template><input type="text" :value="modelValue" @input="$emit('update:modelValue', $event.target.value)">
      </template>
      
  • 总结
    • vue3封装组件支持 v-model 的时候:
      • 父传子 :modelValue 传递数据;
      • 子传父 @update:modelValue 触发事件,更新数据;
    • vue2的 xxx.sync 语法糖解析:
      • 父传子:xxx
      • 子传父 @update:xxx 在vue3.0 使用 v-model:xxx 代替。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/738108.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数据结构:静态链表(编程技巧)

链表的元素用数组存储&#xff0c; 用数组的下标模拟指针。 一、理解 如果有些程序设计语言没有指针类型&#xff0c;如何实现链表&#xff1f; 在使用指针类型实现链表时&#xff0c;我们很容易就可以直接在内存中新建一块地址用于创建下一个结点&#xff0c;在逻辑上&#x…

3、设计模式之工厂模式

工厂模式是什么&#xff1f;     工厂模式是一种创建者模式&#xff0c;用于封装和管理对象的创建&#xff0c;屏蔽了大量的创建细节&#xff0c;根据抽象程度不同&#xff0c;主要分为简单工厂模式、工厂方法模式以及抽象工厂模式。 简单工厂模式 看一个具体的需求 看一个…

面向对象(精髓)变继承关系为组和关系(_Decorator模式)

在软件开发中&#xff0c;设计模式是解决常见问题的可重用解决方案。在面向对象编程中&#xff0c;继承和组合是两种常用的代码复用方式。然而&#xff0c;随着软件需求的不断变化&#xff0c;我们需要更灵活的设计方式来应对不断变化的需求。在本文中&#xff0c;我们将讨论从…

计算机网络——TCP/IP网络层次模型

计算机网络——TCP/IP网络层次模型 TCP/IP网络模型的起源TCP/IP网络层次的结构TCP/IP如何交互 TCP/IP协议栈TCP/IP协议栈主要协议 TCP/IP 和 OSI之间的区别面向连接和无连接面向连接三次握手&#xff0c;四次挥手 无连接 我们上一次了解了OSI的网络层次模型&#xff0c;如果还没…

Linux学习-内存管理

目录 内存管理 malloc free 使用 字符串存储申请堆区 自主输入个数&#xff0c;然后通过malloc在程序中申请空间&#xff0c;不用必须提前指定大小 内存溢出 内存泄漏 内存碎片 内存管理 函数名就是指向该函数的函数指针。 堆区是自低向高&#xff0c;栈区是自高向低…

ffmpeg日记4001-原理介绍-视频切割原理

原理 打开输入---->打开输出---->根据输入来创建流---->拷贝流设置---->循环读帧---->判断时间点是否到达切割点&#xff0c;并做设置---->设置pts和dts---->写入---->善后 重点是pts和dts如何设置。参考《ffmpeg学习日记25-pts&#xff0c;dts概念的…

ftp速度太慢只有几十k,怎么解决?

FTP是目前许多企业日常运营中还在用的文件传输方式。虽然比较普遍&#xff0c;然而&#xff0c;许多用户在使用FTP时经常遇到速度缓慢的问题&#xff0c;有时甚至只有几十KB/s。这不仅影响工作效率&#xff0c;还可能导致许多数据传输的延迟的问题。本文将探讨FTP速度慢的原因&…

计算机服务器中了faust勒索病毒怎么解密,faust勒索病毒解密工具流程

在互联网飞速发展的今天&#xff0c;越来越多的企业走向了数字化办公模式&#xff0c;许多企业开始利用网络计算机开展各项工作业务&#xff0c;网络也为企业的生产效率提供了极大便利&#xff0c;但网络中存在许多恶意威胁。近日&#xff0c;云天数据恢复中心接到许多企业的求…

Java 学习和实践笔记(34):对象的转型(casting)

对象的转型&#xff08;casting)有两种&#xff0c;一种是向上转型&#xff0c;一种是向下转型。 向上转型&#xff1a;父类引用指向子类对象。这属于自动类型转换&#xff0c;编译器会自动完成。 上一节的多态中&#xff0c;形参为父类Animal, 但是调用时实参为子类对象Dog&…

linux中查看并修改日期

1.如何在终端控制行界面显示并且调整日期&#xff1a; 显示当前日期&#xff1a; 2.显示当前年份&#xff1a; 3.显示当前月份&#xff1a; 4.显示当前天数&#xff1a; 5.显示到目前为止的天数&#xff1a; 6.显示日期&#xff1a; date “%x“ ≈ date ”%Y %m %d"…

09-设计模式 面试题

你之前项目中用过设计模式吗? 工厂方法模式分类 简单工厂模式工厂方法模式抽象工厂模式工厂模式 需求:设计一个咖啡店点餐系统。 设计一个咖啡类(Coffee),并定义其两个子类(美式咖啡【AmericanCoffee】和拿铁咖啡【LatteCoffee】);再设计一个咖啡店类(CoffeeStore)…

一、什么是 HarmonyOS ?

HarmonyOS 是华为开发的一款面向未来的全场景分布式智慧操作系统&#xff0c;将逐步覆盖 18N 全场景终端设备。 对消费者而言&#xff0c;HarmonyOS 用一个“统一的软件系统”&#xff0c;从根本上解决消费者面对大量智能终端体验割裂的问题&#xff0c;为消费者带来统一、便利…

Kafka Stream入门

1. 什么是流式计算 流式计算&#xff08;Stream Processing&#xff09;是一种计算模型&#xff0c;旨在处理连续的数据流。与传统的批处理模型不同&#xff0c;流式计算可以实时或接近实时地处理和分析数据&#xff0c;这意味着数据在生成后不久就被处理&#xff0c;而不是存…

基于android的物业管理系统的设计与实现19.8

目录 基于android的物业管理系统的设计与实现 3 摘 要 3 Android property managemengt system 5 Abstract 5 1 绪论 6 1.1 选题背景 6 1.2 课题研究现状 6 1.3 设计研究主要内容 7 1.4 系统主要设计思想 8 2 开发环境 8 2.1 Android系统的结构 8 图2-1 Android系统架构图 9 2…

Python绘图-14绘制3D图(下)

14.7绘制3D等高线图个性化colormap 14.7.1图像呈现 14.7.2绘图代码 import numpy as np # 导入numpy库&#xff0c;numpy是Python的一个强大的数值计算扩展程序库&#xff0c;支持大量的维度数组与矩阵运算。 import matplotlib.pyplot as plt # 导入matplotlib的绘图模块p…

UDP编程及特点

目录 1.UDP编程流程 2.recvfrom()、sento() 3.代码演示 3.udp特点 1.UDP编程流程 socket()用来创建套接字&#xff0c;使用 udp 协议时&#xff0c;选择数据报服务 SOCK_DGRAM。sendto()用来发送数据&#xff0c;由于 UDP 是无连接的&#xff0c;每次发送数据都需要指定对端…

神经网络基本使用

1. 卷积层 convolution layers import torch import torchvision from torch import nn from torch.nn import Conv2d from torch.utils.data import DataLoader from torch.utils.tensorboard import SummaryWriterdataset torchvision.datasets.CIFAR10(./dataset,trainFa…

Aspose.Words指定位置插入table

如果在创建书签&#xff0c;然后在书签位置插入表格&#xff0c;会出现格式错乱&#xff0c;在单元格位置里面有一个表格&#xff0c;不符合实际使用。正确做法是复制模板文件里面的表格行&#xff0c;然后插入若干行。 如图标记红色位置插入动态数据行&#xff0c;是先复制标…

day1_C++:实现C++风格字符串输出

1.提示并输入一个字符串&#xff0c;统计该字符中大写、小写字母个数、数字个数、空格个数以及其他字符个数&#xff0c;要求使用C风格字符串完成 程序代码&#xff1a; #include <iostream>//标准输入输出流 #include <string.h>//C中字符串相关头文件 using na…

HBase分布式数据库的原理和架构

一、HBase简介 HBase是是一个高性能、高可靠性、面向列的分布式数据库&#xff0c;它是为了在廉价的硬件集群上存储大规模数据而设计的。HBase利用Hadoop HDFS作为其文件存储系统&#xff0c;且Hbase是基于Zookeeper的。 二、HBase架构 *图片引用 Hbase采用Master/Slave架构…