vuex我也能手写了!

前言

vuex给组件通信带来了极大便利,想想我们是不是也能打造一个简易版的vuex呢?

正文

实现vuex

vuex的基本用法如下:

  1. 首先引入createStore ,调用createStore(传入一个对象 作为参数)并将结果store这个实例对象抛出 ,在main.js中引入 store后将它use掉。
  2. 访问仓库数据只需引入useStore调用它后就能访问了。
  3. 触发mutations中的方法需使用commit('方法名' , 参数)来触发

步骤一

我们根据它的基本用法,我们使用 先搭建一个基本框架

js 复制代码
class Store {
    constructor(options) {
        this.$options = options  //一个对象
        this._state = reactive({  //响应式数据源
          data: options.state()
        })
        this._mutations = options.mutations
    }

function createStore(options) {
  return new Store(options)
}

export {
  createStore
}

步骤二

我们访问仓库数据源会直接store.state ,但是这里访问则是store._state.data ,那么可以使用get关键字去声明一个函数,直接解决问题!

js 复制代码
get state() { 
    return this._state.data
}

步骤三

因为 Vuex 插件需要被 use() 才能被使用,所以必须要有个 install 方法,其中接收的参数app 就是Vue ,我们利用 Vue 的provide方法将其提供出去

js 复制代码
 install(app) {   //将store挂载到全局   app就是vue
    app.provide('_store_', this)
 }

步骤四

为了能获取到仓库数据,我们需要打造一个useStore方法并抛出,也就是说把这个仓库的实例对象注入到组件中。(const store = useStore() 相当于 inject('store'))

js 复制代码
function useStore() {
  return inject('_store_')
}

步骤五

我们要访问仓库中mutations的方法得使用store.commit()进行触发,它接收一个函数名 ,其它为剩余的参数

js 复制代码
 commit(method, ...args) {  //触发mutations中的方法
    const fn = this._mutations[method]  //获取mutations中的方法
    fn && fn(this.state, ...args)  //如存在则调用mutation中的方法,这个方法接收state和剩余参数
 }

这里只打造了可以访问数据源和触发mutation中方法的简易版vuex,其它模块的实现也不会太难,最后附上整份代码:

js 复制代码
//手动实现vuex
import { reactive, inject } from 'vue'
class Store {
   constructor(options) {
        this.$options = options  //一个对象
        this._state = reactive({  //响应式数据源
          data: options.state()
        })
        this._mutations = options.mutations
   }

  get state() {
    return this._state.data
  }

  commit(method, ...args) {  //触发mutations中的方法
    const fn = this._mutations[method]  //获取mutations中的方法
    fn && fn(this.state, ...args)  //如存在则调用这个方法
  }

  install(app) {   //将store挂载到全局   app就是vue
    app.provide('_store_', this)
  }

}

function createStore(options) {
  return new Store(options)
}

function useStore() {
  return inject('_store_')
}

export {
  createStore,
  useStore
}
相关推荐
❀͜͡傀儡师4 小时前
Vue+SpringBoot 集成 PageOffice实现在线编辑 Word、Excel 文档
vue.js·spring boot·word
Zhencode4 小时前
深入Vue3响应式核心:computed 的实现原理与应用
前端·javascript·vue.js
是欢欢啊5 小时前
全新的table组件,vue3+element Plus
前端·javascript·vue.js
小小前端--可笑可笑13 小时前
Vue / React 单页应用刷新 /login 无法访问问题分析
运维·前端·javascript·vue.js·nginx·react.js
小林敲代码778814 小时前
记一次 Vue 项目首屏优化:从 7.1s 到 0.9s,深挖 Gzip 的力量
前端·javascript·vue.js
半兽先生17 小时前
告别 AI 乱写 Vue!用 vue-skills 构建前端智能编码标准
前端·vue.js·人工智能
前端达人18 小时前
都2026年了,还在用Options API?Vue组合式API才是你该掌握的“正确姿势“
前端·javascript·vue.js·前端框架·ecmascript
chao-Cyril19 小时前
从入门到进阶:前端开发的成长之路与实战感悟
前端·javascript·vue.js
念念不忘 必有回响21 小时前
前端判断文本是否溢出:单行与多行场景的完整解析
前端·javascript·css·vue.js
css趣多多21 小时前
vue3的组件间通信ref子组件需要把父组件要的ref数据开放
前端·javascript·vue.js