一个 vue 的单文件 SAP ( single page web application ) 即在一个 .vue 为后缀的文件中, 会包含3个部分.

  • 模板: html
  • 逻辑: javascript
  • 样式: css

这种同时存在, 然后组成一个小组件的方式其实, 其实非常符合编程思维的. 比原本拆分为 .html, .css, .js 这样的方式好维护很多. 本篇讲关于模板部分的一些 vue 的常用语法.

插值表达式 {{ }}

花括号里是可以放变量和 js 表达式的.

<!DOCTYPE html>
<html lang="en">
<head>
<title>常用模板语法</title>
<script src="https://unpkg.com/vue@3"></script>
</head>
<body>
<div id="root"></div>
<script>
const app = Vue.createApp({
data () {
return {
message: 'hello, world!'
}
},
template: `<div>{{message.toUpperCase()}}</div>`
}) app.mount('#root')
</script>
</body>
</html>

则页面会显示:

HELLO, WORLD!

v-html

告诉模板将以 html 的方式来展示数据, 举例如下:

<!DOCTYPE html>
<html lang="en">
<head>
<title>常用模板语法</title>
<script src="https://unpkg.com/vue@3"></script>
</head>
<body>
<div id="root"></div>
<script>
const app = Vue.createApp({
data () {
return {
message: 'hello, world!'
}
},
// v-html: 以 html 的方式来展示数据
template: `<div v-html="message"></div>`
}) app.mount('#root')
</script>
</body>
</html>

则结果为: hello, world!

v-bind

用来绑定属性, 当然也可以简写为 ":"

<!DOCTYPE html>
<html lang="en">
<head>
<title>常用模板语法</title>
<script src="https://unpkg.com/vue@3"></script>
</head>
<body>
<div id="root"></div>
<script>
const app = Vue.createApp({
data () {
return {
disabled: false
}
},
template: `<input v-bind:disabled="disabled" />`
// template: `<input :disabled="disabled" />`
}) app.mount('#root')
</script>
</body>
</html>

值得注意的是这里的属性绑定可以简写为:

<input :disabled="disabled" />

另外在补充两个常用但一看就懂的 DOM 元素的 显示 / 隐藏 指令 v-show 和 v-if

  • v-if : 当值为 true 的显示, 否则不显示, 本质是动态在 DOM 树内增删元素
  • v-show: 当值为 true 的显示, 否则不显示, 本质是 display: none
<!DOCTYPE html>
<html lang="en">
<head>
<title>v-if 和 v-show</title>
<script src="https://unpkg.com/vue@3"></script>
</head>
<body>
<div id="root"></div>
<script>
const app = Vue.createApp({
data () {
return {
message: 'hello, world',
show: false
}
},
methods: {
handleClick () {
this.show = !this.show
}
},
// template: `<div v-if="show">{{message}}</div>`
template: `
<div v-show="show" @click=>{{message}}</div>
<button @click="handleClick">显示/隐藏</button>
`
}) app.mount('#root')
</script>
</body>
</html>

从真实的使用频率来看, 就那种频繁显示隐藏的建议用 v-show; 使用次数不多的用 v-if 这样可以减少增删 dom 的消耗.

v-on

这里最为常用的就是点击事件 v-on:click = 'xxx'.

<!DOCTYPE html>
<html lang="en">
<head>
<title>常用模板语法</title>
<script src="https://unpkg.com/vue@3"></script>
</head>
<body>
<div id="root"></div>
<script>
const app = Vue.createApp({
data () {
return {
message: 'hello, world'
}
},
methods: {
handleClick () {
alert('click')
}
},
template: `<div v-on:click="handleClick">{{message}}</div>`
// template: `<div @click="handleClick">{{message}}</div>`
}) app.mount('#root')
</script>
</body>
</html>

值得注意的是这里的 v-on:click 事件绑定可以简写为:

<div @click="handleClick">{{message}}</div>

动态属性和事件绑定 [ ]

即对 dom 元素的属性和事件名, 通过数据的方式进行动态的绑定, 栗子如下:

<!DOCTYPE html>
<html lang="en">
<head>
<title>动态属性和事件绑定</title>
<script src="https://unpkg.com/vue@3"></script>
</head>
<body>
<div id="root"></div>
<script>
const app = Vue.createApp({
data () {
return {
message: 'hello, world',
// event: 'click',
event: 'mouseenter',
name: 'title'
}
},
methods: {
handleClick () {
alert('click')
}
},
template: `
<div
@[event]="handleClick"
@[name]="message"
>
{{message}}
</div>
`
}) app.mount('#root')
</script>
</body>
</html>

阻止默认行为 @click.prevent

通常是用于表单的提交, 我们要设置默认不让其跳转 (要改为手动提交校验这样的逻辑):

<!DOCTYPE html>
<html lang="en">
<head>
<title>阻止默认行为</title>
<script src="https://unpkg.com/vue@3"></script>
</head>
<body>
<div id="root"></div>
<script>
const app = Vue.createApp({
data () {
return {
message: 'hello, world',
// event: 'click',
event: 'mouseenter',
name: 'title'
}
},
methods: {
handleClick () {
alert('click')
}
},
template: `
<form action="https://www.baidu.com"
@click.prevent="handleClick"
>
<button type="submit">提交</button>
{{message}}
</form>
`
}) app.mount('#root')
</script>
</body>
</html>

简单就到这里了, 这些常用的模板语法其实就那么几个, 用多了就熟悉了.

vue3 基础-常用模板语法的更多相关文章

  1. Vue常用模板语法

    常用模板语法   本篇将在上一篇的基础上记录文本渲染.表达式.过滤器以及常用指令的简单用法. 一.文本渲染 Vue支持动态渲染文本,即在修改属性的同时,实时渲染文本内容.同时为了提高渲染效率,也支持只 ...

  2. Vue.js学习笔记(二) - 常用模板语法

    本篇将在上一篇的基础上记录文本渲染.表达式.过滤器以及常用指令的简单用法. 一.文本渲染 Vue支持动态渲染文本,即在修改属性的同时,实时渲染文本内容.同时为了提高渲染效率,也支持只渲染一次,即第一次 ...

  3. .net 开源模板引擎jntemplate 教程:基础篇之语法

    一.基本概念 上一篇我们简单的介绍了jntemplate并写了一个hello world(如果没有看过的,点击查看),本文将继续介绍jntemplate的模板语法. 我们在讲解语法前,首先要了解一下标 ...

  4. 12月14日内容总结——模板层之标签、自定义模板语法、母版(模版)的继承与导入、模型层前期准备知识点、ORM常用关键字

    目录 一.模板层之标签 分支结构if for循环 with(定义变量名) 二.自定义过滤器.标签及inclusion_tag(了解) 三.母版(模板)的继承与导入(重要) 四.模型层之前期准备 模型层 ...

  5. 100多个基础常用JS函数和语法集合大全

    网站特效离不开脚本,javascript是最常用的脚本语言,我们归纳一下常用的基础函数和语法: 1.输出语句:document.write(""); 2.JS中的注释为//3.传统 ...

  6. vue基础——模板语法

    模板语法介绍 Vue.js使用了基于HTML的模板语法,允许开发者声明式地将dom绑定至底层Vue实例的数据.所有Vue.js的模板都是合法的HTML,所以能被遵循规范的浏览器和HTML解析器解析. ...

  7. 基础常用JS函数和语法

    100多个基础常用JS函数和语法集合大全  来源:http://www.cnblogs.com/hnyei/p/4605103.html 网站特效离不开脚本,javascript是最常用的脚本语言,我 ...

  8. golang 模板(template)的常用基本语法

    1. 模板 在写动态页面的网站的时候,我们常常将不变的部分提出成为模板,可变部分通过后端程序的渲染来生成动态网页,golang提供了html/template包来支持模板渲染. 这篇文章不讨论gola ...

  9. vue基础---模板语法

    Vue.js 使用了基于 HTML 的模板语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据.所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器和 HTML 解 ...

  10. Vue模板语法与常用指令

    Vue.js 使用了基于 HTML 的模板语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据.在底层的实现上,Vue 将模板编译成虚拟 DOM 渲染函数,结合相应系统,在应用状态改变时 ...

随机推荐

  1. Johnson 全源负权最短路径算法详解

    Floyd-Warshall算法可以求解出图内任意两点的最短路径,适用于稠密图,但时间复杂度为 \(O(n³)\):Dijkstra算法求解单源最短路径的时间复杂度为 \(O(m + n log n) ...

  2. FreeModbus源码详解(转)

    学习转载原文链接: https://blog.csdn.net/golf_research/article/details/52240739 https://blog.csdn.net/u014748 ...

  3. 摸鱼日历,新闻简报等一些工作摸鱼日历API接口合集分享

    摸鱼人日历API接口 请求示例(图片输出): https://moyu.qqsuu.cn 请求示例(JSON输出):[推荐] https://moyu.qqsuu.cn/?type=json 调用示例 ...

  4. 2024.11.19随笔&联考总结

    联考 看到 T1 就知道一定是简单计数题然后发现 \(O(n)\) 可以过于是就大概写了写式子就开写.写的过程中犯了一些低级错误,代码重构了一次才过.耽误的时间比较久.然后开 T2,一眼有一个 \(O ...

  5. AI时代的灵魂拷问:我们真正的核心竞争力到底是什么?

    "当所有人都在谈论AI+的时候,今天我想聊一点不一样的..." 上周,朋友看着我用Cursor在30分钟内完成了他过去需要两天才能完成的工作. 那一刻,一种强烈的危机感涌上心头,他 ...

  6. 寻找旋转排序数组中的最小值 II

    地址:https://leetcode-cn.com/problems/find-minimum-in-rotated-sorted-array-ii/ <?php /** 154. 寻找旋转排 ...

  7. Windows服务器等保审核安全设置

    1.开启账户锁定策略 进入Windows服务器,快捷键"WIN+R"打开运行窗口.输入"gpedit.msc"并点击确定,依次点击"计算机配置&quo ...

  8. 【由技及道】螺蛳壳里做道场-git仓库篇-gitlab-Vs-gitea【人工智障AI2077的开发日志001】

    指令接收:「开始构建代码宇宙」 系统检测:需求模糊度99.9% 启动应急协议:构建最小可行性生态圈 核心组件锁定:代码基因库(人类称之为Git仓库) 需求分析:论人类语言的艺术性 人类指令翻译机 表面 ...

  9. 『Python底层原理』--GIL对多线程的影响

    在 Python 多线程编程中,全局解释器锁(Global Interpreter Lock,简称 GIL)是一个绕不开的话题. GIL是CPython解释器的一个机制,它限制了同一时刻只有一个线程可 ...

  10. [Qt 基础-01] QPushButton

    QPushButton 简介 QPushButton是一个很常用的一个按钮控件,主要用于创建一个可按压的按键.它显示了一 个文本和一个图标.另外,你也可以在创建时,指定一个快捷键. 基本用法 1. 创 ...