这种写法是es6语法吗

问题1:

const mutations = {
  INCREMENT (state) {
    state.count++
  }
}

INCREMENT是函数吗,为什么要大写

问题2:

<script>
export default {
}
</script>

export default是个空对象,这么写有什么意义吗,其它js来import它的时候得到的是什么

阅读 4.4k
3 个回答

关于是否是ES6,没错,楼上有人回答了

用ES6甚至可以这样写:

const mutations = {
  INCREMENT:(state) => ++state.count
  }
}

这是vuex的演示代码,源代码出自这里:
vuex

用全部大写命名 mutation 是一个惯例,方便将它和 actions 区分开。

最后export一个空对象,正常来说肯定是方便以后添加,先留个占位而已

  1. 上面那个是函数的简写,等同于

    const mutations = {
      INCREMENT:function (state) {
        state.count++
      }
    }
  2. 函数名字大写还是小写没有要求,这个随意。只要清楚js是区分大小写的,给函数命名的时候注意这一点就行

  3. 下面这个我不是很熟悉,不清楚

问题1:是ES6,因为有const,但是大小写只是函数标识符而已,与ES6无关。
问题2:其他JS import得到一个空对象。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题