首页 > 解决方案 > Vue自定义v-model值从axios get请求获取后不更新值

问题描述

我有一个名为“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-model 仍然为空。

这里会有什么问题?我该如何解决?

提前致谢。

标签: laravel-5vue.jsvuejs2vue-componentaxios

解决方案


您只需在初始化时为变量赋值v-modelvalue属性) (方法,仅在组件初始化时调用)。您没有可以对( ) 更改做出反应的代码,这将更新变量。contentdata()valuev-modelcontent

您应该为 创建一个手表value,然后this.content = this.value再次设置。

PS:另外,试试这个

this.skill = response.data.data;

做这个

this.skill.name = response.data.data.name;

推荐阅读