Javascript实现GridView无刷新选择一行

Javascript可以实现对GridView中某一行选择,而无需进行页面的刷新。

首先要在GridViewonrowdataboundevent handler中为GridView中的每一行onclick绑定event handler (Javascript)。假如GridView代码如下:

        <asp:GridView runat="server" id="GridViewCategory" AutoGenerateColumns="False"

    Width="100%" BackColor="#CCCCCC" BorderColor="#999999" BorderStyle="Solid"

    BorderWidth="3px" CellPadding="4" CellSpacing="2"

ForeColor="Black" onrowdatabound="GridViewCategory_RowDataBound">

        <RowStyle BackColor="White" />

        <Columns>

            <asp:BoundField DataField="Description" HeaderText="Category" />

        </Columns>

        <FooterStyle BackColor="#CCCCCC" />

        <PagerStyle BackColor="#CCCCCC" ForeColor="Black" HorizontalAlign="Left" />                       

        <HeaderStyle BackColor="Black" Font-Bold="True" ForeColor="White" />

</asp:GridView>

onrowdataboundevent handler代码如下:

        protected void GridViewCategory_RowDataBound(object sender, GridViewRowEventArgs e)

        {

            try

            {

                if (e.Row.RowType == DataControlRowType.DataRow)

                {

                    e.Row.ID = e.Row.Cells[0].Text;

                    e.Row.Attributes.Add("onclick", "GridView_selectRow(this, '" + e.Row.Cells[0].Text + "')");

                }

            }

            catch (Exception ex)

            {

                throw new ApplicationException(ex.Message);

            }

        }

最后,GridView中每一行的onclick event handlerJavascript代码如下:

<script type="text/javascript">  

    var lastRowSelected;   

    function GridView_selectRow(row, description) {

        if (lastRowSelected != row) {

            if (lastRowSelected != null) {

                lastRowSelected.style.backgroundColor = 'White';

                lastRowSelected.style.color = 'Black';

            }

        }

        row.style.backgroundColor = '#000099';

        row.style.color = 'White';

        lastRowSelected = row;

        document.getElementById("<%=TextBoxCategory.ClientID%>").value = description;

    }

</script>

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值