我想知道如何使用placeholder标记实现select效果,最好将默认选择的选项(如“请选择一个选项:”)进行分类。

我已经尝试了一些变体,但到目前为止它们还没有起作用,并且我确信可以实现,因为我在某个地方看到了它(不记得在哪里)。

我已经试过了:

1)

<fieldset>
            <select data-placeholder="Please select a product" id="s1" class="global">
                <option value="Some">Some</option>
                <option value="Slower">Slower</option>
                <option value="Slow">Slow</option>
                <option value="Fast">Fast</option>
                <option value="Faster">Faster</option>
            </select>
</fieldset>

2)
<fieldset>
            <select id="s1" class="global">
                <option data-placeholder="true"  value="Some">Some</option>
                <option value="Slower">Slower</option>
                <option value="Slow">Slow</option>
                <option value="Fast">Fast</option>
                <option value="Faster">Faster</option>
            </select>
</fieldset>

两者都不起作用,也许有一个jQuery方法可以做到这一点?

快速编辑:我不想只禁用其中一个选项并将其设置为selected,因为它仍将与其他元素一起显示在下拉列表中。

最佳答案

这是两种类型的占位符,可重新选择和隐藏:

演示:http://jsfiddle.net/lachlan/FuNmc/

可重新选择的占位符:

<select>
    <option value="" selected>Please select</option>
    <option value="1">Item 1</option>
    <option value="2">Item 2</option>
    <option value="3">Item 3</option>
</select>

隐藏的占位符:
<select class="empty">
    <option value="" selected disabled>Please select</option>
    <option value="1">Item 1</option>
    <option value="2">Item 2</option>
    <option value="3">Item 3</option>
</select>

CSS更改第一项的颜色:
select option { color: black; }
select option:first-child { color: grey; }
select.empty { color: grey; }
/* Hidden placeholder */
select option[disabled]:first-child { display: none; }

还有一个jQuery,用于在选择后切换字体颜色:
// Applies to all select boxes that have no value for their first option
$("select:has(option[value=]:first-child)").on('change', function() {
    $(this).toggleClass("empty", $.inArray($(this).val(), ['', null]) >= 0);
}).trigger('change');

灵感:
https://stackoverflow.com/a/5805194/1196148-可重新选择的占位符
https://stackoverflow.com/a/8442831/1196148-隐藏的占位符

关于javascript - `select`标签的占位符?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/8368847/

10-12 07:19