vuex-annotation
v0.4.1
Published
A plug-in based on vuex, which aims to make vuex cooperate with typescript to maximize its power
Downloads
11
Maintainers
Readme
vuex-annotation
If you like typescript, you will like it
Description
A plug-in based on vuex, which aims to make vuex cooperate with typescript to maximize its power
API
- Service()
- Mutation()
- Action()
- Autowried()
Example
yarn add vuex-annotation or npm install vuex-annotation
add "emitDecoratorMetadata": true, to tsconfig.js
// store/modules/User.ts
import { Main ,Action, Mutation, Service } from 'vuex-annotation';
// This is a module of vuex
@Service({name: 'User'})
export class User {
// state
public age: number = 1;
// getter
public get ageGetter() {
return this.age;
}
@Mutation()
private setAge() {
this.age += 1;
}
@Action()
public updateUserInfo(data: any) {
this.setAge();
}
}
// store/index.ts
import {User} from './modules/User';
const instance = new Main({
modules: [User] // Just drop the modules to modules
});
export const store = instance.createStore();
Use in components
// ...
import {User} from '@/store';
export default class Home extends Vue {
@Autowried("User") // Inject by name
public users2!: User;
@Autowried() // Inject by type
public users!: User;
public testActions() {
this.users.updateUserInfo(1);
}
}