vue中绑定事件的方式
v-on:原生事件名 的方式绑定事件
data:image/s3,"s3://crabby-images/b417d/b417d9674118a1d812776298de77db0800489d78" alt=""
data:image/s3,"s3://crabby-images/313ca/313ca7553077fedd38d6d679a7ad83736dc43a70" alt=""
运行结果
点击按钮后出现如下
data:image/s3,"s3://crabby-images/96cc3/96cc327d83de77c928eb1f562676327622bc5468" alt=""
下面@click的方式是v-on:事件名的简写方式
v-on:click=""
双引号里面是一个函数写法
data:image/s3,"s3://crabby-images/105a7/105a7b6e8e2e99ed661220bfe0005c14167710aa" alt=""
data:image/s3,"s3://crabby-images/c44d7/c44d7c1931615d05c487597080ada17be846ec6b" alt=""
调用时候可以直接写上test vue会自动判断test为一个函数然后执行这个函数
也可以写上test()
如下
data:image/s3,"s3://crabby-images/5dcc2/5dcc23df169ec6c7d80f2302cda32af9220319c3" alt=""
运行结果
data:image/s3,"s3://crabby-images/984da/984da2db498a6f4381644ba9006b8c91ca2b23e7" alt=""
还可以箭头函数传参数
data:image/s3,"s3://crabby-images/e9d9b/e9d9b24aa4f5e9a85ec786a99f4f070e336f5d6e" alt=""
data:image/s3,"s3://crabby-images/6056e/6056e757777f51dafdf8e9b89315ed1cc9f99765" alt=""
运行结果
data:image/s3,"s3://crabby-images/7dbbd/7dbbd04a4939afc61a2a5f5b7aa9bf5bba18df00" alt=""
不通过传参数的方式 箭头函数内部无法获取到vue实例里面的变量
如下
data:image/s3,"s3://crabby-images/f9e1c/f9e1c943a4f8320804ef9cb05ce00f65af34a8bd" alt=""
data:image/s3,"s3://crabby-images/68002/68002f630175c901df860e5a3b83bf6eece88b1e" alt=""
运行结果
data:image/s3,"s3://crabby-images/09123/09123776d99f0a100a0717934a1bd7e25c081467" alt=""
报错了 引用不到myname变量
解决方法
1.将箭头函数改成普通function 加入this.变量值
如下
data:image/s3,"s3://crabby-images/af4e0/af4e05266f4a76955693921f91e48410ab144445" alt=""
data:image/s3,"s3://crabby-images/73a47/73a47f03a27fc8caaba6ed64e0ddd677ed9f2b6f" alt=""
这时必须执行test2()小括号必须有
运行结果
data:image/s3,"s3://crabby-images/6b930/6b9302e367686d67a3ce9892ec414a587e46b691" alt=""
如果去掉小括号 如下调用写法
data:image/s3,"s3://crabby-images/4e810/4e810e38743d9978e67b45e2458b6c27b52dd92d" alt=""
运行结果
data:image/s3,"s3://crabby-images/bc8c6/bc8c62abde25ac04d533510f24a340abd8256472" alt=""
找不到myname变量
这时需要使用到methods方法
官方推荐做法 将函数统一放到methods下面
methods方法不能使用箭头函数 因为里面this不会指向vue实例 而是undefined
在methods里面定义方法 是官方推荐的 不在data里面定义 会出一定的问题
在methods里面定义的方法 调用时候 加上小括号 或者不加都可以正常运行
如下
data:image/s3,"s3://crabby-images/0b5fc/0b5fc556c63d6be2a31c7088cf638cfaad0d64fb" alt=""
data:image/s3,"s3://crabby-images/cee5b/cee5b5bebe4b2c19bfea1cf464b2853301415353" alt=""
运行结果
data:image/s3,"s3://crabby-images/c9e01/c9e0165c2ffe610a188c79a73d4b58507fd26417" alt=""
改成加上小括号
data:image/s3,"s3://crabby-images/9c4ef/9c4efca3f194da690181b5e1a0c7afbe73bf39c1" alt=""
运行结果
data:image/s3,"s3://crabby-images/3e01f/3e01f7ec42f7bc458004f5bf8b1e20dfa791fa93" alt=""
总结
vue中要把方法定义在methods里面 是一个对象属性 里面放一堆函数
必须要写成普通function不能是箭头函数 否则会出现this指向undefined
然后函数调用时候 表达式加小括号 不加都可以 不加vue会自动判断表达式是一个function进而执行函数
网友评论