【Vue】大悟!模板语法-插值语法指令语法

2023-12-26 10:30

本文主要是介绍【Vue】大悟!模板语法-插值语法指令语法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

模板语法

Vue模板语法包括两大类

  1. 插值语法

插值语法也就是两个大括号,也叫Mustache

功能:用于解析标签体内容,可以进行运算、三元表达式等,将最终解析出来的内容插入到标签中

写法:{{xxx}},xxx 是 js 表达式,可以直接读取到 data 中的所有区域

  • 插值表达式中只能放置单个表达式,不支持语句块、循环、条件语句等

  • 插值表达式中的内容会被解释为JS 表达式,因此你可以在其中执行基本的JS 运算、函数调用和条件判断等

  • 如果需要更复杂的逻辑,应该使用计算属性、方法或者指令来实现--后面会讲到

  • 在插值表达式中,你直接使用属性名(无需 this),Vue.js 会自动识别并将表达式与 Vue 实例的数据进行绑定因为 Vue 在模板编译过程中会自动处理这些细节

  1. 指令语法

功能:用于解析标签(包括:标签属性、标签体内容、绑定事件…)

举例:<a v-bind:href="xxx">或简写为<a :href="xxx">,xxx 同样要写 js 表达式,可以直接读取到 data 中的所有属性

备注:Vue中有很多的指令,且形式都是 v-xxx,此处只是拿v-bind举例

代码

<div id="root"><!-- 普通写法 --><!-- 单向数据绑定:<input type="text" v-bind:value="name"><br/>双向数据绑定:<input type="text" v-model:value="name"><br/> --><!-- 简写 -->单向数据绑定:<input type="text" :value="name"><br/>双向数据绑定:<input type="text" v-model="name"><br/><!--v-model只能应用在表单类元素(输入类元素)上 --><!-- <h2 v-model:x="name">错了</h2> --></div></body><script type="text/JS">Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示new Vue({el:'#root',data:{name:'即兴小索奇'}})</script>

拓展

  • vue中的指令都是v-开头

  • 输出vue实例时,f12查看,里面带$ 符号的,都是给我们用的,下划线_结尾的是vue底层用的,不是给我们用的

  • 函数都会有 prototype ,除了 Function.prototype.bind() 之外

  • 对象都会有 __proto__ ,除了 Object.prototype 之外(其实它也是有的,之不过是 null

  • 所有函数都由 Function 创建而来,也就是说他们的 __proto__ 都等于 Function.prototype

  • Function.prototype 等于 Function.__proto__

具体来说vue示例

  • _ 开头的表示 Vue 内部属性,如 _isVue_uid 等,不要直接操作改属性

  • $ 开头的表示 Vue 添加的实例属性/方法,如 、refs、、emit 等(可以直接vue.$调用哈)

  • 粉红色的是响应式属性,即和模板绑定的数据,在 datacomputed 等中定义,可以直接修改它们触发响应式更新

  • 普通的black色属性是用户可能额外定义的普通属性,不是响应式的

所以在打印 Vue 实例时,根据不同符号可以区分属性的作用,这可以帮助我们更好地理解和使用 Vue需要注意只有 data 中的数据和 computed 是响应式的

JS 中没有类的概念的,主要通过原型链来实现继承通常情况下,继承意味着复制操作,但在 JS中 默认并不会复制对象的属性,相反,JS 只是在两个对象之间创建一个关联(原型对象指针),这样,可以简单理解为委托(继承),一个对象就可以通过委托访问另一个对象的属性和函数,所以与其叫继承,委托的说法反而更准确些

当要找一个自己对象原型上没有的属性或者方法的时候,会沿着原型链一级一级的往上走 s1===>s1.__proto__==>s1.__proto__.__proto__==>s1.__proto__.__proto__.__proto__==>null

const c = new Vue({el:'#root',data:{name:'即兴小索奇'}})console.log(c);

图中的name是数据代理(后期会讲到-简单理解就是修改能变化的数据)

image-20230807012433413

image-20230807012433413

image-20230807013614066

image-20230807013614066

插值语法

<!DOCTYPE html>
<html><head><meta charset="UTF-8" /><title>模板语法</title><!-- 引入Vue --><script type="text/JS" src="../js/vue.js"></script></head><body><div id="root"><h1>插值语法</h1><h3>你好,{{name}}</h3><hr/><h1>指令语法</h1><a v-bind:href="school.url.toUpperCase()" x="hello">点我去{{school.name}}学习1</a><a :href="school.url" x="hello">点我去{{school.name}}学习2</a></div></body><script type="text/JS">Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示new Vue({el:'#root',data:{name:'jack',school:{name:'suoqi-teacher,url:'https://github.com/suoqi',}}})</script>
</html>

image.png

image.png

数据绑定

Vue中有2种数据绑定的方式

  • v-bind:单向绑定,数据只能从 data 流向页面

  • v-model:双向绑定,data和页面互通,改任意一方都可变化

备注

  • v-model:双向绑定一般都应用在表单类元素上,如 <input>``<select>``<textarea>等,如标题使用就会报错,因为这样的设计考虑到了页面双向的影响(如标题没有value输入,怎么影响data变化?没有意义了)

  • v-model:value可以简写为v-model,因为v-model默认收集的就是value值

  • v-bind:value 可以简写为:value

代码

<!DOCTYPE html>
<html><head><meta charset="UTF-8" /><title>数据绑定</title><!-- 引入Vue --><script type="text/JS" src="../js/vue.js"></script></head><body><!-- 准备好一个容器--><div id="root">单向数据绑定:<input type="text" :value="name"><br/>双向数据绑定:<input type="text" v-model="name"><br/><!-- 如下代码是错误的,因为v-model只能应用在表单类元素(输入类元素)上 --><!-- <h2 v-model:x="name">hello</h2> --></div></body><script type="text/JS">Vue.config.productionTip = false //阻止 vue 在启动时生成生产提示new Vue({el:'#root',// data中的属性名也可加引号,但常常不加引号data:{name:'即兴小索奇'}})</script>
</html>

image-20230807005208611

image-20230807005208611

注意

在插值中{{method()}}{{method}}完全不同

  • 前者是把方法的返回值插入

  • 后者完全是函数插值

对您有用的话请点个免费的爱心叭~

这篇关于【Vue】大悟!模板语法-插值语法指令语法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/539077

相关文章

C# $字符串插值的使用

《C#$字符串插值的使用》本文介绍了C#中的字符串插值功能,详细介绍了使用$符号的实现方式,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录$ 字符使用方式创建内插字符串包含不同的数据类型控制内插表达式的格式控制内插表达式的对齐方式内插表达式中使用转义序列内插表达式中使用

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

SpringBoot集成EasyPoi实现Excel模板导出成PDF文件

《SpringBoot集成EasyPoi实现Excel模板导出成PDF文件》在日常工作中,我们经常需要将数据导出成Excel表格或PDF文件,本文将介绍如何在SpringBoot项目中集成EasyPo... 目录前言摘要简介源代码解析应用场景案例优缺点分析类代码方法介绍测试用例小结前言在日常工作中,我们经

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框

HTML img标签和超链接标签详细介绍

《HTMLimg标签和超链接标签详细介绍》:本文主要介绍了HTML中img标签的使用,包括src属性(指定图片路径)、相对/绝对路径区别、alt替代文本、title提示、宽高控制及边框设置等,详细内容请阅读本文,希望能对你有所帮助... 目录img 标签src 属性alt 属性title 属性width/h

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

HTML5 中的<button>标签用法和特征

《HTML5中的<button>标签用法和特征》在HTML5中,button标签用于定义一个可点击的按钮,它是创建交互式网页的重要元素之一,本文将深入解析HTML5中的button标签,详细介绍其属... 目录引言<button> 标签的基本用法<button> 标签的属性typevaluedisabled