文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

vue中怎么同时监听多个参数

2023-06-29 23:05

关注

这篇文章主要讲解了“vue中怎么同时监听多个参数”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue中怎么同时监听多个参数”吧!

如何同时监听多个参数

vue使用watch同时监听多个参数,其中有任意一个参数发生改变时,都会被监听到需要使用到计算属性computed与监听watch

data中定义一个对象

data(){    return{        obj:{            name:'xpf',            gender:'male',            age:24    }    }}
computed:{    'newParams':function(){        const {name,age} = this.obj        return {name,age}    }    },
watch:{    newParams:function(){        alert(1)    }},

完整代码

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>watch同时监听多个属性</title>    <script src="https://cdn.bootcss.com/vue/2.6.10/vue.js"></script></head><body>    <div id="app">        <div @click="changeObj">点我</div>    </div>        <script>        new Vue({            el:'#app',            data(){                return{                    obj:{                        name:'xpf',                        gender:'male',                        age:24                    }                }            },            computed:{                'newParams':function(){                    const {name,age} = this.obj                    return {name,age}                }                },            watch:{                newParams:function(){                    alert(1)                }            },            methods:{                changeObj(){                    // this.obj.name = 'xx'                    this.obj.age = 21                }            }        })    </script></body></html>

vue事件监听,条件判断

事件监听 v-on

语法糖@

1. 基本的使用法法

    <div id="add">        点击次数{{counter}}         <button @click = "add">+</button> <!--v-on:click = "" 语法糖  -->        <button @click = "dec">-</button>    </div>
    <script src="../js/vue.js"></script>    <script>        const add = new Vue({            el:'#add',            data:{                counter:0            },            methods:{                add:function(){                    console.log('添加了');                    this.counter++                },                dec:function(){                    console.log('减少了');                    this.counter--                }            }        })      </script>

2. 事件监听带参数的使用方法

不带参数,写函数时,小括号可写可不写

<button @click = "one">按钮1</button><button @click = "one()">按钮2</button>

带有参数时,写函数时,小括号要写,传进的参数也要写

<button @click = "two">按钮2</button> <!-- 默认输出 浏览器生产的event事件对象 --><button @click = "two()">按钮3</button> <!-- 输出 undefind --><button @click = "two(123)">按钮4</button>  <!-- 输出 123  -->

即带参数有带event

<button @click = "three(123,$event) ">按钮5</button>

在小括号里添加$event可即添加参数又添加event事假

3.事件对象的修饰符

.stop  相当于事件对象的stopPropagaton,阻止冒泡事件

 <div @click = "one">父亲      <button @click.stop = "two">儿子</button>    </div>

.prevent 阻止默认事件 preventDefault

<a href="https://www.baidu.com/" rel="external nofollow"  @click.prevent = "two">百度一下</a>

keyup 监听某个键盘键帽

.enter 只监听回车键

<input type="text" @keyup= "two"><input type="text" @keyup.enter = "two">

.once只监听一次

<button @click.once = "two">按钮</button>

条件判断

1.v-if的基本使用

 <div id="add">    <div v-if = "true">{{message}}</div>    <div v-if = "false">{{name}}</div>     <div v-if = "isShow">      <h3>ccc</h3>      <h3>ccc</h3>      <h3>ccc</h3>      <h3>ccc</h3>    </div>

为true显示,为false隐藏,可设置一个变量isShow来控制

2.v-if和v-else使用

 <div id="add">    <h3 v-if = "isShow">我是你爸爸</h3>    <h3 v-else>不,我才是你爸爸</h3>  </div>

两者只能显示一个当变量isShow为true时,else隐藏,同理相反

3.v-if和v-else-if和v-lese使用

<h3 v-if = "message >=90"> 优秀 </h3> <h3 v-else-if = "message >=80"> 良好 </h3> <h3 v-else-if = "message >=70"> 及格 </h3> <h3 v-else> 不及格 </h3>

3个结合可读性差,不建议

可在computed里封装一个函数

 computed: {        result(){          let num = " "          if (this.message >=90) {            num = '优秀'          }else if(this.message >= 80){            num = '良好'          }else{            num = "不及格"          }          return num        }      }

在调用,可读性较好 

感谢各位的阅读,以上就是“vue中怎么同时监听多个参数”的内容了,经过本文的学习后,相信大家对vue中怎么同时监听多个参数这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯