vue 提示没有方法,但是vue methods data已经写了?咋回事

Sponsered by
你可以使用 v-on 指令来绑定并监听 DOM 事件。绑定的内容可以是一个当前实例上的方法 (后面无需跟括号) 或一个内联表达式。如果提供的是一个方法,则原生的 DOM event 会被作为第一个参数传入,同时这个 event 会带有 targetVM 属性,指向触发该事件的相应的 ViewModel:
&div id="demo"&
&a v-on="click: onClick"&触发一个方法函数&/a&
&a v-on="click: n++"&触发一个表达式&/a&
el: '#demo',
methods: {
onClick: function (e) {
console.log(e.target.tagName) // "A"
console.log(e.targetVM === this) // true
执行表达式
当在 v-repeat 里使用 v-on 时,targetVM 显得很有用,因为 v-repeat 会创建大量子 ViewModel。但是,通过执行表达式的方式,把代表当前 ViewModel 数据对象的别名传进去,会更方便直观一些:
&ul id="list"&
&li v-repeat="item in items" v-on="click: toggle(item)"&
{{item.text}}
el: '#list',
{ text: 'one', done: true },
{ text: 'two', done: false }
methods: {
toggle: function (item) {
item.done = !item.done
当你想要在表达式中访问原来的 DOM event,你可以传递一个 $event 参数进去:
&button v-on="click: submit('hello!', $event)"&Submit&/button&
methods: {
submit: function (msg, e) {
e.stopPropagation()
key 过滤器
当监听键盘事件时,我们常常需要判断常用的 key code。Vue.js 提供了一个特殊的只能用在 v-on 指令的过滤器:key。它接收一个表示 key code 的参数并完成判断:
&!-- 只有当 keyCode 等于 13 时才调用方法 --&
&input v-on="keyup:submit | key 13"&
它也预置了一些常用的按键名:
&!-- 效果同上 --&
&input v-on="keyup:submit | key 'enter'"&
查看 API 参考:key 过滤器的全部预设参数。
为什么要在 HTML 中写监听器?
你可能会注意到整个事件监听的方式违背了 “separation of concern” 的传统理念。不必担心,因为所有的 Vue.js 时间处理方法和表达式都严格绑定在当前视图的 ViewModel 上,它不会导致任何维护困难。实际上,使用 v-on 还有更多好处:
它便于在 HTML 模板中轻松定位 JS 代码里的对应方法实现。
因为你无须在 JS 里手动绑定事件,你的 ViewModel 代码可以是非常纯粹的逻辑,和 DOM 完全解耦。这会更易于测试。
当一个 ViewModel 被销毁时,所有的事件监听都会被自动移除。你无须担心如何自行清理它们。
下一步:。更多公众号:ucaicn优才网(),全网唯一一个提供全栈工程师培训的在线教育网站,本账号旨在发布最新全栈工程师课程信息和免费公开课信息,分享精彩技术文章,推荐靠谱高薪工作,欢迎关注。最新文章相关推荐搜狗:感谢您阅读vue.js快速入门,本文可能来自网络,如果侵犯了您的相关权益,请联系管理员。QQ:methods中的划方法划互相调用时变量的作用域是怎样的,vue。js_珍藏百科
methods中的划方法划互相调用时变量的作用域是怎样的,vue。js
编辑: &&&来源:用户发布&&&发布时间:&&&查看次数:46
methods中的划方法划互相调用时变量的作用域是怎样的,vue。js
不太知道化你在说什么...
作用域:它是指对某一变量和方法具有访问权限的代码空间,在JS中,作用域是在函数中维护的。表示变量或函数起作用的区域,指代了它们在怎么样的化上下文中执行,亦即上下文执行环境。Javascript的作用域只有两种:全局作用域和本地作用域,本地作用域是按照函数来区分的。闭包:在js中的我的理解就是函数嵌套函数,当内部函数在定义它的作用域的外部被引用时,就创建了该内部函数的闭包,如果内部函数引用了位于外部函数的变量,这些变量在内存不会被释放,当外部函数调用完毕后,因为闭包需要它们.使用闭包要注意:1)由于闭包会使得函数中的变量都被保存在内存中,所以不能滥用闭包,内存消耗很大,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。2)闭...1)由于闭包会使得函数中的变量都被保存在内存中。解决方法是,指代了它们在怎么样的化上下文中执行.使用闭包要注意,当内部函数在定义它的作用域的外部被引用时,不要随便改变父函数内部变量的值。Javascript的作用域只有两种,亦即上下文执行环境,这时一定要小心:它是指对某一变量和方法具有访问权限的代码空间,如果内部函数引用了位于外部函数的变量,将不使用的局部变量全部删除,本地作用域是按照函数来区分的。闭包:在js中的我的理解就是函数嵌套函数,内存消耗很大,就创建了该内部函数的闭包,把内部变量当作它的私有属性(privatevalue),这些变量在内存不会被释放,在JS中,把闭包当作它的公用方法(PublicMethod),因为闭包需要它们,作用域是在函数中维护的,否则会造成网页的性能问题,在IE中可能导致内存泄露,如果你把父函数当作对象(object)使用。表示变量或函数起作用的区域。所以。2)闭包会在父函数外部,改变父函数内部变量的值,在退出函数之前:全局作用域和本地作用域,所以不能滥用闭包,当外部函数调用完毕后作用域
电脑数码相关
本文相关文章
- 关于我们 - 版权声明-
广告服务 - 友情链接 - 管理登录 -
Copyright &
All Rights Reserved
如有任何侵权、造谣信息请将网页地址和有法律效力的侵权造谣证明或判决书发往QQ:小时内删除。
苏ICP备号-1&}

我要回帖

更多关于 vue computed methods 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信