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

win7优化工具搜索引擎优化核心

win7优化工具,搜索引擎优化核心,进入公众号会不会泄露个人信息,网上商城系统的设计与实现14天阅读挑战赛 学不可以已... 目录 一、Vuex简介 1.1 vuex介绍 1.2 vuex核心 二、Vuex使用 2.1 Vuex安装 2.2 创建store模块 2.3 创建vuex的store实例并注册上面引入的各大模块 三、使用Vuex获取、修改值案例 3.1 创建两个菜单组件 3.2 配置路由 3.3 模拟菜单数据 …

14天阅读挑战赛
学不可以已...

目录

一、Vuex简介

1.1 vuex介绍

1.2 vuex核心

二、Vuex使用

2.1 Vuex安装

2.2 创建store模块

2.3 创建vuex的store实例并注册上面引入的各大模块

三、使用Vuex获取、修改值案例

3.1 创建两个菜单组件

3.2 配置路由

3.3 模拟菜单数据

3.4 vuex核心操作

3.5 界面获取、修改值实现

四、异步处理

4.1 异步改变值

4.2 异步发送Ajax到后端

Tips❕


一、Vuex简介

1.1 vuex介绍

        Vuex是专门为vue应用程序开发的状态管理模式,将组件的共享状态抽取出来,以一个全局单例模式进行管理,组件树构成一个巨大的视图,不管组件在树的何种位置,任何组件都能获取到状态和触发行为。可以将其想象为一个“前端数据库”(数据仓库),让其在各个页面上实现数据的共享包括状态,并且可操作。(核心就是 解决组件间的通讯问题)

1.2 vuex核心

  1. State(单一状态树):存储应用程序的状态数据,类似于组件中的data属性。但与组件的data不同,Vuex的状态是响应式的,当状态发生变化时,所有依赖该状态的组件都会自动更新。

  2. Getters(状态获取):用于从状态中派生出新的数据,类似于Vue组件中的计算属性。Getters可以对状态进行一些计算或过滤,并将结果暴露给组件使用。

  3. Mutations(变更):用于修改状态的唯一途径。Mutations是同步的操作,用于处理同步的状态变更。每个Mutation都有一个字符串类型的事件名称和一个回调函数,通过提交(commit)Mutation来触发状态的变更。

  4. Actions(动作:提交mutation,可以包含异步操作):用于处理异步操作和复杂的业务逻辑。Actions可以包含任意异步操作,例如发送网络请求或执行定时任务,并通过提交Mutations来修改状态。Actions可以通过分发(dispatch)来触发。

  5. Modules(模块):用于将大型的Vuex应用程序拆分为更小的模块,每个模块都有自己的状态、获取器、变更和动作。这样可以更好地组织代码,提高代码的可维护性和可扩展性。

使用Vuex可以带来以下好处:

  1. 集中式的状态管理:将应用程序的状态集中管理,使得状态的变更更加可追踪和可维护。

  2. 组件之间的数据共享:不同组件之间可以轻松地共享状态,避免了通过props和事件传递数据的繁琐过程。

  3. 状态的可预测性:通过明确的状态变更方式(Mutations和Actions),可以更好地追踪状态的变化,提高代码的可读性和可维护性。

  4. 插件扩展:Vuex提供了丰富的插件机制,可以方便地扩展Vuex的功能,例如添加日志记录、持久化存储等。

二、Vuex使用

2.1 Vuex安装

注意: 运行环境

1、node.js版本10输入下指令进行安装

npm install vuex -S

2、node.js版本18请执行下指令 

npm i -S vuex@3.6.2

2.2 创建store模块

创建store目录及需要的文件:

2.3 创建vuex的store实例并注册上面引入的各大模块

1、src/store/index.js

import Vue from 'vue'
import Vuex from 'vuex'
import state from './state'
import getters from './getters'
import actions from './actions'
import mutations from './mutations'
Vue.use(Vuex)
const store = new Vuex.Store({state,getters,actions,mutations
})export default store

 2、src/main.js

通过在根实例中注册store选项,该store实例会注入到根组件下的所有子组件中,且子组件可以通过this.$store访问到。

三、使用Vuex获取、修改值案例

3.1 创建两个菜单组件

src/views/vuex

3.2 配置路由

src/router/index.js

3.3 模拟菜单数据

    <!-- 模拟数据 --><el-submenu key="key_999" index="index_999"><template slot="title"><span slot="title">Vuex管理</span></template><el-menu-item key="key_99901" index="/vuex/pageOne"><span>pageOne</span></el-menu-item><el-menu-item key="key_99902" index="/vuex/pageTwo"><span>pageTwo</span></el-menu-item></el-submenu>

3.4 vuex核心操作

1、在state.js中定义全局参数

export default {Name: '云村小威'
}

2、在mutations.js中改变值

export default {/* 1.state指state.js文件导入的对象2.payload指vue文件传递过来的界面*/setName: (state, payload) => {state.Name = payload.Name}
}

3、在getters.js中获取参数值

export default {getName: (state) => {return state.Name;}
}

        这一些列操作相当于java分装实体类,把它一一才拆分,这样可以更好地组织代码,提高代码的可维护性和可扩展性。

3.5 界面获取、修改值实现

1、pageOne.vue组件编写:

<template><div><h1>PageOne</h1><p>请输入您要修改的值</p><input type="text" v-model="msg"><button @click="changed">修改参数值</button><button @click="getData">获取参数值</button></div>
</template><script>export default {data() {return {msg: '默认值'}},methods:{changed(){this.$store.commit('setName',{Name:this.msg})},getData(){let name = this.$store.getters.getName;alert(name);}}}
</script><style>
</style>

注意:

  1. setName是mutations.js导出的属性名
  2. getName是getters.js导出的属性名

效果展示:

2、pageTwo.vue组件编写:

<template><div><h1>PageTwo</h1>{{change}}</div>
</template><script>export default {data() {return {msg: '默认值'}},computed:{change(){return this.$store.getters.getName;}}}
</script><style>
</style>

效果展示:

四、异步处理

4.1 异步改变值

1、src/store/actions.js

export default {setNameSync: (context, payload) => {//context指的是vuex的上下文setTimeout(function() {context.commit('setName', payload)}, 3500)}
};

 2、在pageOne.vue组件添加异步事件

<button @click="Asynchronization">异步改变参数值</button>Asynchronization() {this.$store.dispatch('setNameSync', {name: this.msg})}

效果演示:

4.2 异步发送Ajax到后端

1、后端请求代码编写:

package com.ycxw.ssm.controller;import com.zking.ssm.util.JsonResponseBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletRequest;
import java.text.SimpleDateFormat;
import java.util.Date;@RestController
@RequestMapping("/vuex")
public class VuexController {@RequestMapping("/queryVuex")public JsonResponseBody<?> queryVuex(HttpServletRequest request) {String resturantName = request.getParameter("resturantName");SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String date = sdf.format(new Date());try {System.out.println("模拟异步情况,睡眠6秒,不能超过10秒,axios超时时间设置的是10秒!");Thread.sleep(6000);System.out.println("睡醒了,继续...");} catch (Exception e) {e.printStackTrace();}return new JsonResponseBody<>(resturantName + "-" + date,true,0,null);}
}

2、src/api/action.js 封装请求的地址

  'VUEX': '/vuex/queryVuex'

3、src/store/actions.js 异步发送ajax到后端

  setNameAjax: (context, payload) => {let _this = payload._this;let url = _this.axios.urls.VUEX;let params = {resturantName: payload.Name};_this.axios.post(url, params).then(r => {console.log(r)}).catch(r => {//异常代码console.log(r);});}

4、在pageOne.vue组件添加Ajax异步事件

<button @click="Ajax">异步Ajax改变参数值</button>Ajax() {this.$store.dispatch('setNameAjax', {Name: this.msg,_this: this})}

 十秒异步处理演示:

Tips❕

 Action类似于 mutation,不同在于:

   1. Action提交的是mutation,而不是直接变更状态

   2. Action可以包含任意异步操作

   3. Action的回调函数接收一个 context 上下文参数,注意,这个参数可不一般,它与 store 实例有着相同的方法和属性

注1: VUEX 的 actions 中无法获取到 this 对象

如果要在actions 或者 mutations 中使用this对象,可以在调用的时候把this对象传过去。 

http://www.yidumall.com/news/7114.html

相关文章:

  • 近期的新闻热点济南网站seo哪家公司好
  • 网站开发与设计实验报告总结海口网站建设
  • 医保局网站建设中标公告网站优化内容
  • 网站建设动态代码百度移动权重
  • 网站建设模板研究semi认证
  • 做周边的专业网站网页制作模板
  • 市场营销怎么做推广搜索引擎推广与优化
  • 网站建设的成本怎么引流推广自己的产品
  • 装修网站有哪些云南百度公司
  • 唐山网站建设天津seo关键词排名优化
  • 一个网站需要多少钱某网站seo策划方案
  • 湖北专业网站建设口碑好淘宝关键词排名是怎么做的
  • 网站平台建设服务承诺书全网营销推广 好做吗
  • 乌海做网站的公司拼多多推广引流软件免费
  • 企业可以做哪些网站有哪些内容最新中高风险地区名单
  • 设计报价网站济南网站优化公司排名
  • 网站后台数据库丢失贵阳百度推广电话
  • htmi如何做网站全网整合营销公司
  • 做视频自媒体要投稿几个网站宁德市政府
  • 惠州网站建设模板合作球队积分排名
  • 做购物网站 需要手续百度获客平台
  • 网站建设 英文版中国营销网站
  • 目前最好的推广平台杭州优化建筑设计
  • 国学网站源码重庆企业seo
  • asp网站建设搜外友链
  • 服装定制图片网站如何优化关键词排名
  • 北京软件外包公司排名seo快速排名优化
  • 定制版网站建设费用什么是交换链接
  • 可以做动漫的网站网站搜索排名
  • 宁波网站建设制作方法seo咨询推广找推推蛙