【Vue入门】语法 —— 插值、指令、过滤器、计算属性、监听器

目录

一、模版语法

1.1 插值

1.1.1 文本

1.1.2 html解析

1.1.3 属性

1.1.4 表达式

1.2 指令

1.2.1 核心指令

1.2.3 动态参数

二、过滤器

2.1 局部过滤器

2.2 全局过滤器

三、计算属性

四、监听器

五、排座案例

小结:计算属性和监听属性的区别


一、模版语法

1.1 插值

        Vue.js 使用了基于 HTML 的模板语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据。所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器和 HTML 解析器解析。vue将模板编译成虚拟dom,结合响应系统,Vue 能够智能地计算出最少需要重新渲染多少组件,并把 DOM 操作次数减到最少。

html模板语法: 这是一种基于字符串的模板技术,以字符串和数据为输入,通过用正则表达式将占位符替换为所需数据的方式,构建出完整的 HTML 字符串。

1.1.1 文本

        直接使用{{xxx}}的形式,标签将会被替换成为数据对象(data)上xxx属性值,当绑定的数据对象上的xxx属性值发生变化时,插值处的值也会发生变化(双向绑定

<div id="xw">
       {{msg}}
</div>

1.1.2 html解析

如果要输出html格式的数据,需要使用v-html指令。

<!DOCTYPE html>
<html><head><meta charset="utf-8" /><title>html解析</title><!-- 1.导入工具 --><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script><script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script></head><body><!-- 2.定义边界 --><div id="xw"><div v-html="htmlstr"></div></div><!-- 3.构建vue实例并绑定边界 --><script>new Vue({el: "#xw",data() {return {htmlstr: '<h3 style="color:blue;">这是一个html片段</h3>'}}})</script></body>
</html>

1.1.3 属性

HTML属性中的值应使用v-bind指令。类型与jQuery中的$("#xxx").attr(Name,Val)

<!DOCTYPE html>
<html><head><meta charset="utf-8" /><title>html解析</title><!-- 1.导入工具 --><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.10/vue.js"></script><script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.7.1/jquery.min.js"></script><style>.blueClass{font-size: 30px;color: skyblue;}</style></head><body><!-- 2.定义边界 --><div id="xw"><p v-bind:class="hontColor">哈哈</p></div><!-- 3.构建vue实例并绑定边界 --><script>new Vue({el: "#xw",data() {return {hontColor:"blueClass",}}})</script></body>
</html>

也可以这样写:

//在html使用v-bind:style指令设置样式
<p v-bind:style="color">哈哈</p>
data() {return {//定义一个属性,其值为所需样式color:"color: yellowgreen;"}
}

1.1.4 表达式

 Vue提供了完全的JavaScript表达式支持:

  • {{str.substr(0,3)}}
  • {{ number + 1 }}
  • {{ ok ? 'YES' : 'NO' }}
  • <li v-bind:id="'list-' + id">我的Id是js动态生成的</li>

示例1:字符截取

<!-- 在html中加入元素,定义表达式 -->
<p>{{str.substring(5,9)}}</p>
data() {return {str: '大家都叫我king'}
}

示例二:很简单就不一一演示了

<p>数字:{{number+1}}</p>
<p>{{ok ? 'yes' : 'no'}}</p>
<span :id="'users_id_'+id">小威</span>
new Vue({el: "#xw",data() {return {number: 99,ok: false,id: 66}}})

1.2 指令

1.2.1 核心指令

 v-if|v-else|v-else-if :根据其后表达式的bool值进行判断是否渲染该元素

 v-show:与v-if类似,只是会渲染其身后表达式为false的元素,而且会给这样的元素添加css代码:style="display:none"

 v-for:类似JS的遍历

 v-bind:在上面已用到,添加属性或元素

 v-on:v-on:(也可以用@替代),在上篇已讲述过,用来调用函数。

 v-model:用来自动更新绑定的元素的值  

示例1:

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>核心指令</title><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw">分数:<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: '#xw',data() {return {score: 60}}})</script></html>

示例二:

<div v-show="score==90">v-show-上优秀学员名单</div>

示例3:

结合v-model实现下拉框和复选框

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>核心指令</title><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw"><p>v-for</p><select v-model="hobbySelected"><option v-for="h in hobby" :value="h.id">{{h.name}}</option></select><div v-for="h in hobby"><input :value="h.id" type="checkbox" />{{h.name}}</div></div></body><script type="text/javascript">new Vue({el: '#xw',data() {return {hobby: [{id: "1",name: "beautifulgirl"},{id: "2",name: "按摩"},{id: "3",name: "洗jio"}],hobbySelected: 3};}})</script></html>

示例4:

<!--参数:href-->
<div><a v-bind:href="url">baidu</a>
</div><!--
参数:动态参数.
attname需要在data中定义,
注意:attname要全部小写!!
-->
<div><a v-bind:[attrname]="url">baidu</a><button v-on:[evname]="clickme">点我看看</button>
</div>

1.2.3 动态参数

注意:在动态参数中,作为参数的变量名(如:attrname)要全部小写,否则无效 !!

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>动态参数</title><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw"><p>动态参数</p><input v-model="evname" /><button v-on:[evname]="handle">动态参数</button></div></body><script type="text/javascript">new Vue({el: '#xw',data() {return {evname:'dblclick'}methods: {handle() {alert("触发事件");}}})</script>
</html>

Vue为v-bind和v-on这两个最常用的指令,提供了特定简写

指令简写示例
v-bind:xxx:xxxv-bind:href 简写为 :href
v-on:xxx@xxxv-on:click 简写为 @click

二、过滤器

        vue允许自定义过滤器,一般用于常见的文本格式化,过滤器可用的两个地方:双花括号插值v-bind表达式,过滤器应该被添加在js表达式的尾部,使用管道运算符 " | "

2.1 局部过滤器

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>过滤器</title><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw">{{msg}}<br />{{msg|single}}<br />{{msg|param(2,3)}}</div><script type="text/javascript">// 绑定边界	ES6具体体现new Vue({el: '#xw',data() {return {msg: "bug快离开~bug快离开~"};},filters: {'single': function(val) {return val.substring(2, 3);},'param': function(val, start, end) {return val.substring(start, end);}}})</script></body>
</html>

注1:过滤器函数接受表达式的值作为第一个参数 
注2:过滤器可以串联     
        {{ message | filterA | filterB }}
注3:过滤器是JavaScript函数,因此可以接受参数: 
        {{ message | filterA('arg1', arg2) }} 

2.2 全局过滤器

时间转换案例: 

//给Date类添加了一个新的实例方法format
Date.prototype.format = function (fmt) {//debugger;var o = {"M+": this.getMonth() + 1,                 //月份"d+": this.getDate(),                    //日"h+": this.getHours(),                   //小时"m+": this.getMinutes(),                 //分"s+": this.getSeconds(),                 //秒"q+": Math.floor((this.getMonth() + 3) / 3), //季度"S": this.getMilliseconds()             //毫秒};if (/(y+)/.test(fmt))fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));for (var k in o)if (new RegExp("(" + k + ")").test(fmt))fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));return fmt;
};function fmtDate(date, pattern) {var ts = date.getTime();var d = new Date(ts).format("yyyy-MM-dd hh:mm:ss");if (pattern) {d = new Date(ts).format(pattern);}return d.toLocaleString();
};

拷入date.js(日期格式化)放入项目js目录中,在页面中引入。
定义全局过滤器 

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>过滤器</title><script src="js/date.js"></script><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw"><p>{{date | fmtDate}}</p>无过滤器:<br />{{date}}</div><script type="text/javascript">// 全局过滤器Vue.filter('fmtDate', function(value) {return fmtDate(value, 'yyyy年MM月dd日')});// 绑定边界	ES6具体体现new Vue({el: '#xw',data() {return {date: new Date()};}})</script></body>
</html>

三、计算属性

   计算属性可用于快速计算视图(View)中显示的属性。这些计算将被缓存,并且只在需要时更新。

使用场景:当一个属性需要复杂的逻辑运算之后才能获取其值,可以使用计算属性,在一个计算属性中可以完成各种复杂的逻辑,包括运算,方法调用等,只要最终返回一个结果就可以了


语法:computed:{}

购物车案例:

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>计算属性</title><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw"><p>计算属性</p><table border="1" style="width: 600px;height: 300px;"><tr><td>物品</td><td>单价</td><td>数量</td><td>小计</td></tr><tr><td>帽子</td><td>{{maoziDanjia}}</td><td><input v-model="maozi" /></td><td>{{maoziTotal}}</td></tr><tr><td>衣服</td><td>{{yifuDanjia}}</td><td><input v-model="yifu" /></td><td>{{yifuTotal}}</td></tr><tr><td>裤子</td><td>{{kuziDanjia}}</td><td><input v-model="kuzi" /></td><td>{{kuziTotal}}</td></tr><tr><td>总价</td><td colspan="3">{{total}}</td></tr></table></div></body><script type="text/javascript">// 绑定边界	ES6具体体现new Vue({el: '#xw',data() {//定义所需属性值return {maoziDanjia: 10,yifuDanjia: 30,kuziDanjia: 20,maozi: 1,yifu: 1,kuzi: 1,km: 2,m: 2000};},computed: {maoziTotal() {return this.maoziDanjia * this.maozi;},yifuTotal() {return this.yifuDanjia * this.yifu;},kuziTotal() {return this.kuziDanjia * this.kuzi;},total() {return this.maoziTotal + this.yifuTotal + this.kuziTotal;}}})</script>
</html>

四、监听器

监听属性 watch,我们可以通过 watch 来响应数据的变化
   

语法:watch:{}

示例: 米和厘米的单位换算

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>计算属性</title><script src="js/vue&jquery.js"></script></head><body><!-- 定义边界 --><div id="xw"><p>监听属性</p>米:<input v-model="m" />厘米:<input v-model="cm" /></div></body><script type="text/javascript">// 绑定边界	ES6具体体现new Vue({el: '#xw',data() {return {m: 2,cm: 200};},watch: {// v指的是m变量m: function(v) {this.cm = parseInt(v) * 100;},// v指的是km变量cm: function(v) {this.m = parseInt(v) / 100;}}})</script>
</html>

五、排座案例

<!DOCTYPE html>
<html><head><title>排座</title><script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script></head><body><div id="app"><h2>排座</h2><input type="text" v-model="seatInput1"><input type="text" v-model="seatInput2"><input type="text" v-model="seatInput3"><hr><h3>用户:</h3><ul><!-- 遍历过滤器传来的值 --><li v-for="user in filteredUsers" :key="user.id">{{ user.name }}</li></ul><hr></div><script>new Vue({el: '#app',data: {seatInput1: '',seatInput2: '',seatInput3: '',users: [{id: 1,name: '老王'},{id: 2,name: '老六'},{id: 3,name: '老八'},{id: 4,name: '老聂'},{id: 5,name: '老五'}]},/* 定义一个filteredUsers计算属性 */computed: {/* 使用filter方法来过滤users数组中的元素。filter方法接受一个回调函数作为参数,该回调函数会对数组中的每个元素进行判断,并返回一个新的数组,其中包含满足条件的元素。 */filteredUsers() {return this.users.filter(/* 使用=>箭头函数的语法来定义一个匿名函数。这个匿名函数接受一个参数user,表示users数组中的每个元素。 */user => {/* 使用逻辑运算符&&来判断user.name是否不等于seatInput1、seatInput2和seatInput3的值。如果满足这个条件,说明user.name不等于任何一个输入框的值,那么这个元素就会被保留在过滤后的数组中。 */return user.name !== this.seatInput1 &&user.name !== this.seatInput2 &&user.name !== this.seatInput3});}}});</script></body>
</html>

小结:计算属性和监听属性的区别

计算属性:是一种依赖于其他属性计算得出的属性。它的值是根据其依赖的属性动态计算而来的,并且会进行缓存,只有在依赖的属性发生变化时才会重新计算。计算属性适用于需要根据其他属性进行复杂计算或处理的场景。通过使用计算属性,可以将复杂的逻辑封装起来,使代码更加清晰和可维护。

监听属性:是一种用于监听指定属性变化并执行相应操作的属性。当监听的属性发生变化时,可以执行指定的回调函数来响应变化。监听属性适用于需要在属性变化时执行异步或开销较大的操作的场景。通过使用监听属性,可以实时监测属性的变化并执行相应的操作,例如发送网络请求或执行复杂的计算。

        计算属性适用于根据其他属性进行计算得出结果的场景,而监听属性适用于需要实时监测属性变化并执行相应操作的场景。两者的区别在于计算属性是根据其他属性进行计算得出结果,而监听属性是在属性变化时执行相应操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/136040.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

怎么防止360安全卫士修改默认浏览器?

默认的浏览器 原先选项是360极速浏览器&#xff08;如果有安装的话&#xff09;&#xff0c;我这里改成了Chrome。 先解锁 才能修改。

今年嵌入式行情怎么样?

今年嵌入式行情怎么样&#xff1f; 嵌入式技术今年可以说是IT领域中最炙手可热的之一。随着中年危机和内卷问题的出现&#xff0c;越来越多的互联网从业者将目光投向了嵌入式领域。国内的嵌入式市场一直受终端需求变化的影响而波动&#xff0c;但随着国内产业自主化的发展趋势…

uniapp 小程序 父组件调用子组件方法

答案&#xff1a;配合小程序API > this.selectComponent("")&#xff0c;来选择组件&#xff0c;再使用$vm选择组件实例&#xff0c;再调用方法&#xff0c;或者data 1 设置组件的id,如果你的多端&#xff0c;请跟据情况设置ref,class,id&#xff0c;以便通过小…

9.18号作业

完善登录框 点击登录按钮后&#xff0c;判断账号&#xff08;admin&#xff09;和密码&#xff08;123456&#xff09;是否一致&#xff0c;如果匹配失败&#xff0c;则弹出错误对话框&#xff0c;文本内容“账号密码不匹配&#xff0c;是否重新登录”&#xff0c;给定两个按钮…

如何将 JavaScript Excel XLSX 查看器添加到Web应用程序

在 JavaScript 中创建 Excel 查看器可能是一项艰巨的任务&#xff0c;但使用 SpreadJS JavaScript 电子表格&#xff0c;创建过程要简单得多。在本教程博客中&#xff0c;我们将向您展示如何使用 SpreadJS 的强大功能来创建一个查看器&#xff0c;该查看器允许您在 Web 浏览器中…

with ldid... /opt/MonkeyDev/bin/md: line 326: ldid: command not found

吐槽傻逼xcode 根据提示 执行了这个脚本/opt/MonkeyDev/bin/md 往这里面添加你brew install 安装文件的目录即可

【实验】H3C校园双出口配置案例,可跟做!

【微|信|公|众|号&#xff1a;厦门微思网络】 1.案例拓补 该拓扑图中的校园网内部分为两个网段&#xff1a;一个为学生校舍网段&#xff08;192.168.2.0&#xff09;&#xff0c;主要访问电信提供的internet服务器&#xff1b;另外一个网段为校园办公和教学用网段&#xff08;…

操作系统的体系结构

一、内核结构 操作系统内核也有两种类别&#xff1a;大内核结构、微内核结构 大内核结构&#xff1a;也叫宏内核/单内核。将操作系统的主要功能模块都作为操作系统内核。大内核结构包括进程管理、存储器管理、设备管理等功能&#xff08;第四层&#xff09;和时钟管理、中断处理…

爬虫工作者必备:使用爬虫ip轻松获得最强辅助

在进行网络数据爬取时&#xff0c;爬虫ip成为了爬虫工作者们的得力辅助。通过使用爬虫ip&#xff0c;可以实现IP地址的伪装和分布式请求&#xff0c;有效规避访问限制和提高爬取效率。本文将为爬虫工作者们分享关于使用爬虫ip的知识&#xff0c;帮助您轻松获取最强辅助&#xf…

【SpringMVC】基于 Spring 的 Web 层MVC 框架

&#x1f384;欢迎来到边境矢梦的csdn博文&#x1f384; &#x1f384;本文主要梳理SpringMVC : 基于 Spring 的 Web 层MVC 框架 &#x1f384; &#x1f308;我是边境矢梦&#xff0c;一个正在为秋招和算法竞赛做准备的学生&#x1f308; &#x1f386;喜欢的朋友可以关注一下…

VMware workstation 中centos7虚拟机在nat模式下怎么配置网卡,指定我想要的IP并且可以联网

1、首先打开我们的虚拟网络编辑器 2、查看我们的网关 3、查看IP池&#xff0c;根据需求自己设置 4、打开centos7虚拟机 编辑网卡配置 vim /etc/sysconfig/network-scripts/ifcfg-ens160####我的网卡是ens160TYPEEthernet PROXY_METHODnone BROWSER_ONLYno BOOTPROTOstatic …

「聊设计模式」之原型模式(Prototype)

&#x1f3c6;本文收录于《聊设计模式》专栏&#xff0c;专门攻坚指数级提升&#xff0c;助你一臂之力&#xff0c;带你早日登顶&#x1f680;&#xff0c;欢迎持续关注&&收藏&&订阅&#xff01; 前言 设计模式是软件开发中经过长期实践总结的经验和规范&#…

git 查看当前版本号

你看&#xff0c;那个人好像一条狗哎。 ——周星驰 《大话西游》 要查看当前 Git 仓库的版本号&#xff0c;您可以使用以下命令&#xff1a; git log --oneline -n 1 这会显示最近一次的提交信息&#xff0c;包括提交的哈希值&#xff08;版本号&#xff09;和提交的摘要信息…

微服务保护-流量控制

流量控制 雪崩问题虽然有四种方案&#xff0c;但是限流是避免服务因突发的流量而发生故障&#xff0c;是对微服务雪崩问题的预防。我们先学习这种模式 簇点链路 当请求进入微服务时&#xff0c;首先会访问DispatcherServlet&#xff0c;然后进入Controller、Service、Mapper&…

vue基础知识十三:Vue中的$nextTick有什么作用?

一、NextTick是什么 官方对其的定义 在下次 DOM 更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法&#xff0c;获取更新后的 DOM 什么意思呢&#xff1f; 我们可以理解成&#xff0c;Vue 在更新 DOM 时是异步执行的。当数据发生变化&#xff0c;Vue将开启一个异…

神经网络 01(介绍)

一、神经网络 人工神经网络 (Artificial Neural Network&#xff0c;简写为ANN)也简称为神经网络 (NN)&#xff0c;是一种模仿生物神经网络结构和功能的 计算模型。人脑可以看做是一个生物神经网络&#xff0c;由众多的神经元连接而成。各个神经元传递复杂的电信号&#xff0c…

HTTP代理与VPN:网络代理技术的比较

HTTP代理和VPN是两种常见的网络代理技术&#xff0c;它们可以帮助用户隐藏自己的IP地址、保护网络隐私、绕过网络限制等。本文将介绍HTTP代理和VPN的定义、工作原理、优缺点以及使用场景。 一、HTTP代理 HTTP代理是一种通过代理服务器转发网络请求的技术。当用户发起网络请求时…

C++ - map 和 set的 例题

前言 本博客在 一下文章关于 map 和 set 讲解之下&#xff0c;对 map 当中的 operator[] &#xff08;&#xff09;函数的功能运用&#xff0c;感受 map 功能强大。 349. 两个数组的交集 - 力扣&#xff08;LeetCode&#xff09; 给定两个数组 nums1 和 nums2 &#xff0c;返回…

CG MAGIC分享3ds Max卡顿未保存处理方法有哪些?

3ds Max进行建模、渲染这一系列过程中&#xff0c;大家使用中都会遇到各种原因导致软件卡顿或崩溃是很常见的情况。 可以说卡机没关系&#xff0c;可是卡顿发生时&#xff0c;如果之前的工作没有及时保存&#xff0c;可能会导致数据的丢失和时间的浪费。这就是最让人烦躁的了&…

Linux基本指令

本片文章只讲述Linux的一些基本指令&#xff0c;让你简单上手Liunx&#xff01; 目录 &#x1f351;ls : 显示当前目录下的文件列表 -a &#xff1a;列出目录下的所有文件&#xff0c;包括以 . 开头的隐含文件​编辑 -l &#xff1a;显示文件的详细信息​编辑 &#x1f3…