javascript - 怎样理解js函数参数使用大括号(vuex手册中一个例子)?
PHPz
PHPz 2017-04-11 12:35:27
[JavaScript讨论组]

vuex手册中的tutorial里,“计数器加一”的例子,创建的action函数使用了大括号{}把参数包起来,不太理解:

export const incrementCounter = function ({ dispatch, state }) {
  dispatch('INCREMENT', 1)
}

{}通常表示一个对象,这里作为action函数的参数传入,看起来有点多余。
我尝试去掉{}:

export const incrementCounter = function (dispatch, state) {
  dispatch('INCREMENT', 1)
}

发现代码不能正确运行:点“+1”按钮,计数器的值不变,一直为0:

当然这个尝试应该是有点问题的,浏览器有报错:

哪位可以详细解释下原理和作用吗?

PHPz
PHPz

学习是最好的投资!

全部回复(2)
PHP中文网

https://developer.mozilla.org...

PHP中文网

自问自答一个,算是表达自己对于vuex文档中使用的“函数参数的解构赋值”的看法。

我认为这里使用{}解构赋值的目的在于,后续调用传入参数(它是一个对象)的一些属性时,能省去前缀,尤其当属性比较多的时候。

但是其实可以使用另一种做法,类似于php中处理HTTP的GET或POST请求时的extract()函数,直接把对象的key都提取出来,有人也给出了简单的实现:

function extract(data, where) {
    for (var key in data) {
        where[key] = data[key];
    }
}

function runTest() {
    var myData = { name: "Olly", age: 19, };
    extract(myData, this);
    alert(name +" is "+ age +"!");
}

runTest();
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号