javascript - 如何修复下拉列表中项目的显示?

标签 javascript vue.js javascript-objects html-select

我有下拉列表。我想将“title 1234”放在下拉列表的第一位。 It is important that when "title 1234"is selected, its value is 1234. How should I do it?

这样得到它:

target screen

现在列表看起来像这样:

screen now

Vue.createApp({
        data: () => ({
            model: 'title 1234',
            options: {
                1234: 'title 1234',
                1: 'title 1',
                2: 'title 2',
                3: 'title 3',
                10: 'title 10',
            },
        })
    }).mount('#app')
<div id="app">
  <select v-model="model">
    <option v-for="option in options">
      {{ option }}
    </option>
  </select>
  <span>Value: {{ model }}</span>
</div>
    
<script src="https://unpkg.com/vue@next"></script>
<script src="app.js"></script>

最佳答案

您可以使用 Map及其 .entries() method获取 for-of loop 中的键和值

Vue.createApp({
    data: () => ({
        model: '1234',
        options: new Map([
            [ 1234, 'title 1234' ],
            [ 1, 'title 1' ],
            [ 2, 'title 2' ],
            [ 3, 'title 3' ],
            [ 10, 'title 10' ],
        ]),
    }),
}).mount('#app')
<div id="app">
    <select v-model="model">
        <option v-for="[ key, value ] of options.entries()" :value="key">
            {{ value }}
        </option>
    </select>
    <span>Value: {{ model }}</span>
</div>

<script src="https://unpkg.com/vue@next"></script>
<script src="app.js"></script>

关于javascript - 如何修复下拉列表中项目的显示?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70577971/

相关文章:

javascript - 在 Gridster 上,拖动期间将小部件保持在鼠标下方

javascript - VueJS - 更改推送数组元素的样式

javascript - 是否有任何理由在函数中创建局部 $(this) 变量?

Javascript 有一个图像作为 URI 数据,如何通过 multipart/form-data 表单上传该图像?

javascript - 观察vuejs中动态变化对象的变化

javascript - 当用户需要时获取文本字段

javascript 通过其他 javascript 对象的一个​​对象方法

javascript - 从 javascript 对象数组中选择对象子集

javascript - 数据绑定(bind)到 Polymer 中的动态路径

javascript - 检查用户是否滚动到页面底部相反