わからないこと
下のようなフォームにおいて、input 1のデフォルトの値をVuex storeから取得した値にしたいと思っています。
(input 2はvuex storeから取得した値)
フォームコンポーネントのmounted内で下のような実装をしているのですが、vuex storeの値がnullとなってしまっています。
mounted() { if (!this.user.name) this.user.name = this.name },
- フォームコンポーネントがmountedしたタイミングで、
- vuex storeの値をフォームコンポーネントのdata内の変数にインサート
したいと思っています。
下にコード全体を載せますので、どなたかアドバイスいただけたら嬉しいです。
- フォームコンポーネント
vue
1<template> 2 <div> 3 input 1 4 <el-input v-model="user.name"></el-input> 5 6 input 2 7 <el-input v-model="name"></el-input> 8 </div> 9</template> 10 11<script> 12 import {mapState, mapActions} from 'vuex' 13 14 export default { 15 mounted() { 16 if (!this.user.name) this.user.name = this.name 17 18 }, 19 computed: { 20 ...mapState({ 21 name: state => state.user.name, 22 age: state => state.user.age 23 }), 24 }, 25 data() { 26 return { 27 user: { 28 name: '', 29 age: '' 30 } 31 } 32 } 33 } 34</script>
- Vues store
vue
1 2export const state = () => ({ 3 name: 'iii', 4 age: 0 5}); 6 7// action, mutationsなど省略 8
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。