Oam*_*nji 4 javascript vue.js vuex v-model
我的目标是创建一个“编辑帐户”表格,以便用户可以修改其帐户数据。我想以一种已经填写了用户数据的形式显示帐户数据,即用户名,电子邮件,地址...
然后,用户可以修改表单中的数据并提交此表单,以更新其用户信息。
我正在使用v-model将表单输入绑定到数据中名为accountInfo的对象,如下所示:
data() {
return {
accountInfo: {
firstName: ''
}
}
}
Run Code Online (Sandbox Code Playgroud)
这是我模板中表单输入的示例:
<input v-model.trim="accountInfo.firstName" type="text" class="form-control" id="first-name" />
Run Code Online (Sandbox Code Playgroud)
对象中键的值当前为空字符串,但我希望这些值来自名为userProfile的对象,该对象是vuex中的状态属性。
在我的“编辑帐户”组件中,我通过导入来映射vuex状态:
import { mapState } from "vuex";
Run Code Online (Sandbox Code Playgroud)
然后在计算属性中使用以下内容
computed: {
...mapState(["userProfile"])
}
Run Code Online (Sandbox Code Playgroud)
我想做的是,不是使用空字符串作为accountInfo的值,而是从从vuex映射的userProfile计算属性中为其分配值,如下所示:
data() {
return {
accountInfo: {
firstName: this.userProfile.fristName,
}
}
}
Run Code Online (Sandbox Code Playgroud)
这将为我的表单提供所需的初始数据,但是不幸的是,这不起作用,大概是因为数据在生命周期中的呈现时间早于计算出的属性。
完整代码:
EditAccount.vue
<template>
<div class="container-fluid">
<form id="sign_up_form" @submit.prevent>
<div class="form-row">
<div class="form-group col-md-6">
<input v-model.trim="signupForm.firstName" type="text" class="form-control" id="first_name" />
</div>
</div>
</form>
</div>
</template>
<script>
import { mapState } from "vuex";
import SideBar from "../common/SideBar.vue";
export default {
name: "EditAccount",
computed: {
...mapState(["userProfile"])
},
data() {
return {
accountInfo: {
firstName: this.userProfile.firstName
}
};
}
};
</script>
Run Code Online (Sandbox Code Playgroud)
store.js:
export const store = new Vuex.Store({
state: {
userProfile: {firstName: "Oamar", lastName: "Kanji"}
}
});
Run Code Online (Sandbox Code Playgroud)
小智 11
将您的输入与 v-model 原样绑定:
<div id="app">
<input type="text" v-model="firstName">
</div>
Run Code Online (Sandbox Code Playgroud)
使用挂载的生命周期钩子设置初始值:
import Vue from 'vue';
import { mapGetters } from 'vuex';
new Vue({
el: "#app",
data: {
firstName: null
},
computed: {
...mapGetters(["getFirstName"])
},
mounted() {
this.firstName = this.getFirstName
}
})
Run Code Online (Sandbox Code Playgroud)
您是对的,在调用初始函数后将对计算结果进行评估data
。
我会在另一个答案中解释Vue的沟通渠道,但这是您可以做的一个简单示例。
将Form组件视为呈现逻辑,因此它不需要了解商店,而只需接收概要数据作为道具。
export default {
props: {
profile: {
type: Object,
},
},
data() {
return {
accountInfo: {
firstName: this.profile.firstName
}
};
}
}
Run Code Online (Sandbox Code Playgroud)
然后,让父级处理业务逻辑,以便从商店中获取信息,触发操作等。
<template>
<EditAccount :profile="userProfile" :submit="saveUserProfile"/>
</template>
<script>
import { mapState, mapActions } from "vuex";
export default {
components: { EditAccount },
computed: mapState(['userProfile']),
methods: mapActions(['saveUserProfile'])
}
</script>
Run Code Online (Sandbox Code Playgroud)
尽管Jacob没错说商店已经准备就绪,并且this.$store.state.userProfile.firstName
可以正常工作,但我认为这更多地是围绕设计问题的补丁,可以通过上述解决方案轻松解决。
归档时间: |
|
查看次数: |
5362 次 |
最近记录: |