如何禁用select选项的值? (vue.js 2)

时间:2017-02-10 21:48:09

标签: javascript jquery vue.js vuejs2 vue-component

我的组件是这样的:

<div id="demo">
  <div>
    <select class="form-control" v-model="selected" required>
      <option v-for="option in options" v-bind:value="option.id">{{ option.name }}</option>
    </select>
    {{selected}}
  </div>
</div>

var demo = new Vue({
  ...
  data() {
    return {
      selected: '',
      options: [{
        id: '',
        name: 'Select Category'
      }]
    };
  },
  ...
})

请在此处查看完整代码和演示:https://fiddle.jshell.net/oscar11/stvct9er/5/

我要禁用“选择类别”。因此“选择类别”已禁用。用户无法选择它。用户只能选择“选择类别”以外的值。

我该怎么做?

2 个答案:

答案 0 :(得分:6)

您应该直接在option代码中添加select

<select class="form-control" v-model="selected" required>
  <option value="" disabled>Select a category</option>
  <option v-for="option in options" v-bind:value="option.id">{{ option.name }}</option>
</select>

另外,请将其从data功能中删除。

data() {
  return {
    selected: '',
    options: []
  };
}

我建议您不要在options数组中添加此选项,因为它是placeholder的{​​{1}}属性。

这是working solution

答案 1 :(得分:3)

其他选项可能是使用绑定

禁用该元素
  <option v-for="option in options" :disabled="!option.id"  v-bind:value="option.id">{{ option.name }}</option>

Working fiddle