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; }

相关推荐
丶乘风破浪丶3 分钟前
Vue项目中判断相同请求的实现方案:从原理到实战
前端·javascript·vue.js
0思必得06 分钟前
[Web自动化] JS基础语法与数据类型
前端·javascript·自动化·html·web自动化
xiaohe06017 分钟前
📦 Uni ECharts 是如何使用定制 echarts 的?一篇文章轻松掌握!
vue.js·uni-app·echarts
Hy行者勇哥8 分钟前
JavaScript性能优化实战:从入门到精通
开发语言·javascript·性能优化
Irene199117 分钟前
JavaScript 常见算法复杂度总结(大O表示法)
javascript·算法
光影少年24 分钟前
Vue 2 / Vue 3 diff算法
前端·javascript·vue.js
未来之窗软件服务34 分钟前
JAVASCRIPT 离线解析IP地址 幽冥大陆(七十) —东方仙盟练气期
开发语言·javascript·tcp/ip·仙盟创梦ide·东方仙盟
指尖跳动的光38 分钟前
如何减少项目里面if-else
前端·javascript
yanghuashuiyue39 分钟前
Vue3难以统一的命名规范
前端·vue.js·typescript
AAA阿giao1 小时前
用 LangChain 玩转大模型:从零搭建你的第一个 AI 应用
javascript·人工智能·langchain·llm·ai编程·ai开发