Le renvoi de this.user (une propriété globale calculée) fonctionne comme prévu. Bien sûr, je fais une copie car je ne veux pas écraser les données réelles de l'utilisateur. J'utilise donc Object.assign. Cependant, dès que j'inclus return Object.assign({}, this.user) (par opposition à this.user), la méthode watch ne fonctionne plus.
Voici mon modèle (j'utilise bootstrap-vue) :
<template>
<form role="form">
<b-form-group
label="First Name"
label-for="basicName"
:label-cols="3"
:horizontal="true">
<b-form-input id="user-name-first" type="text" v-model="userFormData.fname"></b-form-input>
</b-form-group>
<b-form-group
label="Last Name"
label-for="basicName"
:label-cols="3"
:horizontal="true">
<b-form-input id="user-name-lirst" type="text" v-model="userFormData.lname"></b-form-input>
</b-form-group>
<b-form-group
label="Email"
label-for="user-email"
:label-cols="3"
:horizontal="true">
<b-form-input id="user-email" type="text" v-model="userFormData.email"></b-form-input>
</b-form-group>
<b-form-group
:label-cols="3"
:horizontal="true">
<b-button type="submit" variant="primary">Save changes</b-button>
<b-button type="button" variant="secondary" @click="userFormCancel">Cancel</b-button>
</b-form-group>
</form>
</template>
Donc, cela fonctionne et met éditsEn attente à vrai à chaque fois que des changements sont appliqués à Profil de l'utilisateur (via v-model sur une entrée)
<script>
export default {
name: 'userProfile',
data () {
return {
editsPending: false
}
},
computed: {
userFormData: function () {
return this.user
}
},
watch: {
userFormData: {
deep: true,
handler (val) {
this.editsPending = true
}
}
},
methods: {
userFormCancel () {
this.editsPending = false
}
}
}
</script>
...mais ce n'est pas le cas ; userFormData devient un clone de utilisateur pero éditsEn attente n'est pas affecté par les mises à jour de userFormData .
<script>
export default {
name: 'userProfile',
data () {
return {
editsPending: false
}
},
computed: {
userFormData: function () {
return Object.assign({}, this.user)
}
},
watch: {
userFormData: {
deep: true,
handler (val) {
this.editsPending = true
}
}
},
methods: {
userFormCancel () {
this.editsPending = false
}
}
}
</script>
Quelqu'un peut-il expliquer pourquoi cela se produit et proposer une solution viable ?