vue中常见的指令

简单介绍一下常见的vue中用到的指令

v-on

指定当前的事件,语法糖为@,如例子所示,指定按钮的事件为addCounter,点击会使变量counter + 1

html 复制代码
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<!-- <script src="https://unpkg.com/vue@next"></script> -->
		<script src="js/v3.2.8/vue.global.prod.js" type="text/javascript" charset="utf-8"></script>
	</head>
	<body>
		<div id="app">		
			{{ counter }}
			<button @click="addCounter">+1</button>
		</div>
		<script>
			const App = {
				data() {
					return {
						counter: 0
					}
				},
				methods: {
					addCounter() {
						this.counter ++;
					}
				}
			};
			Vue.createApp(App).mount('#app');
		</script>
	</body>
</html>

v-html

会将输出的文本解析为html

v-text

会将变量解析为文本

html 复制代码
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<!-- <script src="https://unpkg.com/vue@next"></script> -->
		<script src="js/v3.2.8/vue.global.prod.js" type="text/javascript" charset="utf-8"></script>
	</head>
	<body>
		<div id="app">		
			<p v-text="msg"></p>
			<p v-html="msg"></p>
		</div>
		<script>
			const App = {
				data() {
					return {
						msg: '<b>1</b>'
					}
				}
			};
			Vue.createApp(App).mount('#app');
		</script>
	</body>
</html>

v-if v-show

都可以控制元素的显示,v-show 不管显示不显示,元素都会被加载,使用的css的display属性去控制元素,v-if如果不显示的话,元素会在编译的时候被去除.

<p v-html="msg" v-if="displayFlg">

v-for

用户循环变量的显示,以及列表数据的显示。

html 复制代码
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<!-- <script src="https://unpkg.com/vue@next"></script> -->
		<script src="js/v3.2.8/vue.global.prod.js" type="text/javascript" charset="utf-8"></script>
	</head>
	<body>
		<div id="app">		
			<p v-for="(val,index) in arrayText">{{index}} -- {{val}} </p>
		</div>
		<script>
			const App = {
				data() {
					return {
						arrayText: ['蛮子', '寒冰', '剑圣']
					}
				}
			};
			Vue.createApp(App).mount('#app');
		</script>
	</body>
</html>

v-bind

用于绑定元素的属性,如下图给img标签绑定了src属性

html 复制代码
		<div id="app">		
			<img v-bind:src="imgsrc"/>
		</div>
		<script>
			const App = {
				data() {
					return {
						imgsrc: 'img/1.jpg'
					}
				}
			};
			Vue.createApp(App).mount('#app');
		</script>

v-model

用于绑定表单元素的值,改变表单中的值,也会改变对应的属性值

html 复制代码
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<!-- <script src="https://unpkg.com/vue@next"></script> -->
		<script src="js/v3.2.8/vue.global.prod.js" type="text/javascript" charset="utf-8"></script>
	</head>
	<body>
		<div id="app">
			<input  type="text" v-model="text"/>
			<p>{{text}}</p>
		</div>
		<script>
			const App = {
				data() {
					return {
						text: 'Hi好'
					}
				}
			};
			Vue.createApp(App).mount('#app');
		</script>
	</body>
</html>

v-pre

跳过元素的vue编辑

v-once

只加载一次,后续改变不在渲染

v-cloak

用于元素未完全加载时候,不显示。需要配合css来使用。

v-cloak\] { display: none; }

相关推荐
空&白2 分钟前
vue暗黑模式
javascript·vue.js
VT.馒头1 小时前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
css趣多多1 小时前
一个UI内置组件el-scrollbar
前端·javascript·vue.js
-凌凌漆-1 小时前
【vue】pinia中的值使用 v-model绑定出现[object Object]
javascript·vue.js·ecmascript
大橙子额3 小时前
【解决报错】Cannot assign to read only property ‘exports‘ of object ‘#<Object>‘
前端·javascript·vue.js
WooaiJava5 小时前
AI 智能助手项目面试技术要点总结(前端部分)
javascript·大模型·html5
LYFlied5 小时前
从 Vue 到 React,再到 React Native:资深前端开发者的平滑过渡指南
vue.js·react native·react.js
Never_Satisfied5 小时前
在JavaScript / HTML中,关于querySelectorAll方法
开发语言·javascript·html
董世昌415 小时前
深度解析ES6 Set与Map:相同点、核心差异及实战选型
前端·javascript·es6
B站_计算机毕业设计之家5 小时前
豆瓣电影数据采集分析推荐系统 | Python Vue Flask框架 LSTM Echarts多技术融合开发 毕业设计源码 计算机
vue.js·python·机器学习·flask·echarts·lstm·推荐算法