你可以使用 v-on 指令来绑定并监听 DOM 事件。绑定的内容可以是一个当前实例上的方法 (后面无需跟括号) 或一个内联表达式。如果提供的是一个方法,则原生的 DOM event 会被作为第一个参数传入,同时这个 event 会带有 targetVM 属性,指向触发该事件的相应的 viewmodel:
你可以使用 v-on 指令来绑定并监听 DOM 事件。绑定的内容可以是一个当前实例上的方法 (后面无需跟括号) 或一个内联表达式。如果提供的是一个方法,则原生的 DOM event 会被作为第一个参数传入,同时这个 event 会带有 targetVM 属性,指向触发该事件的相应的 viewmodel:
当在 v-repeat 里使用 v-on 时,targetVM 显得很有用,因为 v-repeat 会创建大量子 viewmodel。但是,通过执行表达式的方式,把代表当前 viewmodel 数据对象的别名传进去,会更方便直观一些:
当你想要在表达式中访问原来的 DOM event,你可以传递一个 $event 参数进去。
系统有很多预设值可以使用,例如:
预设值为:
它便于在 HTML 模板中轻松定位 JS 代码里的对应方法实现。 因为你无须在 JS 里手动绑定事件,你的 viewmodel 代码可以是非常纯粹的逻辑,和 DOM 完全解耦。这会更易于测试。 当一个 viewmodel 被销毁时,所有的事件监听都会被自动移除。你无须担心如何自行清理它们。
本文已被整理到了《》,欢迎大家学习阅读。