Code前端首页关于Code前端联系我们

Vue:点击事件onclick和@click区别

terry 1年前 (2024-03-25) 阅读数 370 #Vue
文章标签 onclick@click

聊聊Vue:点击事件onclick和@click区别。

一、直接上结论

  • onclick 只能触发 js的原生方法,不能触发vue的封装方法

  • @click 只能触发vue的封装方法,不能触发js的原生方法

二、验证代码,可直接运行

<!DOCTYPE html>
<html>
<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>探索onclick和@click的区别</title>
</head>
<body>
<!-- 主体区域 -->
<section id="app">
    <button onclick="jsMethod()">onclick使用js中的方法</button><br>
    <button @click="jsMethod()">@click使用js中的方法</button><br>
    <button onclick="vueMethod()">onclick使用vue中的方法</button><br>
    <button @click="vueMethod()">@click使用vue中的方法</button>
</section>
<!-- 底部 -->
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script>
    const app = new Vue({
        el: '#app',
        data: {
        },
        methods: {
            vueMethod() {
                console.log("您触发了vue内部方法!")
            }
        }
    })
    function jsMethod() {
        console.log("您触发了js方法!")
    }
</script>
</body>
</html>

三、点击结果

image.png

补充:

vue.js @click和v-on:click有什么区别?
没有区别,@ 只是一个 v-on: 的缩写,为了书写方便。

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

<!-- 完整语法 -->
<a v-bind:href="url" rel="external nofollow"  rel="external nofollow" ></a>
<!-- 缩写 -->
<a :href="url" rel="external nofollow"  rel="external nofollow" ></a>
v-on 缩写
<!-- 完整语法 -->
<a v-on:click="doSomething"></a>
<!-- 缩写 -->
<a @click="doSomething"></a>

版权声明

本文仅代表作者观点,不代表Code前端网立场。
本文系作者Code前端网发表,如需转载,请注明页面地址。

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

热门