uniapp 中 vuex 的使用
创始人
2024-03-14 14:26:47
0
  • 1. uniapp 中 vuex 的介绍

  • 2. uniapp 中 vuex 的使用

  • 3. require.context 介绍

  • 4. vuex 模块分离

  • 5. vuex 模块分离 - 代码优化

1. uniapp 中 vuex 的介绍


uniapp 内置了 vuex,不需像 vue 脚手架那样里通过 npm 安装了,我们只需要引用就行了

2. uniapp 中 vuex 的使用


在 uniapp 根目录创建 store/index.js 文件

// 1. 引入vue 和 vueximport Vue from 'vue';import Vuex from 'vuex';// 2. 安装插件Vue.use(Vuex)// 3. 导入对象const store = new Vuex.Store({ })// 4. 默认导出 storeexport default store

在 uniapp 根目录下的 main.js 中新增下面两处修改,导入 store 对象,并将 store 对象挂载到 vue 实例中

修改 store/index.js 文件,在 vuex 中添加一个数据

const store = new Vuex.Store({    state: {        name: 'liang'    }})

在页面中使用 vuex 数据(下面 computed 的两种写法都是正确的):


通过修改 main.js 我们可以把 store 对象挂载到 uni 上

uni.$store = store

然后,在页面中可以通过下面方式获取到 vuex 中的数据

// this 是 vue 实例,所以,当挂载到 Vue 上时要注意 this 的指向this.$store.state// 挂载到 uni 上时获取 vuex 数据uni.$store.state

3. require.context 介绍


require.context 是 webpack 提供的一个 api,该 api 可以实现工程自动化(遍历文件夹中的文件,自动导入模块)

语法格式:

// directory 检索的目录// useSubdirectories 是否检索子目录,取值: true | false// 匹配文件的正则表达式,一般用于匹配文件名require.context(directory, useSubdirectories, regExp)

使用示例:

// 匹配当前目录下的 modules 中所有以 .js 结尾的文件// require.context 的返回值是一个函数const files = require.context("./modules", false, /\.js$/);// files.keys() 匹配到的文件// ['./common.js', './user.js']files.keys().forEach(key => {    // files(key) 文件 export 出的数据    const data = files(key)});

4. vuex 模块分离


我当前所在的公司有一套前端基础框架,这是一个 uniapp 项目,对 vuex 进行了模块分离处理。当 vuex 需要存储的数据比较多时,比如有:用户,购物车,积分商城等模块,为了方便管理,对应前面三个功能可以分离出三个模块文件,但并没有使用 vuex 的模块化

// tore/modules/user.js 用户模块export const state = {    token: ''}// store/modules/cart.js 购物车模块export const state = {    cart: []}// store/index.js 模块合并之后export const state = {    token: '',    cart: []}

下面是我们公司模块分离方式的代码示例:

a. 分离出的模块文件: store/modules/*.js

export const state = {}export const mutations = {}export const actions = {}

b. 在 store/index.js 中导入模块化的文件,合并对象属性

import Vue from 'vue';import Vuex from 'vuex';Vue.use(Vuex)const files = require.context("./modules", false, /\.js$/);const modules = {    state: {},    mutations: {},    actions: {}};files.keys().forEach(key => {    Object.assign(modules.state, files(key)["state"]);    Object.assign(modules.mutations, files(key)["mutations"]);    Object.assign(modules.actions, files(key)["actions"]);});const store = new Vuex.Store(modules)export default store

5. vuex 模块分离 - 代码优化


上面模块分离是我们公司的前端基础框架的代码,但我觉得可以将代码再优化一下

通过上面代码可以发现,抽离出的模块文件代码是这样的:

export const state = {}export const mutations = {}export const actions = {}

给 vuex 的几个属性都定义了常量,然后再分别导出,我不想这样写,可以这样导出

export default {    state: { },    mutations: {},    actions: {}}

store/index.js 中的 files.keys().forEach() 需要修改下:

files.keys().forEach(key => {    Object.keys(modules).forEach(item => {        Object.assign(modules[item], files(key).default[item])    })});

 

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...