《Vue3 二》Vue 的模板语法

在 React 中,想要编写 HTML,是使用 JSX,之后通过 Babel 将 JSX 编译成 React.createElement 函数调用;在 Vue 中,也支持 JSX 的开发模式,但大多数情况下都是使用基于 HTML 的模板语法,在模板中允许开发者以声明式的方式将 DOM 和底层组件实例的数据绑定在一起,在底层的实现中,Vue 会将面编译成虚拟 DOM 渲染函数。

Mustache 插值语法:

Mustache 插值语法:可以通过双大括号将 data 中的数据、methods 中的函数或者 JavaScript 表达式显示到 template 模板中。

<div id="app"><!-- data 中的数据 --><div>当前数字:{{count}}</div><!-- methods 中的函数 --><div>{{formatCount(count)}}</div><!-- JavaScript 表达式 --><div>三倍当前数字:{{count * 3}}</div><!--  JavaScript 表达式只能是单个表达式,下面的语法会报错 --><div>{{ const count = 10 }}</div>
</div><script>const app = Vue.createApp({data() {return {count: 10,}},methods: {formatCount(argu) {return `双倍当前数字:${argu*2}`},}})app.mount('#app')
<script>

常见的基本指令:

指令都是用在元素的属性上。

v-bind

v-bind:用于动态绑定一个或多个属性值,或者向另一个组件传递 props 值。语法糖是 :

<div id="app"><img v-bind:src="imgUrl" />
</div><script>
const app = Vue.createApp({data() {return {imgUrl: 'http://gips2.baidu.com/it/u=195724436,3554684702&fm=3028&app=3028&f=JPEG&fmt=auto?w=1280&h=960',}},
})
app.mount('#app')
</script>

使用 v-bind 动态绑定 class 属性值:

动态绑定的 class 和普通静态的 class 是可以一起使用的,不会被覆盖。

  1. 绑定对象:可以给 :class 绑定一个对象来动态切换 class。对象中的属性名是 class 名,属性值是布尔类型,只有属性值为 true 时才会渲染对应的 class。
    <!-- 只有当 isActive 为 true 时才会显示 active 样式 -->
    <div v-bind:class="{ active: isActive }"></div>
    
  2. 绑定数组:可以给 :class 绑定一个数组来渲染多个 class。
    <div v-bind:class="[activeClass, errorClass]"></div>
    

使用 v-bind 动态绑定 style属性值:

  1. 绑定对象:属性名可以使用驼峰式或者用引号括起来的短横线分割来命名。
    <div v-bind:style="{ color: activeColor, fontWeight: activeFontWeight, 'font-size': activeFontSize + 'px' }"></div>
    
  2. 绑定数组:可以将多个样式对象应用到同一个元素上。
    <div :style="[baseStyles, {color: activeColor}]"></div>
    

使用 v-bind 动态绑定属性名:

如果属性名称不是固定的,可以使用 v-bind:[属性名]="属性值" 的格式来定义。

<~-- name 是动态的 --> 
<div v-bind:[name]="value"></div>

使用 v-bind 直接绑定一个对象:

常用于给组件传递 props 属性值。

<div id="app"><!-- 会自动地遍历对象中的所有属性,将它们作为属性添加到当前的元素上 --><div v-bind="props">Hello Vue</div>
</div><script>
const app = Vue.createApp({data() {return {props: {name: 'Lee',height: 1.88,},}},
})
app.mount('#app')
</script>

在这里插入图片描述

v-on

v-on:用于绑定事件。语法糖是 @

<div id="app"><div v-on:click="handleClick">Hello Vue</div>
</div><script>const app = Vue.createApp({methods: {handleClick() {console.log('click')}}})app.mount('#app')
</script>

传递参数:

  1. 只有默认参数:如果在绑定事件时,没有传递任何参数,那么 event 对象会被默认传递进来。
    <div id="app"><div v-on:click="handleClick">Hello Vue</div>
    </div><script>const app = Vue.createApp({methods: {handleClick(event) {console.log('click', event)}}})app.mount('#app')
    </script>
    ```	![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/4aa258c96a1347a1aa771cf3ecaf5873.png)
    
  2. 只有明确传递的参数:如果在绑定事件时,有显式地传递参数,那么只有明确传递的参数会被传递进来。
<div id="app"><div v-on:click="handleClick('Lee')">Hello Vue</div>
</div><script>const app = Vue.createApp({methods: {handleClick(name) {console.log('click', name)}}})app.mount('#app')
</script>

在这里插入图片描述

  1. 既有明确传递的参数,也有默认参数:如果在绑定事件时,有显式地传递参数和 $event,那么明确传递的参数和 event 对象都会被传递进来。
    <div id="app"><div v-on:click="handleClick('Lee', $event)">Hello Vue</div>
    </div><script>const app = Vue.createApp({methods: {handleClick(name, event) {console.log('click', name, event)}}})app.mount('#app')
    </script>
    
    在这里插入图片描述

修饰符:

v-on 支持修饰符,相当于是对事件进行一些特殊的处理。

  1. .stop:调用 event.stopPropagation() 阻止事件冒泡。
  2. .prevent:调用 event.preventDefault() 阻止默认事件。
  3. .capture:添加事件侦听器时使用 capture 捕获模式。
  4. .passive:添加事件侦听器时使用 {passive: true} 模式,提前告知浏览器不要阻止事件的默认行为。
  5. .self:只有当事件是从侦听器绑定的元素本身触发时才触发回调。
  6. .{keyAlias}:只有当事件是从特定键触发时才触发回调。
  7. .left:只有当点击鼠标左键时才触发回调。
  8. .right:只有当点击鼠标右键时才触发回调。
  9. .middle:只有当点击鼠标中键时才触发回调。
  10. .once:只触发一次回调。

v-model

v-model:用于实现双向绑定。经常和表单一起使用,可以用于 input、textarea、select、checkbox、radio 等表单控件。

双向数据绑定:是指将视图(用户界面)中的数据与模型(业务逻辑)中的数据进行双向关联。当视图中的数据发生变化时,模型中的数据也会随之更新;同样,当模型中的数据发生变化时,视图中的数据也会随之更新。

select 如果是单选,v-model 绑定到属性中的值是就是单个的值;如果是多选,v-model 绑定到属性中的值就是数组类型。
checkbox 如果只有一个选择框时,v-model 绑定到属性中的值是布尔值类型,此时即使明确地给元素绑定 value 属性,当选中时也不会影响到 v-model 绑定的值; 如果有多个选择框时,v-model 绑定到属性中的值是数组类型, 此时必须明确地给元素绑定 value 属性,当选中时 value 属性值会被自动地添加到 v-model 绑定的数组中。

<div id="app"><!-- 手动实现双向数据绑定 --><input :value="message" @input="handleMessageInput" /><!-- Vue 实现双向数据绑定,本质上就是上面代码的语法糖 --><input v-model="message" /><div>{{message}}</div>
</div><script>const app = Vue.createApp({data() {return {message: 'Hello Vue',}},  methods: {handleMessageInput(event) {this.message = event.target.value}},})app.mount('#app')
</script>

v-model 的原理:

  1. v-bind 绑定 value 属性的值。
  2. v-on 绑定 input 事件监听函数,在函数中会获取到最新的值赋值到绑定的属性中。

v-model 的修饰符:

多个修饰符可以并列使用。

  1. lazy:默认情况下,v-model 在进行双向数据绑定时,绑定的是 input 事件,那么在每次内容输入后就会将最新的值和绑定的属性进行同步;如果在 v-model 后面跟上 lazy 修饰符,那么就会将绑定的事件切换为 change 事件,只有在提交时才会触发。
    <div id="app"><input v-model.lazy="message" /><div>{{message}}</div>
    </div><script>const app = Vue.createApp({data() {return {message: 'Hello Vue',}},  })app.mount('#app')
    </script>
    
  2. number:自动将内容转换为数字。
  3. trim:去除内容首尾的空格。

v-text

v-text:用于设置元素的 textContent 文本内容。

<divv-text="message"></div>
<!-- v-text 会直接替换掉元素中的内容 -->
<divv-text="message">你好,Vue</div><!-- 和Mustache 插值语法的效果一样,只不过Mustache 插值语法更灵活 -->
<div>{{message}}</div>

v-html

v-html:默认情况下,如果显示的内容本身是 HTML,Vue 是不会对其进行解析的;如果想要解析出来,需要使用 v-html。

<div id="app"><!-- 会直接将字符串显式出来 --><div>{{content}}</div><!-- 会解析 HTML --><divv-html="content"></div>
</div><script>const app = Vue.createApp({data() {return {content: `<span style="color:red">Hello Vue</span>`,}},})app.mount('#app')
</script>

在这里插入图片描述

v-pre

v-pre:用于跳过元素及其子元素的编译过程,显示原始 Mustache 标签。可以跳过不需要编译的节点,加快编译速度。

<div id="app"><!-- Vue 会跳过对其的编译过程,将其直接显示出来 --><div-pre>{{message}}</div>
</div><script>const app = Vue.createApp({data() {return {message: 'Hello Vue',}},})app.mount('#app')
</script>

v-cloak

v-cloak:这个指令会保持在元素上直到关联的实例结束编译。和 CSS 规则例如 [v-cloak]{display:none} 一起用时,可以用于隐藏未编译的 Mustache 标签直到实例编译完成。

<div id="app"><!-- 初始会显示 {{message}},直到三秒后才显示正确的效果 --><div>{{message}}</div>
</div><script>setTimeout(() => {const app = Vue.createApp({data() {return {message: 'Hello Vue',}},})app.mount('#app')},3000)
</script>
<style>[v-cloak] {display: none;}
</style><div id="app"><!-- 由于有 v-cloak 指令,叠加设置的 CSS 属性,初始什么都不会显示;直到三秒后,Vue 实例编译完成,v-cloak 指令会被 Vue 自动移除,显示正确的效果 --><divv-cloak>{{message}}</div1>
</div><script>setTimeout(() => {const app = Vue.createApp({data() {return {message: 'Hello Vue',}},})app.mount('#app')},3000)
</script>

v-once

v-once:只渲染元素/组件一次,当数据发生变化时,元素/组件及其所有的子节点将被视为静态内容直接跳过,不会重新渲染。可以用于优化更新性能。

<div id="app"><!-- 点击按钮也不会改变 message 显示的内容,因为只会渲染一次 --><divv-once>{{message}}</div><button @click="handleMessageChange">改变 Message</button>
</div><script>const app = Vue.createApp({data() {return {message: 'Hello Vue',}},methods: {handleMessageChange() {this.message = 'Hello World'},}})app.mount('#app')
</script>

v-memo

v-memo:缓存一个模板的子树。在元素和组件上都可以使用。为了实现缓存,该指令需要传入一个固定长度的依赖值数组进行比较,如果数组里的每个值都与最后一次的渲染相同,那么整个子树的更新将被跳过。可以用于优化更新性能。

v-memo 传入空依赖数组 v-memo="[]" 将与 v-once 效果相同。

<!-- 当组件重新渲染,如果 valueA 和 valueB 都保持不变,div 及其子项的所有更新都将被跳过。 -->
<div v-memo="[valueA, valueB]">...
</div>

条件渲染:

v-ifv-elsev-else-ifv-show :根据条件决定是否显示元素或组件。类似 JavaScript 中的条件语句。

<div id="app"><div v-if="Object.keys(info).length"><p>姓名:{{info.name}}</p><p>年龄:{{info.age}}</p></div><div v-else><p>暂无个人信息</p><p>请填写后查看</p></div>
</div><script>const app = Vue.createApp({data() {return {info: {name: 'Lee',age: 18,},}}})app.mount('#app')
</script>

v-ifv-show 的区别:

v-showv-if 类似,但二者也有一些区别:

  1. 用法上的区别:v-show 不可以和 v-else 一起使用,不支持在 template 上使用。
  2. 本质上的区别:
    1. v-show 无论条件是 true 还是 false,它的 DOM 都是实际存在的,只不过是通过 CSS 的 display 属性来进行切换。
      在这里插入图片描述
    2. v-if 只有当条件为 true 时,才会渲染条件块中的元素内容,当条件为 false 时,条件块中的元素内容完全不会被渲染。
      因此,如果元素切换频繁,就使用 v-show;如果元素切换不频繁,就使用 v-if

列表渲染:

v-for:用来遍历一组数据。类似 JavaScript 中的 for 循环 。基本格式是 v-for="(item, index) in 数据",其中 item 和 index 分别是每项元素的自定义别名和自定义索引。

<div id="app"><ul><li v-for="movie in movies">{{movie}}</li></ul>
</div><script>const app = Vue.createApp({data() {return {movies: ['大话西游', '少年派', '盗梦空间']}}})app.mount('#app')
</script>

v-for 遍历支持的类型:

其实只要是可迭代对象,v-for 都可以遍历。

  1. 数组:基本格式是 v-for="(item, index) in 数组"

    Vue 对被侦听的数组的变更方法进行了包裹,所以使用它们也会触发视图更新,这些方法包括 push()、pop()、shift()、unshift()、splice()、sort()、reverse()。
    可以发现,上面的方法都是会修改到原数组的;如果是不会修改到原数组的方法,是无法触发视图更新的,例如 map() 、filter() 等。

  2. 对象:基本格式是 v-for="(value, key, index) in 对象"
  3. 字符串:基本格式是 v-for="(str, index) in 字符串"
  4. 数字:基本格式是 v-for="(num, index) in 数字"

v-for 中的 key 属性:

在使用 v-for 进行列表渲染时,经常会给元素或者组件绑定一个 key 属性,属性值要求是唯一的。

<div id="app"><ul><li v-for="movie in movies" v-bind:key="item">{{movie}}</li></ul>
</div><script>const app = Vue.createApp({data() {return {movies: ['大话西游', '少年派', '盗梦空间']}}}) app.mount('#app')
</script>
key 的作用:

key 属性主要用于 Vue 中的虚拟 DOM 算法,在新旧 nodes 对比时辨识 VNodes。

  1. 如果不使用 key,Vue 会使用一种最大限制减少动态元素并且尽可能尝试就地复用/修改相同类型元素的算法。在源码中是使用 patchUnkeyedChildren() 方法。
  2. 如果使用 key,它会基于 key 的变化重新排列元素顺序,并且会移除/销毁 key 不存在的元素。在源码中是使用 patchkeyedChildren() 方法。
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
<div id="app"><ul><li v-for="movie in movies">{{movie}}</li></ul>
</div><script>const app = Vue.createApp({data() {return {movies: ['大话西游', '少年派', '盗梦空间']}}}) app.mount('#app')
</script>

假设要在大话西游后面插入夏洛特烦恼,原本是大话西游、少年派、盗梦空间,现在是大话西游、夏洛特烦恼、少年派、盗梦空间。
4. 不使用 key 的话:Vue 只能一个一个对比对应位置的元素。会发现第一个元素一样,可以直接复用;但是第二个元素就不一样了,原本是少年派,现在是夏洛特烦恼,因此需要修改其中的值;第三个元素也不一样,需要修改其中的值;还需要创建一个新的第四个元素。
5. 使用 key 的话:Vue 可以通过 key 来比较是否是同一个元素。会发现大话西游、少年派、盗梦空间的元素都一样,可以直接复用,只需要创建一个新的元素插入即可。

template 元素:

template 元素作为一个不可见的包裹元素,最终是不会被浏览器渲染出来的,与条件渲染和列表渲染结合使用可以减少元素层级的嵌套。

<div id="app"><template v-if="Object.keys(info).length"><p>姓名:{{info.name}}</p><p>年龄:{{info.age}}</p></template><template v-else><p>暂无个人信息</p><p>请填写后查看</p></template>
</div><script>
const app = Vue.createApp({data() {return {info: {name: 'Lee',age: 18,},}}
})
app.mount('#app')
</script>

可以看到,p 元素外面并不会再嵌套一层多元的元素。
在这里插入图片描述

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

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

相关文章

高级技巧-使用Mysql 实现根据条件过滤整个分组数据

博客-mysql exists实现过滤所属条件对应分组的全部数据 在数据查询中&#xff0c;有时需要根据某一条件来过滤整个分组的数据&#xff0c;尤其是当某条记录满足特定条件时&#xff0c;需要将该组内的所有记录排除。本文将介绍如何使用 MySQL 的 EXISTS 关键字来实现这种分组过滤…

游戏引擎学习第67天

reviewing “apron”概念以更新区域 我们正在进行模拟区域的扩展工作&#xff0c;目标是通过增加一个更大的区域来支持更丰富的互动&#xff0c;尤其是那些可能超出摄像机视野的内容。现有的模拟区域包括摄像机能看到的区域和其周围的环境区域&#xff0c;但为了保证更高效的游…

计算机网络|数据流向剖析与分层模型详解

文章目录 一、网络中的数据流向二、计算机网络通信模型1.OSI 模型2.TCP/IP 模型3.TCP/IP五层模型3.1 分层架构描述3.2各层地址结构3.3UDP数据包报头结构 三、总结 一、网络中的数据流向 在计算机网络中&#xff0c;数据的流向是指数据从发送端到接收端的传输路径。数据流向涉及…

如何在 Spring Boot 微服务中设置和管理多个数据库

在现代微服务架构中&#xff0c;通常需要与多个数据库交互的服务。这可能是由于各种原因&#xff0c;例如遗留系统集成、不同类型的数据存储需求&#xff0c;或者仅仅是为了优化性能。Spring Boot 具有灵活的配置和强大的数据访问库&#xff0c;可以轻松配置多个数据库。在本综…

【Raven1靶场渗透】

文章目录 一、基础信息 二、信息收集 三、暴力破解 四、提权 一、基础信息 Kali IP &#xff1a;192.168.20.146 靶机IP &#xff1a;192.168.20.153 二、信息收集 nmap -sS -sV -p- -A 192.168.20.153 开放了22&#xff0c;80&#xff0c;111&#xff0c;58305端口 访…

视频监控平台:Liveweb视频汇聚融合平台智慧安防视频监控应用方案

Liveweb是一款功能强大、灵活部署的安防视频监控平台&#xff0c;支持多种主流标准协议&#xff0c;包括GB28181、RTSP/Onvif、RTMP等&#xff0c;同时兼容海康Ehome、海大宇等厂家的私有协议和SDK接入。该平台不仅提供传统安防监控功能&#xff0c;还支持接入AI智能分析&#…

Pytorch | 利用SMI-FGRM针对CIFAR10上的ResNet分类器进行对抗攻击

Pytorch | 利用I-FGSSM针对CIFAR10上的ResNet分类器进行对抗攻击 CIFAR数据集SMI-FGRM介绍SMI-FGRM算法流程 SMI-FGRM代码实现SMI-FGRM算法实现攻击效果 代码汇总smifgrm.pytrain.pyadvtest.py 之前已经针对CIFAR10训练了多种分类器&#xff1a; Pytorch | 从零构建AlexNet对CI…

基于PREEvision的UML设计

众所周知&#xff0c;PREEvision是一款强大的电子电气架构协同开发及管理软件&#xff0c;可以很好地帮助架构工程师完成架构开发工作&#xff0c;其功能包括需求管理、定义功能逻辑、系统软件开发、网络设计、线束设计及整体工程的产品线管理和变形管理等。随着工程师们越来越…

闲谭Scala(2)--安装与环境配置

1. 概述 Java开发环境安装&#xff0c;需要两步&#xff0c;第一安装JDK&#xff0c;第二配置环境变量。 Scala的话&#xff0c;也是两步&#xff0c;第一安装Scale环境&#xff0c;第二配置环境变量。 需要注意的是&#xff0c;配置环境变量&#xff0c;主要是想让windows操…

智慧地下采矿:可视化引领未来矿业管理

图扑智慧地下采矿可视化平台通过整合多源数据&#xff0c;提供实时 3D 矿井地图及分析&#xff0c;提升了矿产开采的安全性与效率&#xff0c;为矿业管理提供数据驱动的智能决策支持&#xff0c;推动行业数字化转型。

王鹤棣新剧《大奉打更人》开播 数据亮眼刷新招商纪录

临近年末&#xff0c;各类国产剧集仍频上新&#xff0c;档期竞争格外激烈。而由王鹤棣领衔主演的古装悬疑轻喜剧《大奉打更人》已于12月28日在CCTV-8和腾讯视频同步播出&#xff0c;开播即横扫各大榜单。该剧从定档官宣到开播&#xff0c;热度一路攀升&#xff0c;开播后更是掀…

数据中台从centos升级为国产操作系统后,资源增加字段时,提交报500错误

文章目录 背景一、步骤1.分析阶段2.查看nginx3.修改用户&#xff08;也可以修改所有者权限&#xff09; 背景 故障报错&#xff1a; nginx报错信息&#xff1a; 2024/12/19 15:25:31 [crit, 500299#0: *249 onen0 " /var/lib/nginx/tmp/cient body/0000000001" f…

BLE core 内容整理解释

本文内容比较杂散&#xff0c;只是做记录使用&#xff0c;后续会整理的有条理些 link layer 基本介绍 **Link Layer Control&#xff08;链路层控制&#xff09;**是蓝牙低功耗&#xff08;BLE&#xff09;协议栈的核心部分&#xff0c;负责实现设备间可靠、安全、低功耗的数…

【疑难杂症】 HarmonyOS NEXT中Axios库的响应拦截器无法拦截424状态码怎么办?

今天在开发一个HarmonyOS NEXT的应用的时候&#xff0c;发现http接口如果返回的状态码是424时&#xff0c;我在axios中定义的拦截器失效了。直接走到了业务调用的catch中。 问题表现&#xff1a; 我的拦截器代码如下&#xff1a; 解决办法&#xff1a; 先说解决办法&#xff…

聚类评价指标

聚类评价指标分为 内部指标 和 外部指标 两大类&#xff0c;用于评估聚类算法的性能。 一、内部评价指标 内部评价指标不依赖真实标签&#xff0c;主要通过聚类结果本身的紧凑性和分离性进行评估。 轮廓系数&#xff08;Silhouette Coefficient, SC&#xff09; 衡量数据点与其…

flask后端开发(1):第一个Flask项目

目录 一、Helloworddebug、host、port的配置 gitcode地址&#xff1a; https://gitcode.com/qq_43920838/flask_project.git 一、Helloword 一般是会创建两个文件夹和app.py app.py from flask import FlaskappFlask(__name__)app.route(/) def hello_world():return Hello…

一文复盘:RAG技术-大模型

原文&#xff1a;https://zhuanlan.zhihu.com/p/13962398269 RAG&#xff08;Retrieval-Augmented Generation&#xff09;之所以被关注&#xff0c;有两方面原因&#xff1a; 1、没有跑大模型的资源&#xff1a;大多数人没有GPU集群搞LLM的预训练。 2、大模型缺乏知识&…

使用 OpenCV 绘制线条和矩形

OpenCV 是一个功能强大的计算机视觉库&#xff0c;它不仅提供了丰富的图像处理功能&#xff0c;还支持图像的绘制。绘制简单的几何图形&#xff08;如线条和矩形&#xff09;是 OpenCV 中常见的操作。在本篇文章中&#xff0c;我们将介绍如何使用 OpenCV 在图像上绘制线条和矩形…

WinForm 美化秘籍:轻松实现 Panel 圆角虚线边框

文章目录 1、引言2、案例实现1、创建自定义 Panel 类2、定义圆角矩形3. 使用自定义 Panel4. 调整属性5、使用背景图片来实现5、拓展&#xff1a;使用 Panel 的 Paint重绘单独实现虚线边框效果 3、实现效果4、总结 1、引言 在 Winform 应用程序开发中&#xff0c;美化用户界面&…

Spring Cloud LoadBalancer (负载均衡)

目录 什么是负载均衡 服务端负载均衡 客户端负载均衡 Spring Cloud LoadBalancer快速上手 启动多个product-service实例 测试负载均衡 负载均衡策略 自定义负载均衡策略 什么是负载均衡 负载均衡(Load Balance&#xff0c;简称 LB) , 是高并发, 高可用系统必不可少的关…