当前位置:首页 > 编程技术 > 正文内容

uniapp 中 vuex 的使用

yc8881年前 (2022-12-02)编程技术254
  • 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 的两种写法都是正确的):

    <template>    <view>        {{ name }}    </view></template><script>    import { mapState } from 'vuex';    export default {        // computed: mapState(['name']),        computed: {            ...mapState(['name'])        }    }</script>

    通过修改 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])    })});


    本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!


    从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!


    本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。


    本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。


    若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。


    本文链接:https://www.10zhan.com/biancheng/10158.html

    标签: uniappvue
    分享给朋友:

    “uniapp 中 vuex 的使用” 的相关文章

    【说站】laravel实现自定义404页面并给页面传值

    【说站】laravel实现自定义404页面并给页面传值

    以 laravel5.8 为例,虽然有自带的404页面,但太简单,我们更希望能自定义404页面,将用户留在站点。实现的方式很简单,将自定义的视图文件命名为 404.blade.php,并放到 reso...

    【说站】Thymeleaf报错Error resolving template “XXX”

    【说站】Thymeleaf报错Error resolving template “XXX”

    修改了一下开源项目的目录结构访问突然报错Error resolving template “XXX”可能原因有如下三种:第一种可能:原因:在使用springboot的过程中,如果使用thymeleaf...

    【说站】用一句话就可以去除宝塔面板操作上的二次验证

    【说站】用一句话就可以去除宝塔面板操作上的二次验证

    用过宝塔的朋友应该都会发现,现在宝塔面板有些鸡肋的功能,删除文件、删除数据库、删除站点等操作都需要做计算题!不仅加了几秒的延时等待,还无法跳过!这时候就会有朋友在想,如何去除宝塔面板的二次验证,此篇文...

    【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

    【说站】Centos8.0如何配置静态IP详解及永久关闭防火墙

    这篇文章主要介绍了详解Centos8 配置静态IP的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来学习一下!1. 查看自己的网关地址点击虚...

    【说站】C#在PDF中添加墨迹注释Ink Annotation的步骤详解

    【说站】C#在PDF中添加墨迹注释Ink Annotation的步骤详解

    PDF中的墨迹注释(Ink Annotation),表现为徒手涂鸦式的形状;该类型的注释,可任意指定形状顶点的位置及个数,通过指定的顶点,程序将连接各点绘制成平滑的曲线。下面,通过C#程序代码介绍如何...

    【说站】linux中redis如何以redis用户重启?

    【说站】linux中redis如何以redis用户重启?

    通过上图我们可以看到,目前状态是已经以 redis 用户启动着,我想修改下 redis 的密码,然后怎么以 redis 用户重启呢?redis 是 nologin 用户,不能通过 su redis 切...