Nativescript RadDataForm значение исходных текстовых полей - PullRequest
0 голосов
/ 28 марта 2019

Мой код похож на здесь 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

Как это использовать?

1 Ответ

0 голосов
/ 28 марта 2019

Попробуйте это,

     updateMessage (e) {
        let property = data.object.getPropertyByName(data.propertyName);
        this.$store.commit('updateMessage', property.valueCandidate);
     },
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...