Компонент не обновляется при изменении атрибута - PullRequest
0 голосов
/ 06 сентября 2018

Моя проблема в том, что компонент Crud-Table не обновляется при изменении currentTable. Когда я назначаю currentTable = 'doctor' на created () или что-то еще. Это работает, но это не здесь. Почему?

<template>
  <div id="adminpanel">
    <div id="tabs">
      <button
        v-for="tableName in tables"
        :key="tableName"
        @click="switchTo(tableName)"
        >{{ tableName }}
      </button>

      <crud-table :tableName="currentTable"/>
    </div>
  </div>
</template>

<script>
import CrudTable from './CrudTable.vue'

export default {
  name: 'AdminPanel',
  data () {
    return {
      tables: ['user', 'doctor'],
      currentTable: 'user'
    }
  },
  methods: {
    switchTo: function (tableName) {
      this.currentTable = tableName
    }
  },
  components: {
    CrudTable
  }
}
</script>

Edit: Это не дубликат, потому что я никоим образом не ошибся в названии реквизита. И это работает, когда я устанавливаю другое начальное значение.

Это мой компонент CrudTable:

<template>
  <table id="crudtable">
      <tr>
        <th>Akcje</th>
        <th v-for="h in header" :key="h">
          {{ h }}
        </th>
      </tr>
      <tr v-for="row in rows" :key="row.id">
        <td>
          <span class="action edit">E</span>
          <span @click="save(visible(row))" class="action save">S</span>
          <span class="action delete">D</span>
        </td>
        <td v-for="cell in ordered(visible(row))" :key="cell.name">
          <input v-model="cell.value" type="text"/>
        </td>
      </tr>
  </table>
</template>

<script>
import {HTTP} from '../http-common'
import {popUp} from '../utils'

export default {
  name: 'CrudTable',
  props: ['tableName'],
  data () {
    return {
      rows: [],
      header: [],
      chunkSize: 10
    }
  },
  computed: {
    endpoint: function () {
      return `/api/${this.tableName}`
    }
  },
  methods: {
    visible: function (row) {
      let ret = {}
      for (let prop in row) {
        if (!prop.startsWith('_')) {
          ret[prop] = row[prop]
        }
      }
      return ret
    },
    ordered: function (row) {
      let ret = []
      for (let col of this.header) {
        ret.push({name: col, value: row[col]})
      }
      return ret
    },
    fillTable: function () {
      let self = this
      let link = `${this.endpoint}/?page=0&size=100`
      HTTP.get(link)
        .then(function (response) {
          self.rows = response.data
        })
        .catch(function (err) {
          console.log(err.response)
        })
    },
    fillHeader: function () {
      let self = this
      HTTP.get(self.endpoint)
        .then(function (response) {
          self.header = Object.keys(response.data)
        })
        .catch(function (err) {
          console.log(err.response)
        })
    },
    save: function (row) {
      HTTP.patch(this.endpoint, row)
        .then(function (response) {
          popUp('ok', `Zapisano obiekt o id ${row.id}`)
        })
        .catch(function (err) {
          console.log(err.response)
        })
    }
  },
  beforeMount () {
    this.fillTable()
    this.fillHeader()
  }
}
</script>

Ответы [ 3 ]

0 голосов
/ 06 сентября 2018

Так как он работает с созданным (), возможно, попробуйте использовать vuex для хранения данных или использовать шину событий, чтобы сказать CrudTable перерисовать

0 голосов
/ 07 сентября 2018

Если я правильно понимаю, вы задаетесь вопросом, почему CrudTable.fillTable() не вызывается при изменении CrudTable.endpoint (которое зависит от CrudTable.tableName). Проблема в том, что fillTable() это просто метод, который не реагирует. fillTable() оценивает endpoint только во время разговора.

Если вы хотите, чтобы fillTable() вызывался при каждом изменении endpoint, вам нужно добавить watcher к этому:

watch: {
  endpoint(value) { // <-- called when endpoint computed prop changes
    this.fillTable(value);
  }
},
methods: {
  fillTable(endpoint) {
     // http.get(`${endpoint}/users`)
  }
}

демо

0 голосов
/ 06 сентября 2018

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

<crud-table :table-name="currentTable"/>

вместо ...

<crud-table :tableName="currentTable"/>

Насколько я помню, свойства должны быть в kabobcase.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...