修改jQuery进度条's基于Gridview列的颜色

Modifying jQuery progressbar's color based on Gridview column

本文关键字:基于 Gridview 颜色 jQuery 修改      更新时间:2023-09-26

我正试图根据gridview中每行的boloean值(布尔值)修改进度条的颜色。如果值为True,则颜色为绿色,如果值为False,则颜色将为红色。但由于某些原因,设置颜色的条件不起作用!

提前感谢:

Asp GridView代码:

<Columns>
<asp:TemplateField>
    <ItemTemplate>
        <%# Container.DataItemIndex + 1 %>
    </ItemTemplate>
</asp:TemplateField>
<asp:BoundField DataField="progress" HeaderText="Progress" SortExpression="progress" />
<asp:BoundField DataField="status" HeaderText="status" SortExpression="status" />
<asp:TemplateField>
<ItemTemplate>
   <div class="pbcontainer">
      <div class="progressbar"><span><%# Eval("progress") %>%</span></div>
      <div class="value" style="visibility:hidden; height:0; width:0;"> <%#         Eval("progress") %> </div>
      <div class="status" style="visibility:hidden; height:0; width:0;"> <%# Eval("status") %> </div>
  </div>
</ItemTemplate>
</asp:TemplateField>
</Columns>

脚本:

</style>
<link href="CSS/jquery-ui.css" rel="stylesheet" />
<script src="Scripts/jquery-1.9.1.js"></script>
<script src="Scripts/jquery-ui-1.10.3%20.js"></script>
<link rel="stylesheet" href="/resources/demos/style.css" />
<script>
    $(function () {
        $('.pbcontainer').each(function () {
            var val = parseInt($(".value", this).text());
            var status = $(".status", this).text();
            var progressColor = "Orange";
            var progressBackColor = "lightYellow";
            console.log(status);
            if (status == "False") {
                progressColor = "Red";
                //console.log("Condition met color red status Flase");
            }
            else if (status == "True") {
                progressColor = "Green";
                //console.log(progressColor);
                //console.log("Condition not met color Green status True");
            }
            $('.progressbar', this).progressbar({ value: val });
            $('.progressbar', this).css({ 'background': progressBackColor });
            $('.progressbar > div', this).css({ 'background': progressColor });
        });
    });
</script>

由于状态周围有多余的空白,因此条件不成立。。

你需要修改你的代码来修剪空白,就像这个

 var status = $.trim( $(".status", this).text() );

查看此演示http://jsfiddle.net/aXTcV/1/

试试这个:

<script type="text/javascript">
    $(function () {
        $('.pbcontainer').each(function () {
            var this_Progress = $(this);
            var val = parseInt($.trim(this_Progress.find('.value').text()));
            var status = $.trim(this_Progress.find('.status').text())
            var progressColor = "Orange";
            var progressBackColor = "lightYellow";
            console.log(status);
            if (status == "False") {
                progressColor = "Red";
                //console.log("Condition met color red status Flase");
            }
            else if (status == "True") {
                progressColor = "Green";
                //console.log(progressColor);
                //console.log("Condition not met color Green status True");
            }
            this_Progress.find('.progressbar').progressbar({ value: val });
            this_Progress.find('.ui-progressbar').css({ 'background': progressBackColor });
            this_Progress.find('.ui-progressbar-value').css({ 'background': progressColor });
        });
    });
</script>