1
0

Тайлбар байхгүй

Kia King Ishii a934da95e4 types: add `useStore` function (#1736) (#1739) 5 жил өмнө
.circleci 6416ebb1e7 feat!: add vue 3 support 5 жил өмнө
.github 0fb54ae089 build: add conventional changelog support (#1707) 5 жил өмнө
dist d3593a2461 Merge branch 'dev' into 4.0 5 жил өмнө
docs a39d0767e4 fix: Prepend devtool handler (#1358) 5 жил өмнө
docs-gitbook 91aa727d42 docs: Update link to flux in README (#1582) 5 жил өмнө
examples df3f690843 build: align build system with vue 3 (#1715) 5 жил өмнө
scripts df3f690843 build: align build system with vue 3 (#1715) 5 жил өмнө
src 7c19049005 refactor: use `app.config.globalProperties` to inject store instance to vue app 5 жил өмнө
test df3f690843 build: align build system with vue 3 (#1715) 5 жил өмнө
types a934da95e4 types: add `useStore` function (#1736) (#1739) 5 жил өмнө
.babelrc 22fbb5bc6a update eslint config and deps 8 жил өмнө
.eslintrc df3f690843 build: align build system with vue 3 (#1715) 5 жил өмнө
.gitignore df3f690843 build: align build system with vue 3 (#1715) 5 жил өмнө
CHANGELOG.md 1c9cd5a5b9 chore: update breaking change status as of 4.0.0-beta.1 5 жил өмнө
LICENSE f053ae7e98 Avoid updating license every year (#1108) 7 жил өмнө
README.md 017b973253 chore: fix styling in README 5 жил өмнө
package.json e72d961eca realese: v4.0.0-beta.1 5 жил өмнө
rollup.config.js df3f690843 build: align build system with vue 3 (#1715) 5 жил өмнө
rollup.logger.config.js df3f690843 build: align build system with vue 3 (#1715) 5 жил өмнө
rollup.main.config.js df3f690843 build: align build system with vue 3 (#1715) 5 жил өмнө
yarn.lock 7932ce4e59 build: update vue to 3.0.0-beta.4 5 жил өмнө

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 with Vue 3.

Status: Beta

All Vuex 3 features work. 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 in the example directory.

Feedback is welcome should you discover any issues. 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.

To create a new store instance, users are now encouraged to use the newly introduced createStore function.

import { createStore } from 'vuex'

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

Whilst this is not technically a breaking change, you may still use the new Store(...) syntax, we recommend this approach to align with Vue 3 and Vue Router Next.

To install Vuex to a Vue 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')

Bundles are now aligned with Vue 3

The following bundles are generated to align with Vue 3 bundles:

  • vuex.global(.prod).js
    • For direct use with <script src="..."> in the browser. Exposes the Vuex global.
    • Global build is built as IIFE, and not UMD, and is only meant for direct use with <script src="...">.
    • Contains hard-coded prod/dev branches and the prod build is pre-minified. Use the .prod.js files for production.
  • vuex.esm-browser(.prod).js
    • For use with native ES module imports (including module supporting browsers via <script type="module">.
  • vuex.esm-bundler.js
    • For use with bundlers such as webpack, rollup and parcel.
    • Leaves prod/dev branches with process.env.NODE_ENV guards (must be replaced by bundler).
    • Does not ship minified builds (to be done together with the rest of the code after bundling).
  • vuex.cjs.js
    • For use in Node.js server-side rendering with require().

Typings for ComponentCustomProperties

Vuex 4 removes its global typings for this.$store within Vue Component to solve issue #994. When used with TypeScript, you must declare your own module augmentation.

Place the following code in your project to allow this.$store to be typed correctly:

// vuex-shim.d.ts

import { ComponentCustomProperties } from 'vue'
import { Store } from 'vuex'

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

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

TODOs as of 4.0.0-beta.1

  • Update docs