Skip to content
Pre-release
Pre-release

@kiaking kiaking released this May 11, 2020 · 3 commits to dev since this release

Bug Fixes

  • types: add useStore function (#1736) #1739
  • build: fix iife build containing process.env.
Assets 2
May 11, 2020
release: v4.0.0-beta.2

@ktsn ktsn released this May 11, 2020 · 3 commits to dev since this release

Features

Assets 2
Pre-release
Pre-release

@kiaking kiaking released this Apr 25, 2020 · 20 commits to dev since this release

Features

  • Added TypeScript support.

Breaking Changes

Bundles are now aligned with Vue 3

The bundles are generated as below to align with Vue 3 bundles.

  • vuex.global(.prod).js
    • For direct use via <script src="..."> in the browser. Exposes the Vuex global.
    • Note that global builds are not UMD builds. They are built as IIFEs and is only meant for direct use via <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 usage via native ES modules imports (in browser via <script type="module">.
  • vuex.esm-bundler.js
    • For use with bundlers like 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 via require().

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>;
  }
}
Assets 2

@ktsn ktsn released this Apr 25, 2020 · 20 commits to dev since this release

Bug Fixes

Features

  • Add prepend option for subscribe and subscribeAction (#1358) (a39d076)
  • logger: createLogger can optionally log actions (#987) (18be128)
Assets 2

@ktsn ktsn released this Apr 19, 2020 · 38 commits to dev since this release

Features

Assets 2
Pre-release
Pre-release

@kiaking kiaking released this Mar 15, 2020 · 48 commits to dev since this release

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(Counter)

app.use(store)

app.mount('#app')

Kown 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.
Assets 2

@ktsn ktsn released this Mar 9, 2020 · 49 commits to dev since this release

Bug Fixes

  • Prevent invalidating subscription iterator (#1438) (@cngu)

Improvements

Assets 2

@ktsn ktsn released this Nov 10, 2019 · 69 commits to dev since this release

Bug Fixes

  • types: avoid broadening vue instance type when using map helpers (#1639) (9a96720) (@ktsn)

Improvements

Performance Improvements

Assets 2

@Akryum Akryum released this May 8, 2019 · 96 commits to dev since this release

Features

Improvements

  • Improved jsdelivr support (#1496)

Fixed

  • Memory leak happening while using registerModule/unregisterModule (#1508)
  • Typings: Make mutation and action payload optional in definition file (#1517)
Assets 2
You can’t perform that action at this time.