IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue之模板语法 -> 正文阅读

[JavaScript知识库]Vue之模板语法

一:插值

1.文本

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script>
		
	</head>
	<body>
		<!-- 定义边界 -->
		<div id="app">
			<p>文本</p>
			<h3>{{msg}}</h3>
		</div>
	</body>
	<script type="text/javascript">
		 /* 绑定边界 */
		 new Vue({
			 el:'#app',
			 // 方式一
			 data() {
			 	return{msg:'我是良好公民'};
			 }
		 })
	</script>
</html>

结果展示:

2.html

使用v-html指令用于输出html代码

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script>

	</head>
	<body>
		<!-- 定义边界 -->
		<div id="app">
			<p>文本</p>
			<h3>{{msg}}</h3>

			<p>html</p>
			<div v-html="htmlstr"></div>
		</div>
	</body>
	<script type="text/javascript">
		/* 绑定边界 */
		new Vue({
			el: '#app',
			data() {
				return {
					msg: '我是良好公民',
					htmlstr:'<h3 style="color:red;">测试html</h3>'
				};
			}
		})
	</script>
</html>

结果展示:

3.属性

HTML属性中的值应使用v-bind指令

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script>

	</head>
	<body>
		<!-- 定义边界 -->
		<div id="app">
			<p>文本</p>
			<h3>{{msg}}</h3>

			<p>html</p>
			<div v-html="htmlstr"></div>
			
			<p>vue的属性</p>
			<!-- 所有原生态的属性,要利用vue的变量,都需要在对应的属性前加v-bind -->
			<a v-bind:href="hrefstr">百度</a>
			
			
		</div>
	</body>
	<script type="text/javascript">
		/* 绑定边界 */
		new Vue({
			el: '#app',
			data() {
				return {
					msg: '我是良好公民',
					htmlstr:'<h3 style="color:red;">测试html</h3>',
					hrefstr:'http://www.baidu.com'
				};
			}
		})
	</script>
</html>

结果展示:

点击后会跳转到百度的页面

4.表达式

Vue提供了完全的JavaScript表达式支持
? ? ? ? ? 例一:{{str.substr(0,4).toUpperCase()}}

<!--  {{str.substr(0,4).toUpperCase()}} 截取第0位到第四位的值,并全部大写-->
			{{str.substring(0,4).toUpperCase()}}
new Vue({
			el: '#app',
			data() {
				return {
					msg: '我是良好公民',
					htmlstr:'<h3 style="color:red;">测试html</h3>',
					hrefstr:'http://www.baidu.com',
					str:'abcdefj'
				};
			}
		})

结果展示:?


? ? ? ? ? 例二:{{ number + 1 }}

<!-- {{ number + 1 }} -->
			{{ number + 1 可以做运算}}
new Vue({
			el: '#app',
			data() {
				return {
					msg: '我是良好公民',
					htmlstr:'<h3 style="color:red;">测试html</h3>',
					hrefstr:'http://www.baidu.com',
					str:'abcdefj',
					number:59
				};
			}
		})

结果展示:


? ? ? ? ? 例三:{{ ok ? 'YES' : 'NO' }}

<!-- {{ ok ? 'YES' : 'NO' }}三元运算 -->
			{{ ok ? 'YES' : 'NO' }}
new Vue({
			el: '#app',
			data() {
				return {
					msg: '我是良好公民',
					htmlstr:'<h3 style="color:red;">测试html</h3>',
					hrefstr:'http://www.baidu.com',
					str:'abcdefj',
					number:59,
					ok:true
				};
			}
		})

结果展示:


? ? ? ? ? 例四:<li v-bind:id="'list-' + id">我的Id是js动态生成的</li>

<!-- <li v-bind:id="'list-' + id">我的Id是js动态生成的</li> -->
			<li v-bind:id="'list-' + id">我的Id是js动态生成的</li>
new Vue({
			el: '#app',
			data() {
				return {
					msg: '我是良好公民',
					htmlstr:'<h3 style="color:red;">测试html</h3>',
					hrefstr:'http://www.baidu.com',
					str:'abcdefj',
					number:59,
					ok:true,
					id:88
				};
			}
		})

?结果展示:

二:指令

指的是带有“v-”前缀的特殊属性

例一:v-if|v-else|v-else-if

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script>

	</head>
	<body>
		<!-- 定义边界 -->
		<div id="app">
			<p>v-if|v-else|v-else-if</p>
			<!-- v-if|v-else|v-else-if 如果大于80分为优秀,小于80大于60为良好,小于60为你天天在干什么 -->
			分数:<input v-model="score" />
			<div v-if="score>80">优秀</div>
			<div v-else-if="score>60">良好</div>
			<div v-else="score<60">你天天在干什么</div>
		</div>
	</body>
	<script type="text/javascript">
		/* 绑定边界 */
		new Vue({
			el: '#app',
			data() {
				return {
					score:78
				};
			}
		})
	</script>
</html>

结果展示:

将结果改为50

?

?然后再改为90

例二:v-show

<!-- v-show -->
			<div v-show="score>90">v-show:优秀</div>
new Vue({
			el: '#app',
			data() {
				return {
					score:78
				};
			}
		})

?结果展示:

再把分数改为小于90

分析:这里大家可能觉得v-if和v-show是一样的,但是其实他们是有区别的

我们加一行v-if在进行测试?

当大于90时都显示

当小于90时

可以看到v-show只是隐藏了,而v-if是完全消失了

例三:v-for? ?遍历?

<!-- v-for -->
			<select>
				<option v-for="h in hobby" :value="h.id">{{h.name}}</option>
			</select>
new Vue({
			el: '#app',
			data() {
				return {
					score:78,
					hobby:[
						{id:"1",name:"上班"},
						{id:"2",name:"摸鱼"},
						{id:"3",name:"摸虾"}
					]
				};
			}
		})

?结果展示:

做回显

<!-- v-for -->
			<select v-model="hobbySelected">
				<option v-for="h in hobby" :value="h.id">{{h.name}}</option>
			</select>
			<input v-model="hobbySelected" />
new Vue({
			el: '#app',
			data() {
				return {
					score:78,
					hobby:[
						{id:"1",name:"上班"},
						{id:"2",name:"摸鱼"},
						{id:"3",name:"摸虾"}
					],
					hobbySelected:3
				};
			}
		})

结果展示:

把3改为2

?

?做复选框

<div v-for="h in hobby">
				<input :value="h.id" type="checkbox" />{{h.name}}
			</div>
new Vue({
			el: '#app',
			data() {
				return {
					score:78,
					hobby:[
						{id:"1",name:"上班"},
						{id:"2",name:"摸鱼"},
						{id:"3",name:"摸虾"}
					],
					hobbySelected:3
				};
			}
		})

结果展示:

?例四:触发事件

<!-- 触发事件 -->
			<button v-on:click="handle">触发事件</button>
			<button @click="handle">触发事件2</button>
new Vue({
			el: '#app',
			data() {
				return {
					score:78,
					hobby:[
						{id:"1",name:"上班"},
						{id:"2",name:"摸鱼"},
						{id:"3",name:"摸虾"}
					],
					hobbySelected:3
				};
			},
			methods:{
				handle(){
					alert("触发事件")
				}
			}
		})

结果展示:

点击触发事件?

点击触发事件2

两种方式都可以触发?

例五:动态参数

只有点击两次才会触发

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script>

	</head>
	<body>
		<!-- 定义边界 -->
		<div id="app">
			<p>动态参数</p>
			<button v-on:[evname]="handle">动态参数</button>
		</div>
	</body>
	<script type="text/javascript">
		/* 绑定边界 */
		new Vue({
			el: '#app',
			data() {
				return {
					evname:'dblclick'
				};
			},
			methods:{
				handle(){
					alert("触发事件")
				}
			}
		})
	</script>
</html>

结果展示:

三:过滤器

作用:对原始数据进行处理

1.全局过滤器

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script>

	</head>
	<body>
		<!-- 定义边界 -->
		<div id="app">
			{{msg|all}}
		</div>
	</body>
	<script type="text/javascript">
		// 全局过滤器
		Vue.filter('all', function(value) {
				return value.substring(0,2);
		});
		
		// 局部过滤器
		
		/* 绑定边界 */
		new Vue({
			el: '#app',
			data() {
				return {
					msg:"abcdefj"
				};
			},
			methods: {
				handle() {
					alert("触发事件")
				}
			}
		})
	</script>
</html>

结果展示:

2.局部过滤器

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script>

	</head>
	<body>
		<!-- 定义边界 -->
		<div id="app">
			<p>全局</p>
			{{msg|all}}
			<p>局部</p>
			{{msg|single}}
		</div>
	</body>
	<script type="text/javascript">
		// 全局过滤器
		Vue.filter('all', function(value) {
				return value.substring(0,2);
		});
		
		// 局部过滤器
		
		/* 绑定边界 */
		new Vue({
			el: '#app',
			data() {
				return {
					msg:"abcdefj"
				};
			},
			methods: {
				handle() {
					alert("触发事件");
				}
			},
			filters:{
				'single':function(val){
					return val.substring(2,3);
				}
			}
		})
	</script>
</html>

结果展示:

?论证是否可以同时使用全局过滤器和局部过滤器

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script>

	</head>
	<body>
		<!-- 定义边界 -->
		<div id="app">
			<p>全局</p>
			{{msg|all}}
			<p>局部</p>
			{{msg|single}}
			<p>同时</p>
			{{msg|all|single}}
		</div>
	</body>
	<script type="text/javascript">
		// 全局过滤器
		Vue.filter('all', function(value) {
				return value.substring(1,4);
		});
		
		// 局部过滤器
		
		/* 绑定边界 */
		new Vue({
			el: '#app',
			data() {
				return {
					msg:"abcdefj"
				};
			},
			methods: {
				handle() {
					alert("触发事件");
				}
			},
			filters:{
				'single':function(val){
					return val.substring(2,3);
				}
			}
		})
	</script>
</html>

结果展示:

?

论证过滤器传参

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script>

	</head>
	<body>
		<!-- 定义边界 -->
		<div id="app">
			<p>全局</p>
			{{msg|all}}
			<p>局部</p>
			{{msg|single}}
			<p>同时</p>
			{{msg|all|single}}
			<p>过滤器传参</p>
			{{msg|param(4,5)}}
		</div>
	</body>
	<script type="text/javascript">
		// 全局过滤器
		Vue.filter('all', function(value) {
				return value.substring(1,4);
		});
		
		// 局部过滤器
		
		/* 绑定边界 */
		new Vue({
			el: '#app',
			data() {
				return {
					msg:"abcdefj"
				};
			},
			methods: {
				handle() {
					alert("触发事件");
				}
			},
			filters:{
				'single':function(val){
					return val.substring(2,3);
				},
				'param':function(val,start,end){
					return val.substring(start,end);
				}
			}
		})
	</script>
</html>

?结果展示:

四:计算属性&监听属性

1.计算属性

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script>

	</head>
	<body>
		<!-- 定义边界 -->
		<div id="app">
			<p>计算属性</p>
			<table border="1" style="width: 600px;height: 300px;">
				<tr>
					<td>洗</td>
					<td>30</td>
					<td>
						<input v-model="xi" />
					</td>
					<td>{{xiTotal}}</td>
				</tr>
				<tr>
					<td>剪</td>
					<td>30</td>
					<td>
						<input v-model="jian" />
					</td>
					<td>{{jianTotal}}</td>
				</tr>
				<tr>
					<td>吹</td>
					<td>188</td>
					<td>
						<input v-model="chui" />
					</td>
					<td>{{chuiTotal}}</td>
				</tr>
				<tr>
					<td>总价</td>
					<td colspan="3">{{total}}</td>
				</tr>
			</table>
		</div>
	</body>
	<script type="text/javascript">
		// 全局过滤器
		Vue.filter('all', function(value) {
				return value.substring(1,4);
		});
		
		// 局部过滤器
		
		/* 绑定边界 */
		new Vue({
			el: '#app',
			data() {
				return {
					xi:1,
					jian:1,
					chui:1
				};
			},
			methods: {
				handle() {
					alert("触发事件");
				}
			},
			computed:{
				xiTotal(){
					return this.xi*30;
				},
				jianTotal(){
					return this.jian*30;
				},
				chuiTotal(){
					return this.chui*188;
				},
				total(){
					return this.xiTotal+this.jianTotal+this.chuiTotal;
				}
			}
		})
	</script>
</html>

结果展示:

修改其中一个的变量

2.监听属性

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script>

	</head>
	<body>
		<!-- 定义边界 -->
		<div id="app">
			<p>计算属性</p>
			<table border="1" style="width: 600px;height: 300px;">
				<tr>
					<td>洗</td>
					<td>30</td>
					<td>
						<input v-model="xi" />
					</td>
					<td>{{xiTotal}}</td>
				</tr>
				<tr>
					<td>剪</td>
					<td>30</td>
					<td>
						<input v-model="jian" />
					</td>
					<td>{{jianTotal}}</td>
				</tr>
				<tr>
					<td>吹</td>
					<td>188</td>
					<td>
						<input v-model="chui" />
					</td>
					<td>{{chuiTotal}}</td>
				</tr>
				<tr>
					<td>总价</td>
					<td colspan="3">{{total}}</td>
				</tr>
			</table>
			
			<p>监听属性</p>
			千米:<input v-model="km"/>
			米:<input v-model="m"/>
		</div>
	</body>
	<script type="text/javascript">
		// 全局过滤器
		Vue.filter('all', function(value) {
				return value.substring(1,4);
		});
		
		// 局部过滤器
		
		/* 绑定边界 */
		new Vue({
			el: '#app',
			data() {
				return {
					xi:1,
					jian:1,
					chui:1,
					km:2,
					m:2000
				};
			},
			methods: {
				handle() {
					alert("触发事件");
				}
			},
			computed:{
				xiTotal(){
					return this.xi*30;
				},
				jianTotal(){
					return this.jian*30;
				},
				chuiTotal(){
					return this.chui*188;
				},
				total(){
					return this.xiTotal+this.jianTotal+this.chuiTotal;
				}
			},
			watch:{
				// m
				m: function(v){
					this.km= parseInt(v)/1000;
				},
				// km
				km: function(v){
					this.m= parseInt(v)*1000;
				}
			}
		})
	</script>
</html>

结果展示:

将千米改为20

?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-29 12:54:58  更:2021-10-29 12:55:57 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/1 14:21:41-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码