为了账号安全,请及时绑定邮箱和手机立即绑定

用vuex敲一个网页计算机demo遇到unknown mutation type

用vuex敲一个网页计算机demo遇到unknown mutation type

花开花落_青藤 2017-06-22 17:13:25
<!DOCTYPE html><html><head><meta charset="UTF-8"><title>计算器</title></head><style>.contain{margin:100px 500px;width: 500px;height: 704px;border: solid 1px #ccc;}.head{position: relative;width: 500px;height: 200px;background-color:#ccc; }.enter{position: absolute;font-size: 20px;font-weight: 800;width: 100%;top:160px;text-align: right;}.result{font-size: 30px;position: absolute;    text-align: right;    top:100px;    width: 100%;}.list{width: 500px;height: 600px;}.list div{font-weight: 800;font-size: 20px;line-height: 124px;text-align: center; width: 123px;height: 124px;    float: left;    border: solid 1px #ccc;}.list div:first-child{color: red;}.list div:last-child{background-color: red;}</style><body><div id="app"><div><div><div>{{result}}</div><div>{{enter ===""?0:enter}}</div></div><div><div><!-- 键盘区域 --><keyboard v-for="item in keys" :value="item"></keyboard></div></div></div></div></body><script src="vue.js"></script><script src="vuex.js"></script><script src="calc_js.js"></script></html>--------------------------------------------------js部分----------------------------------------------------------------------//创建仓库storeconst store = new Vuex.Store({ state:{ result:"",//运算结果 enter:""//输入的值 }, // 定义名为calculate的mutaion mutaions:{ calculate(state,value){ if(value === '='){               // 按键值为'='进行计算               state.result=eval(state.enter);               state.enter +=value; }else if(value==='clear'){ // 按键值clear,清空数据 state.result =state.enter="" }else{ // 输入结果enter进行拼接 state.enter +=value; } } }});// 定义组件Vue.component('keyboard',{ props:['value'], template:`<div @click="getKeyboardValue" :data-value="value">{{value}}</div>`, methods:{ // 点击事件处理函数 getKeyboardValue(event){ // 获取当前按键值 let value = event.target.dataset.value; // 通过commit提交mutaion this.$store.commit('calculate',value) } }});const app = new Vue({ el:'#app', store, data:{ keys:[          'clear','+','-','*',          '7','8','9','/',          '4','5','6','0',          '1','2','3','=' ] }, computed:{ result(){ //通过this.$store获取仓库的数据result return this.$store.state.result; }, enter(){ //通过this.$store获取仓库的数据enter return this.$store.state.enter; } } });
查看完整描述

1 回答

?
慕哥1222438

TA贡献3条经验 获得超44个赞

你的方法没定义,mustation的type

查看完整回答
反对 回复 2017-06-22
  • 1 回答
  • 0 关注
  • 4292 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信