Aucune description

Kia Ishii d3593a2461 Merge branch 'dev' into 4.0 il y a 5 ans
.circleci 6416ebb1e7 feat!: add vue 3 support il y a 5 ans
.github 0fb54ae089 build: add conventional changelog support (#1707) il y a 5 ans
dist d3593a2461 Merge branch 'dev' into 4.0 il y a 5 ans
docs a39d0767e4 fix: Prepend devtool handler (#1358) il y a 5 ans
docs-gitbook 91aa727d42 docs: Update link to flux in README (#1582) il y a 5 ans
examples df3f690843 build: align build system with vue 3 (#1715) il y a 5 ans
scripts df3f690843 build: align build system with vue 3 (#1715) il y a 5 ans
src d3593a2461 Merge branch 'dev' into 4.0 il y a 5 ans
test df3f690843 build: align build system with vue 3 (#1715) il y a 5 ans
types d3593a2461 Merge branch 'dev' into 4.0 il y a 5 ans
.babelrc 22fbb5bc6a update eslint config and deps il y a 8 ans
.eslintrc df3f690843 build: align build system with vue 3 (#1715) il y a 5 ans
.gitignore df3f690843 build: align build system with vue 3 (#1715) il y a 5 ans
CHANGELOG.md fa1ccde633 realese: v3.2.0 il y a 5 ans
LICENSE f053ae7e98 Avoid updating license every year (#1108) il y a 7 ans
README.md 5b44e8e59f types: add typing support (#1717) il y a 5 ans
package.json 5b44e8e59f types: add typing support (#1717) il y a 5 ans
rollup.config.js df3f690843 build: align build system with vue 3 (#1715) il y a 5 ans
rollup.logger.config.js df3f690843 build: align build system with vue 3 (#1715) il y a 5 ans
rollup.main.config.js df3f690843 build: align build system with vue 3 (#1715) il y a 5 ans
yarn.lock 5b44e8e59f types: add typing support (#1717) il y a 5 ans

README.md

Vuex 4

This is the Vue 3 compatible version of Vuex. The focus is compatibility, and it provides the exact same API as Vuex 3, so users can reuse their existing Vuex code for Vue 3.

Status: Alpha

All Vuex 3 feature works. There are a few breaking changes described in a later section, so please check them out. You can find basic usage with both option and composition API at example folder.

Please note that it's still unstable, and there might be bugs. Please provide us feedback if you find anything. You may use vue-next-webpack-preview to test out Vue 3 with Vuex 4.

Breaking changes

Installation process has changed

To align with the new Vue 3 initialization process, the installation process of Vuex has changed as well.

You should use a new createStore function to create a new store instance.

import { createStore } from 'vuex'

const store = createStore({
  state () {
    return {
      count: 1
    }
  }
})

This is technically not a breaking change because you could still use new Store(...) syntax. However, to align with Vue 3 and also with Vue Router Next, we recommend users to use createStore function instead.

Then to install Vuex to Vue app instance, pass the store instance instead of Vuex.

import { createApp } from 'vue'
import store from './store'
import App from './APP.vue'

const app = createApp(App)

app.use(store)

app.mount('#app')

Typings for ComponentCustomProperties

Vuex 4 removes its global typings for this.$store within Vue Component due to solving issue #994. When using TypeScript, you must provide your own augment declaration.

Please place the following code in your project to have this.$store working.

// vuex-shim.d.ts

declare module "@vue/runtime-core" {
  // Declare your own store states.
  interface State {
    count: number
  }

  interface ComponentCustomProperties {
    $store: Store<State>;
  }
}

Known issues

  • The code is kept as close to Vuex 3 code base as possible, and there're plenty of places where we should refactor. However, we are waiting for all of the test cases to pass before doing so (some tests require Vue 3 update).
  • TypeScript support is not ready yet. Please use JS environment to test this for now.

TODOs as of 4.0.0-alpha.1

  • Add TypeScript support
  • ~Make all unit test working~
  • ~Refactor the codebase~
  • Update the build system to align with Vue 3
  • Update docs