当前位置: 首页 > wzjs >正文

网站分析模板宣传片制作合同范本

网站分析模板,宣传片制作合同范本,重庆微信网站建设,wordpress全屏博客在 Vuex 中,Mutation(变更) 和 Action(动作) 都是修改状态的核心机制,但职责和使用场景不同: Mutation(变更) 核心特性: 同步操作:必须是同步函…

在 Vuex 中,Mutation(变更)Action(动作) 都是修改状态的核心机制,但职责和使用场景不同:


Mutation(变更)

核心特性:
  1. 同步操作:必须是同步函数(直接修改状态)。
  2. 直接修改状态:唯一能修改 Vuex state 的方式。
  3. 可追踪性:每个 mutation 会被开发工具记录,便于调试时间旅行(state 快照)。
  4. 不可异步:不能在 mutation 中执行异步操作(否则状态变更无法追踪)。
定义方式:
// store.js
const store = new Vuex.Store({state: {count: 0},mutations: {// 基本 mutation(无参数)INCREMENT(state) {state.count++;},// 带参数的 mutationADD(state, payload) {state.count += payload.value;}}
});
触发方式:

组件中通过 commit 触发:

this.$store.commit('INCREMENT');
this.$store.commit('ADD', { value: 10 }); // 参数作为载荷(payload)

Action(动作)

核心特性:
  1. 支持异步:可在 action 中执行异步操作(如 API 请求)。
  2. 提交 Mutation:不直接修改状态,而是通过 commit 调用 mutation。
  3. 复杂逻辑:适合处理业务逻辑(如多个 mutation 组合、条件判断)。
  4. 返回 Promise:支持异步操作链式调用(如 dispatch 后处理)。
定义方式:
// store.js
actions: {// 基本 action(无参数)incrementAsync({ commit }) {setTimeout(() => {commit('INCREMENT');}, 1000);},// 带参数且返回 PromisefetchData({ commit }, payload) {return new Promise((resolve, reject) => {axios.get('/api/data', { id: payload.id }).then(response => {commit('SET_DATA', response.data); // 提交 mutation 修改状态resolve(); // 通知调用方操作完成}).catch(error => reject(error));});}
}
触发方式:

组件中通过 dispatch 触发:

// 调用异步 action
this.$store.dispatch('incrementAsync');// 带参数并处理 Promise
this.$store.dispatch('fetchData', { id: 123 }).then(() => console.log("Data loaded!")).catch(err => console.error(err));

应用场景对比

Mutation 的典型场景:
  1. 简单状态更新
    mutations: {SET_USER(state, user) {state.user = user;}
    }
    
  2. 同步计数/开关
    mutations: {TOGGLE_SIDEBAR(state) {state.isSidebarOpen = !state.isSidebarOpen;}
    }
    
Action 的典型场景:
  1. 异步 API 请求
    actions: {async login({ commit }, credentials) {const user = await api.login(credentials);commit('SET_USER', user); // 提交 mutation}
    }
    
  2. 组合多个操作
    actions: {checkout({ commit, dispatch }, cartItems) {commit('CLEAR_CART'); // 同步清空购物车dispatch('saveOrder', cartItems); // 异步保存订单},saveOrder({ commit }, items) { ... }
    }
    
  3. 条件性提交 mutation
    actions: {updateProfile({ commit, state }, data) {if (state.isLoggedIn) {commit('UPDATE_PROFILE', data);}}
    }
    

总结

特性MutationAction
职责直接修改状态调用 mutation + 业务逻辑
是否支持异步❌ 必须是同步✔️ 支持异步操作
调用方式commit('name', payload)dispatch('name', payload)
适用场景简单状态更新API 请求、复杂逻辑

设计原则
组件 → dispatch Action → commit Mutation → 修改 State → 更新视图
通过分离同步(Mutation)和异步(Action)逻辑,Vuex 保证了状态变更的可预测性和可维护性。

http://www.dtcms.com/wzjs/552184.html

相关文章:

  • 网站建设的扩展阶段包括质感设计网站
  • 慈溪建设集团网站百度竞价推广计划
  • 淘宝网站建设特点洛阳网站建设制作多少钱
  • 网站正在建设中 英文wordpress分页分类导航插件
  • 网上招聘网站开发报告濮阳市网站怎么做宣传
  • 网站优化报价图片编辑器在线网页版
  • 海门市住房和城乡建设局网站网站添加字体
  • 甘肃省建设厅官方网站张睿企业网站做电脑营销
  • 农业公园网站建设网页设计教程答案
  • 微信游戏网站源码怎么做九龙坡区网站建设
  • 做同款的网站进度插件 wordpress
  • 古风网站建设模板网站建设域名多少钱
  • 内江网站制作百度推广业务员电话
  • 宿州网站建设开发公司上海娱乐场所关门
  • 如何做网站站内搜索代码连云港公司网站优化服务
  • 亚洲成成品网站有线高德地图不显示菲律宾
  • 建站行业发展前景什么语言网站比较安全
  • 朝阳专业网站建设公司整套网站模板
  • 网站备案流程详解wordpress本地图片不显示图片
  • 成都专业网站制作企业信用信息查询公示系统天津
  • 装修公司做宣传在哪个网站公司网站赏析
  • 怎么搞免费的网站上海网站制作福州
  • 网站后台程序下载烟台网站推广广州公司
  • 西安谁家的集团门户网站建设比较好阜宁县网站建设
  • 织梦如何做淘宝客网站南江县建设局网站
  • wordpress 站群软件wordpress建站教程视频教程
  • 青岛网站建设网站制作免费设计自己的名字
  • 做外贸要做什么网站如何做企业网站及费用问题
  • 网站建设柒金手指花总15有经验的坪山网站建设
  • 零基础网站建设教学深圳专业网站建设多少钱