欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue中v-on的指令以及一些其他指令

程序员文章站 2022-04-14 15:36:07
1.v-on的基本使用 我们在的的时侯v-on是可以缩写成@的,例如上边的可以缩写成:@:chick="btn"。 在Vue中,其他的事件都可以用v-on绑定 2.事件修饰符 在事件处理程序中调用 event.preventDefault() 或 event.stopPropagation() 是非 ......

1.v-on的基本使用

<div id="app">
    <!-- 使用事件绑定的简写形式 -->
    <input type="button" value="按钮" v-on:click="btn">
</div>
<script>
    var vm = new vue({
        el: '#app',
//methods是用来专门存放vue的处理方法的 methods: { btn: function () { alert('123'); } } }); </script>

   我们在的的时侯v-on是可以缩写成@的,例如上边的可以缩写成:@:chick="btn"。

   在vue中,其他的事件都可以用v-on绑定

2.事件修饰符

     在事件处理程序中调用 event.preventdefault() 或 event.stoppropagation() 是非常常见的需求。尽管我们可以在方法中轻松实现这点,但更好的方式是:方法只有纯粹的数据逻辑,而不是去处理 dom 事件细节。

为了解决这个问题,vue.js 为 v-on 提供了事件修饰符。之前提过,修饰符是由点开头的指令后缀来表示的。

   使用修饰符 阻止浏览器的默认行为

<div id="app">
    <a href="http://www.qq.com"  v-on:click.prevent="btn">腾讯</a>
</div>
<script>
    var vm = new vue({
        el: '#app',
        methods: {
            btn: function () {
                alert('123');
            }
        }
    });
</script>

  使用修饰符绑定一次性事件

<div id="app">
    <a href="http://www.qq.com" v-on:click.once="btn($event)">腾讯</a>
</div>
<script>
    var vm = new vue({
        el: '#app',
        methods: {
              btn: function (ev) {
                ev.preventdefault();
                alert('123');
            }
        }
    });
</script>

$event是原始的dom事件:有时也需要在内联语句处理器中访问原始的 dom 事件。可以用特殊变量 $event 把它传入方法:

   按键修饰符:绑定键盘抬起事件,但是只有enter 键能触发此事件

<div id="app">
    <input type="text"  v-on:keyup.enter="keyup">
</div>
<script>
    var vm = new vue({
        el: '#app',
        methods: {
            keyup:function(){
                console.log('111')
            }
        }
    });
</script>

   鼠标修饰符:鼠标左键触发事件

<div id="app">
    <input type="button" value="按钮" v-on:click.left="btn">
</div>
<script>
    var vm = new vue({
        el: '#app',
        methods: {
           btn:()=>{
                console.log('111')
            }
        }
    });
</script>

为什么在 html 中监听事件?

   你可能注意到这种事件监听的方式违背了关注点分离 (separation of concern) 这个长期以来的优良传统。但不必担心,因为所有的 vue.js 事件处理方法和表达式都严格绑定在当前视图的 viewmodel 上,它不会导致任何维护上的困难。实际上,使用 v-on 有几个好处:

  1. 扫一眼 html 模板便能轻松定位在 javascript 代码里对应的方法。

  2. 因为你无须在 javascript 里手动绑定事件,你的 viewmodel 代码可以是非常纯粹的逻辑,和 dom 完全解耦,更易于测试。

         3.当一个 viewmodel 被销毁时,所有的事件处理器都会自动被删除。你无须担心如何清理它们。 

3.v-show的指令:

 

<body>
    <div id="app">
        <input type="button" value="按钮" v-on:click="change">
        <p v-show="is_show">秀儿,是你吗</p>
    </div>
</body>
<script>
    var app = new vue({
        el: '#app',
        data: {
            is_show: false,
        },
        methods: {
            change: function () {
                this.is_show = !this.is_show;
            }
        }
    });

</script>

 

4.v-if的指令:

<body>
    <div id="app">
        <input type="text"  id="" v-model="type">
        <div v-if="type === 'a'">我是a</div>
        <div v-else-if="type === 'b'">我是b</div>
        <div v-else-if="type === 'c'">我是c</div>
        <div v-else-if="type === 'd'">我是d</div>
        <div v-else>我什么也不是</div>
    </div>
</body>
<script>
    var app = new vue({
        el:'#app',
        data:{
            type:''
        }
    });

</script>

5.v-for的指令:

<body>
    <div id="app">
        <!-- 数组 -->
        <ul>
            <!-- v-for 循环的语法规则可以参考 js 的 for in 循环 -->
            <li v-for="(v,key) in arr">{{v}}---{{key}}</li>
        </ul>
        <!-- 对象 -->
        <ul>
            <li v-for="(v,k) in oop">{{v}}----{{k}}</li>
        </ul>

    </div>
</body>
<script>
    // for(cc in arr)
    var app = new vue({
        el:'#app',
        data:{
            arr:['ff','hh','jj','gg','ll'],

            oop:{name:'张三',age:30,sex:'男'}
        }
    });
</script>

6.v-once:的指令:

<body>
    <div id="app">
        <!-- 只渲染一次数据 不再是数据单项绑定  这是单次绑定 -->
        <p v-once>{{msg}}</p>
    </div>
</body>
<script>
    var app = new vue({
        el:'#app',
        data:{
            msg:'123'
        }
    });

</script>