前端_Vue_2.创建一个Vue应用、模板语法

news2025/1/2 0:23:56

文章目录

  • 一、创建一个Vue应用
    • 1.1. 应用实例
    • 1.2. 根组件
    • 1.3. 挂载应用
      • 1.3.1. DOM中的根组件模板
    • 1.4. 应用配置
    • 1.5. 多个应用实例
  • 二、模板语法
    • 2.1. 文本插值
    • 2.2. 原始HTML
    • 2.3. Attribute绑定
      • 2.3.1. 简写
      • 2.3.2. 布尔型 Attribute
      • 2.3.3. 动态绑定多个值
    • 2.4. 使用JavaScript表达式
      • 2.4.1. 仅支持表达式
      • 2.4.2. 调用函数
      • 2.4.3. 受限的全局访问
    • 2.5. 指令 Directives
      • 2.5.1. 参数 Arguments
      • 2.5.2. 动态参数
        • 2.5.2.1. 动态参数值的限制
        • 2.5.2.2. 动态参数语法的限制
      • 2.5.3. 修饰符 Modifiers


一、创建一个Vue应用

1.1. 应用实例

每个Vue应用都是通过createApp函数创建一个新的 应用实例

import { createApp } from 'vue'
const app = createApp({
	/* 根组件选项 */
})

// 这段代码一般是放在后台的js代码中。
// 创建app后,挂载到前端HTML的DOM元素上

1.2. 根组件

传入createApp的对象实际上是一个组件,每个应用(app)都需要一个“根组件”,其他组件将作为其子组件。

如果你使用的是单文件组件(就是前文说的.vue文件),我们可以直接从文件中导入根组件。

import { createApp } from 'vue'
// 从一个单文件组件中导入根组件
import App from './App.vue'

const app = createApp(App)

虽然本文的许多示例只需要一个组件,但大多数真实的应用都是由一课嵌套的、可重用的组件树组成的。例如,一个代办事项(Todos)应用的组件树可能是这样的:

App (root component)
├─ TodoList
│  └─ TodoItem
│     ├─ TodoDeleteButton
│     └─ TodoEditButton
└─ TodoFooter
   ├─ TodoClearButton
   └─ TodoStatistics

1.3. 挂载应用

应用实例必须在调用了.mount()方法后才会渲染出来。该方法接收一个“容器”参数,可以是一个实际的DOM元素或是一个CSS选择器字符串:

DOM元素
Document Object Model,取首字母缩写为DOM,翻译过来就是文档对象模型。
当创建好一个页面并加载到浏览器时,DOM就出现了(相当于把HTML文档抽象转换为内存中的一个树形的数据结构对象),它会把网页文档转换为一个文档对象,以方便处理网页内容。 在HTML DOM中,每个元素都是一个节点,所有元素呈现出一种层次结构,可以将它称为节点树。
<div id="app"></div>
app.mount('#app');

应用根组件的内容将会被渲染在容器元素里面。容器元素自己将不会被视为应用的一部分。

.mount()方法应该始终在整个应用配置和资源注册完成后被调用。同时注意,不同于其他资源注册方法,它的返回值是根组件实例而非应用实例。

1.3.1. DOM中的根组件模板

当在未采用构建流程的情况下使用Vue时,我们可以在挂载容器中直接书写根组件模板:

<div id="app">
  <button @click="count++">{{ count }}</button>
</div>

import { createApp } from 'vue'

const app = createApp({
  data() {
    return {
      count: 0
    }
  }
})

app.mount('#app')

当根组件没有设置 template 选项时,Vue将自动使用容器的 innerHTML 作为模板(上面的容器是id为app的div)。

innerHTML设置或获取标签所包含的HTML+文本信息(从标签起始位置到终止位置全部内容包括HTML标签,但不包括自身)

1.4. 应用配置

应用实例会暴露一个 .config 对象允许我们配置一些应用级选项,例如定义一个应用级的错误处理器,它将捕获所有由子组件上抛而未被处理的错误:

app.config.errorHandler = (err) => {
	/* 处理错误 */
}

应用实例还提供了一些方法来注册应用范围内可用的资源,例如注册一个组件:

app.component('TodoDeleteButton', TodoDeleteButton)

这使得 TodoDeleteButton 在应用的任何地方都是可用的。

确保在挂载应用实例之前完成所有应用配置!

1.5. 多个应用实例

应用实例并不只限于一个。createApp API允许你在同一个页面中创建多个共存的Vue应用,而且每个应用都拥有自己的用于配置和全局资源的作用域。

const app1 = createApp({
	/* ... */
});
app1.mount('#container-1')

const app2 = createApp({
	/* ... */
})
app2.mount('#container-2')

如果你正在使用Vue来增强服务器端渲染HTML,并且只想要Vue去控制一个大型页面中特殊的一小部分,应避免将一个单独的Vue应用实例挂载到整个页面上,而是应该创建多个小的应用实例,将它们分别挂载到所需的元素上去。

这点其实就是尽量将页面元素拆分的思想,组件化、模块化。
前期只要将页面划分好区域,然后挂载上Vue应用即可。


二、模板语法

Vue使用一种基于HTML的模板语法,使我们能够声明式地将其组件实例的数据绑定到呈现的DOM上。所有的Vue模板都是语法层面合法的HTML,可以被符合规范的浏览器和HTML解析器解析。

在底层机制中,Vue会将模板翻译成高度优化的JavaScript代码。结合响应式系统,当应用状态变更时,Vue能够智能地推导出需要重新渲染的组件的最少数量,并应用最少的DOM操作。

响应式
Vue会自动跟踪JavaScript状态并在其发生变化时响应式地更新DOM。(MVVM中的VM同步更新V)
这边的后台逻辑是JS写的,相当于VM。JS中改变属性值,会自动更新到前端的V中。

2.1. 文本插值

最基本的数据绑定形式是文本插值,它使用的是“Mustache”语法(即双大括号):

<span>Message:{{ msg }}</span>

双大括号标签会被替换为相应组件实例中 msg 属性的值。同时每次 msg 属性更改时它也会同步更新。

2.2. 原始HTML

双大括号会将数据解释为纯文本,而不是HTML。若想插入HTML,你需要使用 v-html 指令:

<p>Using text interpolation:{{ rawHtmll }}</p>
<p>Using v-html directive: <span v-html="rawHtml"></span></p>

在这里插入图片描述
这里我们遇到了一个新的概念。这里看到的 v-html attribute被称为一个 指令 。指令由 v- 作为前缀,表明它们是一些由Vue提供的特殊的attribute,你可能已经猜到了,它们将为渲染DOM应用特殊的响应式行为。这里我们所做的事情简单来说就是:在当前组件实例上,将此元素的innerHTML与rawHtml属性保持同步。

span 的内容将会被替换为 rawHtml 属性的值,插值为纯HTML——数据绑定将会被忽略。注意,你不能使用 v-html 来拼接组合模板,因为Vue不是一个基于字符串的模板引擎。在使用Vue时,应当使用组件作为UI重用和组合的基本单元。

⚠安全警告
在网站上动态渲染任意HTML是非常危险的,因为这非常容易造成XSS漏洞。
XSS,Cross Site Scripting,跨站脚本攻击。当用户故意设计了一段代码时,浏览器会将其误认为是插入了HTML标签,当这些HTML标签引入了一段JavaScript脚本时,这些脚本程序就将会在用户浏览器中执行,从而盗取信息。

2.3. Attribute绑定

双大括号不能在HTML attributes中使用。想要响应式地绑定一个attribute,应该使用 v-bind 指令:

<div v-bind:id="dynamicId"></div>

v-bind 指令指示Vue将元素的 id attribute与组件的 dynamicId 属性保持一致。如果绑定的值是 null 或者 undefined , 那么该attribute 将会从渲染的元素上移除。

2.3.1. 简写

因为 v-bind 非常常用,我们提供了特定的简写语法:

<div :id="dynamicId"></div>

开头为 : 的attribute可能和一般的HTML attribute看起来不太一样,但它的确是合法的attribute名称字符,并且所有支持Vue的浏览器都能正确解析它。此外,他们不会出现在最终渲染的DOM中。简写语法是可选的,但相信你在了解了它更多的用处后,你应该会更喜欢它。

接下来,我们都将在示例中使用简写语法,因为这是实际开发中更常见的用法。

2.3.2. 布尔型 Attribute

布尔型attribute依据true/false值来决定attribute是否应该存在于该元素上。disabled就是最常见的例子之一。

v-bind 在这种场景下的行为略有不同:

<button :disabled="isButtonDisabled">Button</button>

当 isButtonDisabled 为真值或一个空字符串(即<button disabled=“”>)时,元素会包含这个disabled attribute。而当其为其他假值时 attribute 将被忽略。

2.3.3. 动态绑定多个值

如果你有像这样的一个包含多个attribute的JavaScript对象:

data(){
	return {
		objectOfAttrs:{
			id:'container',
			class:'wrapper'
		}
	}
}

通过不带参数的 v-bind,你可以将它们绑定到单个元素上:

<div v-bind="objectOfAttrs"></div>

2.4. 使用JavaScript表达式

至此,我们仅在模板中绑定了一些简单的属性名。但是Vue实际上在所有的数据绑定中都支持完整的JavaScript表达式:

{{ number +1 }}
{{ ok ? 'YES' : 'NO' }}
{{ message.split('').reverse().join('') }}
<div :id="'list-${id}'"></div>

这些表达式都会被作为JavaScript,以组件为作用域解析执行。
在Vue模板内,JavaScript表达式可以被使用在如下场景上:

  • 在文本插值中(双大括号)
  • 在任何Vue指令(以 v- 开头的特殊attribute)attribute的值中

2.4.1. 仅支持表达式

每个绑定仅支持单一表达式,也就是一段能够被求值的JavaScript代码。一个简单的判断方法是是否可以合法地写在 return 后面。

因此,下面的例子都是无效的:

<!--这是一个语句,而非表达式-->
{{ var a = 1 }}
<!--条件控制也不支持,请使用三元表达式-->
{{ if(ok) { return message } }}

2.4.2. 调用函数

可以在绑定的表达式中使用一个组件暴露的方法:

<span :little="toTitleDate(date)">
	{{ formatDate(date) }}
</span>
ℹ Tip
绑定在表达式中的方法在组件每次更新时会被重新调用,因此不应该产生任何副作用,比如改变数据或触发异步操作。

2.4.3. 受限的全局访问

模板中的表达式将被沙盒化,仅能够访问到有限的全局对象列表。该列表中会暴露常用的内置全局对象,比如 Math 和 Date。

没有显式包含在列表中的全局对象将不能在模板内表达式中访问,例如用户附加在 window 上的属性。然而,你也可以自行在 app.config.globalProperties 上显式地添加它们,供所有的Vue表达式使用。

2.5. 指令 Directives

指令是带有 v- 前缀的特殊 attribute。Vue提供了许多内置指令,包括上面介绍的 v-bind 和 v-html。

指令attribute的期望值为一个JavaScript表达式(除了少数几个例外,即之后要讨论到的 v-for、v-on和v-slot)。一个指令的任务是在其表达式的值变化时响应式地更新DOM。以v-if为例:

<p v-if="seen">Now you see me</p>

这里,v-if 指令会基于表达式 seen 的值的真假来移除/插入该 <p>元素。

2.5.1. 参数 Arguments

某些指令会需要一个 “参数”,在指令名后通过一个冒号隔开做标识。例如用 v-bind 指令来响应式地更新一个 HTML attribute:

<a v-bind:href="url">...</a>
<!--简写-->
<a :href="url">...</a>

这里的 href 就是一个参数,它告诉 v-bind 指令将表达式 url 的值绑定到元素的 href attribute上。在简写中,参数前的一切(例如 v-bind:)都会被缩略为一个 : 字符。

另一个例子是 v-on 指令,它将监听DOM事件:

<a v-on:click="doSomething">...</a>
<!--简写-->
<a @click="doSomething">...</a>

这里的参数是要监听的事件名称: click。 v-on 有一个相应的缩写,即 @ 字符。

2.5.2. 动态参数

同样在指令参数上也可以使用一个JavaScript表达式,需要包含在一对方括号内:

<!--
注意,参数表达式有一些约束,
参见下面“动态参数值的限制”与“动态参数语法的限制”章节的解释
-->
<a v-bind:[attributeName]="url">...</a>
<!--简写-->
<a :[attributeName]="url">...</a>

这里的 attributeName 会作为一个JavaScript表达式被动态执行,计算得到的值会被用作最终的参数。举例来说,如果你的组件实例有一个数据属性attributeName,其值为"href",那么这个绑定就等价于v-bind:href。

相似地,你还可以将一个函数绑定到动态的时间名称上:

<a v-on:[eventName]="doSomething"> ... </a>

<!-- 简写 -->
<a @[eventName]="doSomething">

在此示例中,当 eventName的值是 "focus"时,v-on:[eventName]就等价于v-on:focus。

2.5.2.1. 动态参数值的限制

动态参数中表达式的值应当是一个字符串,或者是 null。特殊值null意为显式移除该绑定。其他非字符串的值会触发警告。

2.5.2.2. 动态参数语法的限制

动态参数表达式因为某些字符的缘故有一些语法限制,比如空格和引号,在HTML attribute名称中都是不合法的。例如下面的示例:

<a :['foo' + bar]="value">...</a>

如果你需要传入一个复杂的动态参数,我们推荐使用计算属性替换复杂的表达式,也是Vue最基础的概念之一。

当使用DOM内嵌模板(直接写在HTML文件里的模板)时,我们需要避免在名称中使用大写字母,因为浏览器会强制将其转换为小写:

<a :[someAttr]="value">...</a>

上面的例子将会在DOM内嵌模板中被转换为:[someattr]。如果你的组件拥有"someAttr"属性而非"someattr",这段代码将不会工作。单文件组件内的模板不受此限制。

2.5.3. 修饰符 Modifiers

修饰符是以点开头的特殊后缀,表明指令需要以一些特殊的方式被绑定。例如 .prevent 修饰符会告知 v-on 指令对触发的事件调用 event.preventDefault():

<form @sumbit.prevent="onSubmit">...</form>

完整的指令语法:
在这里插入图片描述

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

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

相关文章

记录一次Sql性能优化

场景&#xff1a; 主业务表 contract&#xff08;合同表&#xff09;&#xff0c;对于不同主体&#xff08;人员&#xff09;&#xff0c;能查看的合同是不一样的。系统企业业务用到了&#xff0c;系统资源表 PERMISSION_RESOURCE 、员工对于资源关系表&#xff1a;ENTRY_JOIN…

物联卡批发为什么那么火爆?

2022年物联网行业开始爆发&#xff0c;针对于企业设备联网的物联卡就显得格外重要了&#xff0c;而共享单车&#xff0c;移动支付&#xff0c;智慧城市&#xff0c;自动售卖机等企业采购物联卡会面临着各种问题&#xff0c;低价陷阱&#xff0c;流量虚假&#xff0c;管理混乱&a…

[Python图像处理] 合成微缩效果

合成微缩效果前言图像微缩效果原理实现图像微缩效果相关链接前言 图像中的模糊效果可以强烈影响被拍摄场景的感知&#xff0c;模糊在传达所需的尺寸和距离感方面起着重要作用。合成微缩 (miniature faking) 是一个使真实大小物体照片看起来像微缩模型照片的过程&#xff0c;也…

java必背综合知识点总结

一、JDK常用的包 java.lang&#xff1a; 这个是系统的基础类&#xff0c;比如String、Math、Integer、System和Thread&#xff0c;提供常用功能。 java.io: 这里面是所有输入输出有关的类&#xff0c;比如文件操作等 java.net: 这里面是与网络有关的类&#xff0c;比如URL,U…

寻找适配网红很迷茫?最全秘笈来了

根据《2022年全球数字概览》报告显示&#xff0c;全球社交媒体用户超过46.2亿&#xff0c;相当于全球总人口的58.4%。全球用户每天在社交媒体上平均花费近2.5个小时&#xff0c;并且每天以2分钟的速度增长。 社交媒体成为全球网民生活中不可或缺的一部分&#xff0c;而对于跨境…

【深度学习】Yolov5训练意外中断后如何接续训练详解;yolov5中断后继续训练

0. 前言 目标检测是计算机视觉上的一个重要任务,下面这篇文章主要给大家介绍了关于Yolov5训练意外中断后如何接续训练的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下 1. 配置环境 操作系统&#xff1a;Ubuntu20.04 CUDA版本&#xff1a;11.4 Pytorch版本…

Excel - 数据分析师所需的最常用公式。

“先打好基础,再细化细节——克里斯安德森” 这将是我正在撰写的关于必须具备数据分析技能的第 4 个也是最后一个“像你 5 岁一样解释”系列。(请观看其他的——Power BI、Python 和 SQL)。现在,我们将具备所需的所有基本技能,然后可以进入数据分析领域的下一阶段 使用 E…

Java实现大乐透不重复数字随机号码生成方案

大乐透攻略Java实现&#xff08;仅供参考学习&#xff09; 购票方式 每期最低购票数&#xff1a;7 张 最低消费&#xff1a;14 元 方案介绍&#xff1a;后区12个数中随机分成6组&#xff0c;且数字不重复。前区35个数随机分成7组&#xff0c;且数字不重复。前区需要7组才能够…

【目标检测】IoU、GIoU、DIoU、CIoU、EIoU 5大评价指标

目录 一、简介 二、IoU&#xff08;Intersection over Union&#xff09; 三、GIoU&#xff08;Generalized IoU&#xff09; 四、DIoU&#xff08;Distance-IoU&#xff09; 五、CIoU(Complete-IoU) 六、EIoU(Efficient-IoU) 七、pytorch代码实现 七、总结 一、简介 在目标检测…

即时通讯开发之如何测试实时语音通话质量

实时语音聊天开发&#xff0c;对于一般的开发者来说比较神秘&#xff0c;很多朋友不太清楚如何全面的评估一个音频引擎。很多朋友还停留在这样的初级阶段&#xff1a;把demo调通&#xff0c;找几个人喂喂喂......凭自己优异的听觉感受一下&#xff0c;整个测试过程就完成了。 但…

【嵌入式硬件芯片开发笔记】EEPROM芯片M24C32配置流程

【嵌入式硬件芯片开发笔记】EEPROM芯片M24C32配置流程 32-Kbit serial IC bus EEPROM - 105C operation 适用于M24C32/M24C32-DRE 读取存储的从机地址为&#xff1a;0x50 读取标识页面的从机地址为&#xff1a;0x58 WC引脚接地&#xff0c;存储可以进行写操作 地址长度为16位 存…

117. 填充每个节点的下一个右侧节点指针 II

文章目录1. 背2. 题目3. 答案1. 背 这道题本来可以很简答&#xff0c;一个队列&#xff0c;存储指针和它的行数就OK了&#xff0c;但是这道题的难点在于不用额外空间复杂度。 横向看一下&#xff0c;这一行是不是就是一个链表呢&#xff1f; 多加一个变量&#xff0c;用来存储第…

C++入门教程||C++ 判断||C++ 日期 时间

判断结构要求程序员指定一个或多个要评估或测试的条件&#xff0c;以及条件为真时要执行的语句&#xff08;必需的&#xff09;和条件为假时要执行的语句&#xff08;可选的&#xff09;。 下面是大多数编程语言中典型的判断结构的一般形式&#xff1a; 判断语句 C 编程语言提…

three.js实战 -自定义剪切器

1. 前言 这是我在github上看到大佬的一个作品&#xff0c;当时感觉很有意思&#xff0c;决定分享出来&#xff0c;不知道取这个名字是否正确&#xff0c;废话不多说看下面效果。 2.demo效果 3.需要掌握的知识 矩阵的基本运算&#xff0c;能够认是到一些基本变换用到的矩阵(…

晶圆级倒装装备及控制系统

晶圆级倒装装备主要由晶圆盘进料模块、晶圆盘工作台模块、覆晶模块、焊头模块、基板工作台模块、点胶模块、视觉模块和基板进出料模块组成&#xff0c;如图 2-2 所示。 晶圆级倒装装备控制系统结构晶圆级倒装装备的运控系统主要由工控机、运动控制卡、驱动器、反馈装置和直线电…

QA:observable and Subject

概念区别和常见的错误理解辩证&#xff1a; 通俗理解一下 1. Observable 是一条 "水管蓝图" ,每次打开水龙头&#xff0c;水流会按照设计好的路线流向终点。起点和终点一一对应。每次打开水流&#xff0c;都是新的流&#xff0c;水流之间互不影响。一次一管。 2. …

VMWare虚拟机设置CentOS7共享文件夹

1. 目录 系统版本&#xff1a;CentOS 7.9 文章目录1. 目录2. VMWare&#xff1a;虚拟机设置&#xff0c;设置共享文件夹3. 虚拟机设置&#xff1a;手动挂载共享文件夹4. 检查是否挂载成功5. (可选)创建共享文件夹的软链接(快捷方式)6. (可选)定时任务开机自动挂载2. VMWare&am…

博客文章分类导引(持续更新)

摘要&#xff1a;本文提供一篇博客目录&#xff0c;有物联网、安卓编程、硬件设计等若干主题&#xff0c;这些主题一般都是成系统的&#xff0c;可以实现从零开始做出自己的物联网系统。 文章结构如下&#xff1a; 1.物联网专栏 使用arduino编写mqtt客户端连接emqx服务器 VSC…

vue.js:组件化的实现和使用过程

什么是组件化&#xff1f; 当我们遇到复杂问题的时候&#xff1a; 任何一个人处理信息的逻辑能力都是有限的所以&#xff0c;当我们面对一个复杂的问题的时候&#xff0c;我们不可能一次性搞定处理掉一大堆内容但是我们都会有问题拆解的能力将一个复杂的问题拆解成很多小的问…

Springcloud笔记之Ribbon

Ribbon&#xff1a;负载均衡&#xff08;基于客户端&#xff09;1. 负载均衡以及Ribbon1.1 Ribbon 的概念1.2 Ribbon 的作用2. 集成Ribbon3. 使用Ribbon实现负载均衡3.1 步骤3.2 自定义规则1. 负载均衡以及Ribbon 1.1 Ribbon 的概念 Spring Cloud Ribbon 是基于Netflix Ribbo…