Реакционная способность Vuejs на Set Value - PullRequest
0 голосов
/ 08 октября 2019

У меня есть пользовательская таблица с действиями через модальное всплывающее окно, которое устанавливает значения в строках. В основном все работает отлично (обновления для Foo и Bar отправляются на сервер и устанавливаются в базу данных, перезагрузка страницы извлекает данные из базы данных и показывает, что foo / bar были правильно установлены). Единственная не самая лучшая часть - установка Foo, значение в таблице не обновляется. Бар обновляется / реагирует. (шаблон использует foo.name и bar.id). У кого-нибудь есть идеи как заставить Foo обновляться в таблице? Я изменил шаблон усов на использование {{foo.id}}, и он обновляется, но мне нужно имя foo.name.

<template>
  <div>
    <c-dialog
      v-if="foo_modal"
      title="Set Foo"
      :actions="foo_modal_options.actions"
      @cancel="foo_modal = null">
      <slot>
        <div class="form-group">
          <label>Foo:</label>
          <select class="form-control" v-model="foo_modal.thing.foo.id">
            <option v-for="foo in foos" :key="foo.id" :value="foo.id">{{ foo.name }}</option>
          </select>
        </div>
      </slot>
    </c-dialog>
    <c-dialog
      v-if="bar_modal"
      title="Set Rod/Stick"
      :actions="bar_modal_options.actions"
      @cancel="bar_modal = null">
      <slot>
        <div class="form-group">
          <label>Rod:</label>
          <select class="form-control" v-model="bar_modal.thing.rod.id">
            <option v-for="bar in bars" :key="bar.id" :value="bar.id" v-if="bar.type === 'rod'">{{ bar.id }}</option>
          </select>
        </div>
        <div class="form-group">
          <label>Stick:</label>
          <select class="form-control" v-model="bar_modal.thing.stick.id">
            <option v-for="bar in bars" :key="bar.id" :value="bar.id" v-if="bar.type === 'stick'">{{ bar.id }}</option>
          </select>
        </div>
      </slot>
    </c-dialog>

    <c-table-paginated
      class="c-table-clickable"
      :rows="grid.data"
      :columns="grid.columns"
      :actions="grid.actions"
      :key="componentKey">
    </c-table-paginated>
  </div>
</template>

<script>
    import fooModal from '../../components/fooModal.vue';
    import barModal from '../../components/barModal.vue';
    import CTablePaginated from "../../components/custom/cTable/cTablePaginated";
    import cTooltip from '../../components/custom/cTooltip/cTooltip.vue';
    import cDialog from '../../components/custom/cDialog/cDialog.vue';
    import moment from 'moment';

    export default {
        components: { CTablePaginated, cTooltip, cDialog },
        methods: {
            loadData() {
                let that = this;
                that.$http.get('/things', { params: that.param || {} })
                    .then(function (things) {
                        that.things = things.data;
                        that.grid.data = that.things;
                    });
            },
            setBar(thing_id, options, cb) {
                let that = this;
                this.$http.patch(`/things/${thing_id}`, { rod_id: options.rod, stick_id: options.stick })
                    .then(function () {
                        cb();
                    });
            },
            setFoo(thing_id, options, cb) {
                let that = this;
                this.$http.patch(`/things/${thing_id}`, { foo_id: options.foo_id })
                    .then(function () {
                        cb();
                    })
            },
        },
        data() {
            return {
                componentKey: 0,
                things: null,
                foos: [],
                bars: [],
                foo_modal: null,
                foo_modal_options: {
                    actions: [
                        {
                            label: "Save",
                            class: "btn-primary",
                            action: (function (ctx) {
                                return function () {
                                    const thing = ctx.foo_modal.thing;
                                    const options = {
                                        foo_id: thing.foo.id,
                                    };
                                    ctx.setFoo(thing.id, options, function () {
                                        ctx.foo_modal = null;
                                    });
                                }
                            })(this)
                        },
                        {
                            label: "Cancel",
                            action: (function (ctx) {
                                return function () {
                                    ctx.foo_modal = null;
                                }
                            })(this)
                        }
                    ]
                },
                bar_modal: null,
                bar_modal_options: {
                    actions: [
                        {
                            label: "Save",
                            class: "btn-primary",
                            action: (function (ctx) {
                                return function () {
                                    const thing = ctx.bar_modal.thing;
                                    const options = {
                                        rod: thing.rod.id,
                                        stick: thing.stick.id
                                    };
                                    ctx.setBar(thing.id, options, function () {
                                        ctx.bar_modal = null;
                                    });
                                }
                            })(this)
                        },
                        {
                            label: "Cancel",
                            action: (function (ctx) {
                                return function () {
                                    ctx.bar_modal = null;
                                }
                            })(this)
                        }
                    ]
                },
                grid: {
                    data: [],
                    columns: [
                        {
                            label: "Foo",
                            value: function (row) {
                                if (!row.foo) return "No foo set";
                                return `${row.foo.name }`;
                            }
                        },
                        {
                            label: "Rod/Stick",
                            value: function (row) {
                                if (!row.rod && !row.stick) return "No rod/stick set";
                                if (!row.rod) return `No rod set/${row.stick.id}`;
                                if (!row.stick) return `${row.rod.id}/no stick set`;
                                return `${row.rod.id}/${row.stick.id}`;
                            }
                        }
                    ],
                    actions: [
                        {
                            label: "Set Foo",
                            visible: function (thing) {
                                return !thing.active;
                            },
                            action: (function (ctx) {
                                return function (thing) {
                                    if (!thing.foo) thing.foo = {};
                                    ctx.foo_modal = {
                                        thing: thing
                                    };
                                }
                            })(this)
                        },
                        {
                            label: "Set Bar",
                            visible: function (thing) {
                                return !thing.active;
                            },
                            action: (function (ctx) {
                                return function (thing) {
                                    if (!thing.rod) thing.rod = {};
                                    if (!thing.stick) thing.stick = {};
                                    ctx.bar_modal = {
                                        thing: thing
                                    };
                                }
                            })(this)
                        },
                    ],
                }
            };
        },
        props: {
            title: {
                type: String
            },
            param: {
                type: Object,
                required: true
            },
            events: {
                type: Object,
                required: true
            }
        },
        created() {
            let that = this;
            this.loadData();
            this.$http.get('/bars')
                .then(function (bars) {
                    that.bars = bars.data;
                });
            this.$http.get('/foos')
                .then(function (foos) {
                    that.foos = foos.data;
                });
        },
    }
</script>

1 Ответ

0 голосов
/ 10 октября 2019

Есть две возможности, которые вы можете попробовать обе, если любая из них может вам помочь.

  1. Вы можете установить значение, используя метод Vuejs this. $ Set для глубокой реактивности. Нажмите здесь.
  2. Вы можете использовать это. $ NextTick (() => {// установите здесь свою переменную}). Нажмите здесь.
...