如何在JavaScript方法中获取ASP.NET DataGrid控件的选定行索引?

时间:2012-11-16 12:10:07

标签: c# javascript asp.net visual-studio-2008 datagrid

Default.aspx中使用了一个DataGrid,Requirement是在javascript方法中获取所选行的所有列的文本,以将其复制到剪贴板。目前,我正在执行此任务,但它选择Grid的所有行和将所有数据过去到剪贴板。

Default.aspx(示例文件)

<asp:GridView ID="ObjList" runat="server" OnLoad="xyz" AutoGenerateColumns="false" OnRowDataBound="ObjList_RowDataBound" AutoGenerateSelectButton="false"> 
<Columns>
  .
  .
  .
</Columns>

Sample Button调用javascript方法将数据复制到剪贴板。

<asp:ImageButton ID="BtnCopyToClipboard" ToolTip="Copy To Clipboard"   ImageUrl="img/tlb_list_copy.gif" OnClientClick="CopyGridView('ObjList'); return false;" runat="server" />

示例JavaScript函数:

function CopyGridView(gridId) {
var div = document.getElementById(gridId);

var sSelectedRowText = div.Rows[iPL_SelectedRowIndex].Value;
if (div != null) {
    div.contentEditable = 'true';
    var controlRange;
    if (document.body.createControlRange) {
        controlRange = document.body.createControlRange();
        controlRange.addElement(div);
        controlRange.execCommand('Copy');
        alert(InfoMsgClipboard);
    }
    div.contentEditable = 'false';
}
}

任何建议,如何识别网格中的选定行并仅复制剪贴板中选定的行数据。

1 个答案:

答案 0 :(得分:4)

function setSelectedRowId(RowId){
        document.getElementById("txtRowId").value = RowId; }

    private void ObjList_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
    {
       if (e.Item.ItemType == ListItemType.AlternatingItem || e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.SelectedItem)
       {
          e.Item.Attributes.Add("onclick", "setSelectedRowId('" + e.Item.Cells[0].Text + "');
       }