【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-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

数据绑定

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

注意

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

  • 前者是把方法的返回值插入
  • 后者完全是函数插值

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

#晒一晒我的offer##我的实习求职记录#
全部评论

相关推荐

查看36道真题和解析 软件开发2024笔面经
点赞 评论 收藏
转发
头像
不愿透露姓名的神秘牛友
05-11 18:19
1.&nbsp;简述多态实现的原理。2.&nbsp;链表和数组有什么区别?3.&nbsp;简述队列和栈的异同。4.&nbsp;&amp;&amp;和&amp;、||和|有什么区别?5.&nbsp;C++的引用和C语言的指针有什么区别?6.&nbsp;typedef和define有什么区别?7.&nbsp;关键字const是什么?8.&nbsp;static有什么作用?9.&nbsp;extern有什么作用?10.&nbsp;流操作符重载为什么返回引用?11.&nbsp;简述指针常量与常量指针的区别。12.&nbsp;如何避免&quot;野指针&quot;?13.&nbsp;常引用有什么作用?14.&nbsp;构造函数能否为虚函数?15.&nbsp;关键字volatile有什么含意(举例说明)?16.&nbsp;程序什么时候应该使用线程,什么时候单线程效率高?17.&nbsp;Linux有内核级线程吗?18.&nbsp;C++中什么数据分配在栈或堆中,new分配数据是在近堆还是远堆中?19.&nbsp;使用线程是如何防止出现大的波峰?20.&nbsp;函数模板与类模板有什么区别?21.&nbsp;动态连接库的两种方式?22.&nbsp;什么是平衡二叉树?23.&nbsp;冒泡排序算法的时间复杂度是什么?24.&nbsp;C和C++中的struct有什么不同?25.&nbsp;用预处理指令#define声明一个常数,用以表明1年中有多少秒(忽略闰年问题)。26.&nbsp;不能做switch()的参数类型是?27.&nbsp;全局变量可不可以定义在可被多个.C文件包含的头文件中?为什么?28.&nbsp;8086是多少位的系统?在数据总线上是怎么实现的?29.&nbsp;局部变量能否和全局变量重名?30.&nbsp;结构传递和返回是如何实现的?为什么sizeof返回的值大于结构大小的期望值,是不是尾部都有填充?答案在面经中&nbsp;&nbsp;c++/嵌入式面经专栏-牛客网 https://www.nowcoder.com/creation/manager/columnDetail/MJNwoM
查看30道真题和解析
点赞 评论 收藏
转发
2 收藏 评论
分享
正在热议
# 牛客帮帮团来啦!有问必答 #
1152487次浏览 17153人参与
# 通信和硬件还有转码的必要吗 #
11234次浏览 101人参与
# 不去互联网可以去金融科技 #
20603次浏览 258人参与
# 和牛牛一起刷题打卡 #
19066次浏览 1635人参与
# 实习与准备秋招该如何平衡 #
203482次浏览 3628人参与
# 大厂无回复,继续等待还是奔赴小厂 #
4993次浏览 31人参与
# OPPO开奖 #
19280次浏览 268人参与
# 通信硬件薪资爆料 #
266003次浏览 2484人参与
# 国企是理工四大天坑的最好选择吗 #
2235次浏览 34人参与
# 互联网公司评价 #
97728次浏览 1280人参与
# 简历无回复,你会继续海投还是优化再投? #
25040次浏览 354人参与
# 0offer是寒冬太冷还是我太菜 #
454946次浏览 5125人参与
# 国企和大厂硬件兄弟怎么选? #
53925次浏览 1013人参与
# 参加过提前批的机械人,你们还参加秋招么 #
14647次浏览 349人参与
# 硬件人的简历怎么写 #
82294次浏览 852人参与
# 面试被问第一学历差时该怎么回答 #
19410次浏览 213人参与
# 你见过最离谱的招聘要求是什么? #
28386次浏览 248人参与
# 学历对求职的影响 #
161271次浏览 1804人参与
# 你收到了团子的OC了吗 #
538813次浏览 6389人参与
# 你已经投递多少份简历了 #
344308次浏览 4963人参与
# 实习生应该准时下班吗 #
97007次浏览 722人参与
# 听劝,我这个简历该怎么改? #
63528次浏览 622人参与
牛客网
牛客企业服务