问题应该足够清楚。

但我可以看到有人用:

<button @click="function()">press</button>

有人使用:

<button v-on:click="function()">press</button>

但这两者之间究竟有什么区别(如果存在的话)?


当前回答

它们看起来可能与普通的HTML有点不同,但是:和@是属性名的有效字符,所有Vue.js支持的浏览器都可以正确解析它。此外,它们不会出现在最终呈现的标记中。简写语法完全是可选的,但是当您以后学习更多关于它的用法时,您可能会喜欢它。

资料来源:官方文件。

其他回答

V-bind和v-on是vuejs HTML模板中常用的两个指令。 所以他们提供了一个简单的符号来表示它们,如下:

你可以用@替换v-on:

v-on:click='someFunction'

as:

@click='someFunction'

另一个例子:

v-on:keyup='someKeyUpFunction'

as:

@keyup='someKeyUpFunction'

类似地,v-bind with:

v-bind:href='var1'

可以写成:

:href='var1'

两者之间没有区别,前者只是后者的简称。

v-前缀作为识别vue特定的视觉提示 属性。这在你使用Vue.js时很有用 将动态行为应用于一些现有的标记,但可以感觉到 一些常用指令的详细描述。与此同时, 当您正在构建一个 Vue.js管理每个模板的SPA。

<!-- full syntax -->
<a v-on:click="doSomething"></a>
<!-- shorthand -->
<a @click="doSomething"></a>

资料来源:官方文件。

官方来源

Vue.js的官方风格指南建议坚持使用一个版本并保持一致。

指令简写(:用于v-bind:, @用于v-on:和#用于v-slot)应该总是使用或永远不使用。

该规则在“强烈推荐”部分中定义。


它可以通过eslint-plugin-vue plugin和设置vue/v-on-style规则在eslint中强制执行。

默认设置为速记。

{
  "vue/v-on-style": ["error", "shorthand" | "longform"]
}

例子

<template>
  <!-- ✓ GOOD -->
  <div @click="foo"/>

  <!-- ✗ BAD -->
  <div v-on:click="foo"/>
</template>

它们看起来可能与普通的HTML有点不同,但是:和@是属性名的有效字符,所有Vue.js支持的浏览器都可以正确解析它。此外,它们不会出现在最终呈现的标记中。简写语法完全是可选的,但是当您以后学习更多关于它的用法时,您可能会喜欢它。

资料来源:官方文件。