当前位置: 首页 > 面试题库 >

将select的背景色设置为JQuery中的选定选项

潘嘉佑
2023-03-14
问题内容

我有一个带有多个选择框的页面,如下所示:

<select name="item-0-status" id="id_item-0-status">
<option value="">---------</option>
<option value="1">Online</option>
<option value="2">Offline</option>
<option value="3">Unknown</option>
</select>

这些是在Django中自动生成的,因此无法将CSS类,ID或属性直接应用于选项。选择元素的ID为’item-0-status’,’item-1-status’,’item-2-status’等。

我通过以下JQuery代码为选项分配颜色:

$('select[id$=-status][id^=id_item-]').children().each(
        function (){
            if($(this).val() == 0){
                $(this).css('backgroundColor','white');
            }
            if($(this).val() == 1){
                $(this).css('backgroundColor','green');
            }
            if($(this).val() == 2){
                $(this).css('backgroundColor','red');
            }
            if($(this).val() == 3){
                $(this).css('backgroundColor','orange');
            }
        }
    );

哪个工作正常。

我还希望select元素具有与selected选项相同的背景色,我正在尝试使用以下html" target="_blank">方法实现该目的:

$('select[id$=-status][id^=id_item-]').each(
        function (){
            $(this).css('backgroundColor',$('option:selected',this).css('backgroundColor'));
        }
    );

但是,这只是将选择元素着色为蓝色(我认为它是从悬停属性而不是背景获取颜色)。这是Firefox 3.6.8中的版本,就此问题而言,它是唯一涉及的浏览器。

任何想法如何解决这个问题?


问题答案:

将“每个”替换为“更改”

$('select[id$=-status][id^=id_item-]').change(
    function (){
        var color = $('option:selected',this).css('background-color');
        $(this).css('background-color',color);
    }
).change();

这适用于Chrome。

另请参阅:http :
//docs.djangoproject.com/en/dev/ref/contrib/admin/#modeladmin-media-
definitions

支持django admin中的自定义CSS。

而且我认为正确的CSS属性是:'background-color'backgroundColor是javascript,应按以下方式使用:
$(this).css({backgroundColor:color});但是它似乎仍然可以正常工作,所以没什么大不了的。

编辑:

如果要在页面加载时初始化脚本,则只需在后面添加.change()即可。参见代码。

我也在firefox中进行了测试,并且也看到了这种奇怪的行为(蓝色,蓝色?)。

另一个编辑:

好的,所以这是Firefox的快速修复:

$('select[id$=-status][id^=id_item-]').children().each(function (){
    if($(this).val() == 0){
        $(this).attr('style', 'background-color:white;');
    }
    if($(this).val() == 1){
        $(this).attr('style', 'background-color:green;');
    }
    if($(this).val() == 2){
        $(this).attr('style', 'background-color:red;');
    }
    if($(this).val() == 3){
        $(this).attr('style', 'background-color:orange;');
    }
});

$('select[id$=-status][id^=id_item-]').change(function (){
    var style = $(this).find('option:selected').attr('style');
    $(this).attr('style', style);
}).change();

最后编辑:

如果使用CSS,甚至可以做到这一点:

<style>
    select option,
    select {
        background-color:white;
    }

    select option[value="1"],
    select.o1
    {
        background-color:green;
    }

    select option[value="2"],
    select.o2
    {
        background-color:red;
    }

    select option[value="3"],
    select.o3
    {
        background-color:orange;
    }
</style>

<script>    
    $('select[id$=-status][id^=id_item-]').change(function (){
        var color = $(this).find('option:selected').val();

        $(this).removeClass('o1 o2 o3').addClass('o' + $(this).find('option:selected').val());
    }).change();
</script>

另一个编辑:

我碰到了这一点,发现可以将其缩短,所以我只是为了好玩而已:

$('select[id$=-status][id^=id_item-]').children().each(function() {    
    var colors = ['white', 'green', 'red', 'orange'];
    $(this).attr('style', 'background-color:' + colors[$(this).val()] + ';');
});
$('select[id$=-status][id^=id_item-]').change(function() {
    $(this).attr('style', $(this).find('option:selected').attr('style'));
}).change();


 类似资料:
  • 我是瓦丁开发公司的新人,我希望有人能帮助我。我刚刚用模型创建了一个网格表,一切都很好。但是现在,我想改变选定行的背景颜色。我想,我必须创造一个主题。我在瓦丁论坛上发现了这个:https://vaadin.com/forum/thread/17867059/how-to-set-selected-row-opacity-in-vaadin-grid 这是我已经做过的: 我用链接中的代码创建了一个ht

  • 我在用这个http://www.primefaces.org/showcase-labs/ui/selectManyCheckbox.jsfprimefaces组件获取动态布尔复选框值 我需要对所有布尔复选框应用不同的颜色,如下图所示 如果id=1,则颜色为红色;如果id=2,则颜色为橙色,依此类推。 正如我们所知,这些是电影中的动态值,那么我如何从backing bean为这些动态复选框设置背景

  • 我有一个将初始背景颜色设置为红色的按钮。我有一个在红色和深红色之间翻转的动作程序。基本上,如果选择按钮,它是红色的。没有选中,是暗红色。 代码运行,但是每当选择切换按钮时,它都是白色的。所以我在深红色和白色之间切换。 我所做的:我做了很多代码实验,但毫无进展。我做了很多网络搜索,但找不出一个有效的例子。 我正在使用Java11。我需要在代码中更改什么才能获得我想要的行为?

  • 问题内容: 任何答案如何设置所选单元格的背景色? 问题答案: 斯威夫特4.2 对于多个选择,您需要将属性设置为 true 。 myTableView.allowsMultipleSelection = true 如果您将 UITableViewCell 子类化,则可以在自定义单元格类中重写方法。

  • 问题内容: 我有一个框,当单击框并显示所有选项时,我正在尝试更改选项的背景色。 HTML: CSS: 问题答案: 你需要把对标签,而不是标签… 如果要为每个标签设置样式,请使用css 选择器:

  • 我正在实现一个底部导航菜单。但菜单中的第一项未被选中。我注意到,当我更改栏背景的颜色时,它会显示出来,原因是第一项“启用”的颜色与导航栏的背景颜色相同。如何更改“已启用”选项卡以及其余项目的颜色。默认情况下它们是黑色的。。。假设我想把它们改成白色。感谢主要活动的图片。http://pctechtips.org/apps/activity.png菜单xml文件 activity_main.xml