Fără Descriere

Kia King Ishii 0af60e9390 release: v4.0.0-rc.1 4 ani în urmă
.circleci 6416ebb1e7 feat!: add vue 3 support 5 ani în urmă
.github bc23c55dcf chore: add FUNDING.yml 4 ani în urmă
docs 6734ac5a47 docs: make heading level semantically correct 4 ani în urmă
docs-gitbook 2182ad71ce docs: fix broken link (#1821) 4 ani în urmă
examples 2351c2205b Merge branch 'dev' into 4.0 4 ani în urmă
scripts afa566d7f7 feat: include `createLogger` function in core export 4 ani în urmă
src 0006765ca3 fix: fix getters getting re-evaluated on every access (#1823) (#1860) 4 ani în urmă
test 6ec8f44190 Merge branch 'dev' into 4.0 4 ani în urmă
types 4ace5599ce Merge branch 'dev' into 4.0 4 ani în urmă
.babelrc dfacba6a95 build: migrate tests to jest (#1738) 5 ani în urmă
.eslintrc.json dfacba6a95 build: migrate tests to jest (#1738) 5 ani în urmă
.gitignore afa566d7f7 feat: include `createLogger` function in core export 4 ani în urmă
CHANGELOG.md 0af60e9390 release: v4.0.0-rc.1 4 ani în urmă
LICENSE f053ae7e98 Avoid updating license every year (#1108) 7 ani în urmă
README.md 08b7eb93af chore: update the Vuex status in README 4 ani în urmă
jest.config.js 5a2938793a test: migrate e2e test to puppeteer 4 ani în urmă
package.json 0af60e9390 release: v4.0.0-rc.1 4 ani în urmă
rollup.config.js afa566d7f7 feat: include `createLogger` function in core export 4 ani în urmă
yarn.lock 41098e1d5f build: organize npm packages 4 ani în urmă

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: RC

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>
  }
}

createLogger function is exported from the core module

In Vuex 3, createLogger function was exported from vuex/dist/logger but it's now included in the core package. You should import the function directly from vuex package.

import { createLogger } from 'vuex'

TODOs as of 4.0.0-rc.1

  • Update docs