我有一个名为“ TextInput”的组件:
<template>
<q-input
v-model="content"
@input="handleInput"
color="secondary"
:float-label="floatLabel" />
</template>
<script>
import { QInput, QField } from "quasar-framework/dist/quasar.mat.esm";
export default {
props: ['floatLabel', 'value'],
data () {
return {
content: this.value
}
},
components: {
'q-field': QField,
'q-input': QInput,
},
methods: {
handleInput(e) {
this.$emit('input', this.content)
}
}
}
</script>
我在另一个组件中使用了这个组件:
<template>
<card card-title = "Edit Skill">
<img slot="img" src="">
<form class="clearfix" slot="form">
<bim-text v-model="skill.name" :floatLabel="input_label"></bim-text>
<q-btn
@click="edit"
icon="save"
size="14px"
color="secondary"
label="Save" />
</form>
</card>
</template>
<script>
import { QBtn } from "quasar-framework/dist/quasar.mat.esm";
import { Card, TextInput } from "../../base";
import router from '../../../routes/routes';
export default {
data: function () {
return {
id: this.$route.params.id,
skill: {
name: ''
},
input_label: 'Skill Name'
}
},
components: {
'card': Card,
'bim-text': TextInput,
'q-btn': QBtn
},
methods: {
edit: function(){
axios.patch('/api/skills/'+this.id, {
name: this.skill.name,
}, { headers: { Authorization: 'Bearer '.concat(localStorage.getItem('token')) } })
.then(response => {
alert('success');
router.push({ name: "IndexSkills"});
}).catch(error => {
console.log('dd');
});
}
},
mounted() {
axios.get("/api/skills/"+this.id, { headers: { Authorization: 'Bearer '.concat(localStorage.getItem('token')) } })
.then(response => {
this.skill = response.data.data;
}).catch(error => {
alert('error')
});
}
}
</script>
<style scoped>
.q-btn{
float: right;
margin-top: 20px;
}
</style>
如您所见,我创建了一个具有空属性name的技能对象,并发出了axios请求以使用其ID获取指定的对象。然后,应该更新axios请求技能的功能,但是发生的是v模型仍然为空。
这是什么问题?以及我该如何解决?
谢谢。
答案 0 :(得分:1)
在初始化(v-model
方法,仅在组件初始化时调用)时,仅将value
值(content
属性)分配给data()
变量。您没有可以响应value
(v-model
)更改的代码,而该代码会更新content
变量。
您应该为value
创建一个监视,然后再次设置this.content = this.value
。
PS:此外,请尝试尝试
this.skill = response.data.data;
执行此操作
this.skill.name = response.data.data.name;