Vue-MultiSelect: не получается получить свойство от объекта во время события select - PullRequest
1 голос
/ 07 ноября 2019

Я использую плагин Vue-Multiselect для выпадающего списка ввода и пытаюсь получить фамилию клиента при заполнении формы. По какой-то причине я просто получаю object в качестве значения свойства issue.customer_last_name (см. Скриншот ниже). Вместо этого я хочу получить строку Doe.

У кого-нибудь есть идеи? Моя цель - в конечном итоге отправить эти данные (запрос POST) через кнопку отправки на удаленный API.

enter image description here

Ссылка на коды и ящик, повторяющая проблему: https://codesandbox.io/s/vue-template-9z1wd?fontsize=14&module=%2Fsrc%2Fcomponents%2FTest.vue

Полный код:

<template>
  <div>
    <label for="customer_last_name_input">Last Name:</label>
    <multiselect
      id="customer_last_name_input"
      v-model="issue.customer_last_name"
      :options="customers"
      placeholder="Select an existing customer or type to add a new one"
      :custom-label="customerSelectName"
      label="lastname"
      track-by="uid"
      :close-on-select="true"
      @select="onSelect"
    ></multiselect>
    <br>
    <!-- <input id="customer_last_name_input" type="text" class="form-control" v-model="issue.customer_last_name" placeholder required /> -->
    <div>
      <label for="customer_first_name_input">First Name:</label>
      <input
        id="customer_first_name_input"
        type="text"
        v-model="issue.customer_first_name"
        placeholder
        required
      >
    </div>
  </div>
</template>

<script>
import Multiselect from "vue-multiselect";
export default {
  name: "test",
  components: {
    Multiselect
  },
  data() {
    return {
      customers: [
        {
          uid: "1",
          firstname: "John",
          lastname: "Doe",
          email: "johndoe@aol.com",
          phone: null,
          c_organization: "ACME",
          c_title: null
        },
        {
          uid: "2",
          firstname: "Mary",
          lastname: "Smith",
          email: "msmith@aol.com",
          phone: null,
          c_organization: "NBA",
          c_title: "Miss"
        }
      ],
      issue: {
        customer_first_name: "",
        customer_last_name: ""
        //customer_email: ""
      }
    };
  },
  // async created() {
  //   await this.getCustomers()
  // },
  methods: {
    customerSelectName(option) {
      //return `${option.lastname}, ${option.firstname}`
      return `${option.lastname}, ${option.firstname}`;
    },
    onSelect(option) {
      console.log(option.lastname);
      this.issue.customer_last_name = option.lastname;
      this.issue.customer_first_name = option.firstname;
      // this.issue.customer_email = option.email
    }
  }
};
</script>

1 Ответ

0 голосов
/ 07 ноября 2019

Проблема в v-model="issue.customer_last_name" на самом мультивыборе. Это настройка выбора компонента множественного выбора для всего объекта, который выбирает пользователь, а не только для его фамилии.

Поскольку вы используете @select="onSelect" для выполнения всех необходимых обновлений, просто удалите v-model (строка 6 в песочнице кода), и все будет готово.

Отредактировано, чтобы добавить:

Когда вы видите бесполезное [object Object], это может быть полезно для рендерингаэто где-то еще, где он, скорее всего, будет полностью расширен. Все зависит от браузера, но добавление <div>{{issue.customer_last_name}}</div> было полезным инструментом отладки.

...