随笔 - 750  文章 - 1  评论 - 107  阅读 - 34万

[转] VUE 的常用指令3

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="app">
      <input type="text" @keyup.enter="submit" @keyup.esc="clearInput" />
    </div>

<script src="./lib/vue-2.6.12.js"></script>
<script>
    const vm = new Vue({
        el:'#app',
        data:{},
        methods:{
            submit(e){
                console.log('检测到 Enter 键被按下,最新的值是:' + e.target.value)
            },
            clearInput(e){
                e.target.value=''
            }
        }
    })
</script>

</body>
</html>
复制代码

 

事件对象 event

事件不带 ()时,默认会传它所表示的对象

事件带参数后,要传它自己,可以使用 $event  来表示

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="app">
      <h3>count 的值为:{{ count }}</h3>

      <button @click="addCount($event,3)">+3</button>
    </div>

<script src="./lib/vue-2.6.12.js"></script>
<script>
    const vm = new Vue({
        el:'#app',
        data:{
            count: 0
        },
        methods:{
            addCount(e,step){
                const bg = e.target.style.backgroundColor
                e.target.style.backgroundColor = bg == 'red' ? '' : 'red'
                this.count += step
            }
        }
    })
</script>

</body>
</html>
复制代码

preventDefault() 或 stopPropagation() 阻止事件继续传递

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 注意: v-model 指令只能配合表单元素一起使用!

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="app">
      <p>用户名是:{{ username }}</p>
      <input type="text" v-model="username" />

      <p>选中的省份是:{{ province }}</p>
      <select v-model="province">
        <option value="">请选择</option>
        <option value="1">北京</option>
        <option value="2">河北</option>
        <option value="3">黑龙江</option>
      </select>
    </div>

<script src="./lib/vue-2.6.12.js"></script>
<script>
    const vm = new Vue({
        el:'#app',
        data:{
            username: 'zs',
            province: ''
        }
    })
</script>

</body>
</html>
复制代码

 

posted on   z5337  阅读(18)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示