本人目前遇到一个难题,请各位高手、大侠帮帮忙。
我单击一个按钮时要把gridview中的数据一个一个的取出并把对应参数传递给前台的js。
我试了几种后台调前台的方式都没有成功,所以请大侠们帮帮小弟。
谢谢。

解决方案 »

  1.   

      this.RegisterStartupScript("a", "<script type='text/javascript'>函数名('参数');</script>");
    如:
      this.RegisterStartupScript("a", "<script type='text/javascript'>alert('删除成功!');</script>");
      

  2.   

    方法一:1、前台使用静态文本控件隐藏域,将js变量值写入其中;
           2、后台用request["id"]来获取值;
    方法二:可以用cookie或session
      

  3.   

    用前台的onclientclick事件 实现行??
      

  4.   

    Page.ClientScript.Reqiest...()这些方法都可以的
      

  5.   

    <tr>的lang设置一行的ID,点按钮时候,用jquery:
    var rows = $('#addCountryRow > tr');
    rows.each(function(){    if(this.lang == ''){获取到某一行}   });
      

  6.   

    在后可以取得GridView的每一行
    foreach(GridViewRow dr in GridView1.Rows)
    {
       this.RegisterStartupScript("a", " <script type='text/javascript'>函数名('参数'); </script>");
    }
      

  7.   

    、后台用request["id"]来获取值;  我一般用这<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head runat="server">
        <title></title>    <script language="javascript" type="text/javascript">    
        // 判断多选是否与选中项(没有选中的返回false)
        function slcNo_click()
        {
            if (document.form1.checkboxname.length)
            {
                for (var i=0;i<document.form1.checkboxname.length;i++)
                {
                    if(document.form1.checkboxname[i].checked)
                    {
                        return true;
                    }
                }
            }
            else
            {
                if(document.form1.checkboxname.checked)
                {
                    return true;
                }
            }
            alert("请选择后再操作!");
            return false;
        }
        
        // 鼠标经过改变行的颜色
        if (!objbeforeItem)
        {
            var objbeforeItem=null;
            var objbeforeItembackgroundColor=null;
        }    
        function ItemOver(obj)
        {
            if(objbeforeItem)
            {
                objbeforeItem.style.backgroundColor = objbeforeItembackgroundColor;
            }
            objbeforeItembackgroundColor = obj.style.backgroundColor;
            objbeforeItem = obj;
            obj.style.backgroundColor = "#B9D1F3";     
        }
        //        
     
        // 多选的全选与取消
        function checkJs(boolvalue)
        {
            if(document.all.checkboxname.length>1)
            {
                for(var i=0;i<document.all.checkboxname.length;i++)
                {
                    document.all.checkboxname[i].checked = boolvalue;            
                }
            }
            else
                document.all.checkboxname.checked = boolvalue;
        }
        //
        
        // 只有全部选中时“全选”选中
        function SingleCheckJs()
        {
            var flag1=false;
            var flag2=false;
            
            if (document.form1.checkboxname.length)
            {
                for (var i=0;i<document.form1.checkboxname.length;i++)
                {
                    if(document.form1.checkboxname[i].checked)
                        flag1 = true;
                    else
                        flag2 = true;
                }
            }
            else
            {
                if(document.form1.checkboxname.checked)
                    flag1 = true;
                else
                    flag2 = true;
            }
            
            if(flag1==true&&flag2==false)
                document.getElementById("chk").checked = true;
            else
                document.getElementById("chk").checked = false;
        }
        //
        </script>
    </head>
    <body>
        <form id="form1" runat="server">
            <div>
                <table cellpadding="0" cellspacing="0" border="0" width="80%" style="font-size: 11px">
                    <tr>
                        <td align="center">
                            <asp:GridView ID="GridView1" runat="server" Width="100%" CellPadding="4" ForeColor="#333333"
                                AutoGenerateColumns="False" AllowPaging="True" PageSize="12" BorderColor="Silver"
                                BorderStyle="Solid" BorderWidth="1px" OnRowDataBound="GridView1_RowDataBound"
                                ShowFooter="True" EmptyDataText="没有数据记录!!" AllowSorting="True" OnSorting="GridView1_Sorting">
                                <Columns>
                                    <asp:BoundField HeaderText="编号" DataField="id" Visible="False" />
                                    <asp:TemplateField HeaderText="&lt;input type='checkbox' id='chk' name='chk' onclick='checkJs(this.checked);'  /&gt;全选" FooterText="全选">
                                        <ItemTemplate>
                                            <input type="checkbox" id="checkboxname" name="checkboxname" value='<%# DataBinder.Eval(Container.DataItem, "id")%>' onclick='SingleCheckJs();' />
                                        </ItemTemplate>
                                    </asp:TemplateField>
                                    <asp:TemplateField HeaderText="单选" FooterText="单选">
                                        <ItemTemplate>
                                            <input type="radio" id="RadioName" name="RadioName" value='<%# Eval("id")%>' />
                                        </ItemTemplate>
                                    </asp:TemplateField>
                                    <asp:TemplateField HeaderText="自增列" FooterText="自增列">
                                        <ItemTemplate>
                                            <%# (Container.DataItemIndex+1).ToString()%>
                                        </ItemTemplate>
                                    </asp:TemplateField>
                                    <asp:BoundField HeaderText="姓名" FooterText="姓名" DataField="name" SortExpression="name" />
                                    <asp:BoundField HeaderText="身份证号" FooterText="身份证号" DataField="card" SortExpression="card" />
                                    <asp:BoundField HeaderText="价格" FooterText="价格" DataField="price" DataFormatString="{0:¥#,##0.00}"
                                        HtmlEncode="False" SortExpression="price" />
                                    <asp:BoundField HeaderText="数字" FooterText="数字" DataField="price" DataFormatString="{0:0.00}"
                                        HtmlEncode="False" SortExpression="price" />
                                    <asp:BoundField HeaderText="建立时间" FooterText="建立时间" DataField="createdate" DataFormatString="{0:yyyy年MM月dd日 hh时mm分ss秒}"
                                        HtmlEncode="False" SortExpression="createdate" />
                                </Columns>
                                <RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
                                <EditRowStyle BackColor="#999999" />
                                <SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" />
                                <PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
                                <AlternatingRowStyle BackColor="White" ForeColor="#284775" />
                                <PagerSettings Visible="False" />
                                <FooterStyle Font-Bold="True" />
                                <HeaderStyle Font-Bold="False" Font-Italic="False" />
                            </asp:GridView>
                        </td>
                    </tr>
                    <tr>
                        <td align="center" style="height: 25px">
                            <asp:LinkButton ID="btnFirst" CommandArgument="first" OnClick="PagerButtonClick"
                                runat="server">首 页</asp:LinkButton>
                            <asp:LinkButton ID="btnPrev" CommandArgument="prev" OnClick="PagerButtonClick" runat="server">上一页</asp:LinkButton>
                            <asp:LinkButton ID="btnNext" CommandArgument="next" OnClick="PagerButtonClick" runat="server">下一页</asp:LinkButton>
                            <asp:LinkButton ID="btnLast" CommandArgument="last" OnClick="PagerButtonClick" runat="server">尾 页</asp:LinkButton>
                            <asp:Label ID="LblCurrentIndex" runat="server"></asp:Label>
                            <asp:Label ID="LblPageCount" runat="server"></asp:Label>
                            <asp:Label ID="LblRecordCount" runat="server"></asp:Label></td>
                    </tr>
                    <tr>
                        <td>
                            <asp:Button ID="Button2" runat="server" Text="checkbox得到选择的行" OnClick="Button2_Click">
                            </asp:Button>
                            <asp:Button ID="Button1" runat="server" Text="radio得到选择的行" OnClick="Button1_Click"></asp:Button>
                        </td>
                    </tr>
                </table>
            </div>
        </form>
    </body>
    </html>
      

  8.   

    using System;
    using System.Data;
    using System.Configuration;
    using System.Collections;
    using System.Web;
    using System.Web.Security;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.WebControls.WebParts;
    using System.Web.UI.HtmlControls;
    using System.Data.SqlClient;public partial class gridview_fenpage : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            Button2.Attributes["onclick"] = "return slcNo_click();";
            GridViewBind("");
        }    private void GridViewBind(string Sqlsort)
        {
            string connStr = ConfigurationManager.ConnectionStrings["ConnString1"].ConnectionString;
            string SqlStr = "SELECT * FROM test01 where id<1000" + Sqlsort;
            DataSet ds = new DataSet();
            
            try
            {
                SqlConnection conn = new SqlConnection(connStr);
                if (conn.State.ToString() == "Closed") conn.Open();            SqlDataAdapter da = new SqlDataAdapter(SqlStr, conn);
                da.Fill(ds, "test01");            
                if (conn.State.ToString() == "Open") conn.Close();            GridView1.DataSource = ds.Tables[0].DefaultView;
                GridView1.DataBind();            LblCurrentIndex.Text = "第 " + (GridView1.PageIndex + 1).ToString() + " 页";
                LblPageCount.Text = "共 " + GridView1 .PageCount.ToString()+ " 页";
                LblRecordCount.Text = "总共 "+ds.Tables[0].Rows.Count.ToString()+" 条";
                if (ds.Tables[0].Rows.Count == 0)
                {
                    btnFirst.Visible = false;
                    btnPrev.Visible = false;
                    btnNext.Visible = false;
                    btnLast.Visible = false;                LblCurrentIndex.Visible = false;
                    LblPageCount.Visible = false;
                    LblRecordCount.Visible = false;
                }
                else if (GridView1.PageCount == 1)
                {
                    btnFirst.Visible = false;
                    btnPrev.Visible = false;
                    btnNext.Visible = false;
                    btnLast.Visible = false;
                }            // 计算生成分页页码,分别为:"首 页" "上一页" "下一页" "尾 页"
                btnFirst.CommandName = "1";
                btnPrev.CommandName = (GridView1.PageIndex == 0 ? "1" : GridView1.PageIndex.ToString());            btnNext.CommandName = (GridView1.PageCount == 1 ? GridView1.PageCount.ToString() : (GridView1.PageIndex + 2).ToString());
                btnLast.CommandName = GridView1.PageCount.ToString();
                //
            }
            catch(Exception ex)
            {
                Response.Write("数据库错误,错误原因:"+ex.Message);
                Response.End();
            }
        }
        protected void PagerButtonClick(object sender, EventArgs e)
        {
            GridView1.PageIndex = Convert.ToInt32(((LinkButton)sender).CommandName)-1;
            GridViewBind("");        
        }    protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
        {
            e.Row.Attributes["onmouseover"] = "ItemOver(this)";
        }    protected void Button2_Click(object sender, EventArgs e)
        {
            string str=""; 
            string []ckb=null;         str=Request.Form.Get("checkboxname"); 
            ckb=str.Split(new char[]{','});         Response.Write("直接在页面中得到的值为:"+str+"<br>");         Response.Write("处理后存放在数组中,如下:<br>"); 
            for(int i=0;i<ckb.Length;i++) 
            { 
                Response.Write("ckb["+i+"]的值为:"+ckb[i]+"<br>"); 
            } 
        }
        protected void Button1_Click(object sender, EventArgs e)
        {
            Response.Write(Request.Form.Get("RadioName"));
        }
        protected void GridView1_Sorting(object sender, GridViewSortEventArgs e)
        {
            string sql = "";        if (ViewState["SortDirection"] == null || ViewState["SortDirection"].ToString().CompareTo("") == 0)
            {
                ViewState["SortDirection"] = " desc";
            }
            else
                ViewState["SortDirection"] = "";        sql = " order by " + e.SortExpression + ViewState["SortDirection"];
            
            GridViewBind(sql);
        }
    }
      

  9.   

    在数据绑定时,写入JS代码。这里可以只写JS函数,具体的代码写在前台。
      

  10.   

    其实我要的是根据经纬度通过google map API返回的地址