Wie kann ich push-Elemente in einem array in das Daten-Objekt in Vuejs? Vue scheint Sie nicht zu sehen .push () - Methode

Ich bin versucht, fügen Sie Objekte in ein array erklärte ich in Vue-Instanz Daten-Objekt. Ich kann die Werte in den staatlichen Kauf-Objekt, aber wenn ich den push-Daten in die Aufträge Warteschlange array, das leere array nicht gefüllt. Die Funktion wird ausgelöst, aber das array nicht aktualisieren.

Hier ist mein Fragebogen:

<form
  v-on:submit.prevent="queuePurchase"
  class="form-inline row"
  id="order-creation-form"
  method="POST"
>

  @csrf
  <autocomplete-field
    sizing="col-xs-12 col-sm-3 col-md-3"
    name="customer"
    label="Customer"
    :data="{{ json_encode($customers) }}"
    v-on:setcustomer="setCustomer($event)"
  ></autocomplete-field>

  <div class="col-xs-12 col-sm-3 col-md3 form-group d-flex flex-column align-items-start">
    <label for="phone">Product</label>
    <select
      v-model="purchase.product"
      class="form-control w-100"
      name="product"
      aria-describedby="productHelpBlock"
      required
    >
      @foreach ($products as $product)
        <option :value="{{ json_encode($product) }}">
          {{ $product->name }}
        </option>
      @endforeach
    </select>
    <small id="productHelpBlock" class="form-text text-muted">
      Select a product
    </small>
  </div>

  <div class="col-xs-12 col-sm-3 col-md-3 form-group d-flex flex-column align-items-start">
    <label for="phone">Quantity</label>
    <input
      v-model="purchase.quantity"
      type="number"
      min="1"
      name="product"
      class="form-control w-100"
      aria-describedby="productHelpBlock"
      required
    >
    <small id="productHelpBlock" class="form-text text-muted">
      Product quantity
    </small>
  </div>

  <div class="form-group">
    <button type="submit" class="btn btn-success icon-button d-flex">
      <i class="material-icons">add</i>
      <span>&nbsp;&nbsp;  Q U E U E</span>
    </button>
  </div>
</form>

Und hier ist mein javascript:

require("./bootstrap");
window.Vue = require("vue");

Vue.component("queue-table", require('./components/QueueTable.vue'));
Vue.component("autocomplete-field", require('./components/AutocompleteField.vue'));

const purchaseApp = new Vue({
    el: "#purchase-app",

    data() {
        return {
            queue: [],
            purchase: {
                product: null,
                customer: null,
                quantity: null
            }
        }
    },

    methods: {
        setCustomer: function(customerObj) {
            this.purchase.customer = customerObj;
        },

        queuePurchase: function() {
            this.queue.push( this.purchase );
        }
    }
});

Könnte mir bitte jemand erklären, was & warum ist es passiert?

  • Lesen Sie über die Reaktivität in vue hier vuejs.org/v2/guide/list.html#Caveats
  • erfasst werden sollten nach diesem vuejs.org/v2/guide/list.html#Mutation-Methods
  • Sollte dies funktionieren. Sie wahrscheinlich wollen, kopieren Sie die purchase Objekte, obwohl, bevor Sie schieben Sie Sie, um queue. Objekte sind Referenz-Typen. Also, die Warteschlange wird immer store die gleiche Referenz haben (die Punkte für this.purchase).
  • wo sehen Sie die Anzeige der Warteschlange ?
  • Sie gesetzt hatte :data="{{ json_encode($customers) }}" ich denke, Sie kann das nicht tun, wahrscheinlich kann man tun :customers="{{ json_encode($customers) }}" und in Ihrer Daten-Objekt setzen ` Daten() { return {- Kunden :[] ...`
Schreibe einen Kommentar