Мой код похож на здесь https://play.nativescript.org/?template=play-vue&id=TO4i2n&v=4
Мне нужны значения RadDataForm для обновления объекта состояния Vuex, который является источником для RadDataForm.
Итак, я хотел сделать это, но не с одним текстовым полем, а с RadDataForm https://vuex.vuejs.org/guide/forms.html
Магазин Vuex:
const state = {
items: {
mainTab: {
HPval: 10,
MANA: 0,
'type': '',
},
}
RadDataForm
<StackLayout row="0">
<RadDataForm
:source="mainTab"
@propertyCommitted="updateMessage"
:metadata="mainTabMetadata">
</RadDataForm>
</StackLayout>
computed: {
...mapState({
mainTab: state => state.inputValues.items.mainTab,
})
}
И по свойству Commited запустить метод updateMessage. Мне нужно значение (текст) фактического измененного поля, но нет значения. Вы можете видеть, что я хочу зафиксировать мутацию для обновления состояния, как здесь https://vuex.vuejs.org/guide/forms.html, но у меня нет значения.
updateMessage (e) {
console.log("PropertyCommitted");
console.log(e);
//console.log(e);
//console.log(this.val);
//console.dir(e.text);
this.$store.commit('updateMessage', e.target.value)
},
и это мутация в магазине
updateMessage (state, data) {
state.items = data
console.log("PropertyCommitted mutation fired");
}
консольный журнал выдаёт.
JS: object: RadDataForm(940)
JS: editor: "undefined"
JS: entityProperty: EntityProperty(958)
JS: propertyName: "MANA"
JS: group: "undefined"
JS: groupName: "DefaultGroup"
JS: returnValue: "true"
В обычном TextField я могу использовать v-модель, получить значение и зафиксировать мутацию, но как обойти это с RadDataForms?
Там написано https://docs.nativescript.org/ui/professional-ui-components/DataForm/GettingStarted/dataform-start-result
Другое событие - propertyCommitted - вызывается после фиксации свойства, поэтому вы можете использовать его для получения нового значения из исходного объекта или через свойство editedObject RadDataForm.
https://docs.nativescript.org/ns-ui-api-reference/classes/raddataform#editedobject
Как это использовать?