环境:VS2008,javascript,sql server2005
实现:在page1中的文本框textbox1中写入一行数据,然后将这行内容传递到page2中的变量string1中,再根据string1的值在ql server2005中like查询,根据结果集的行数动态生成表格,每一行都是一个热链接,热链接的内容对应数据库结果集的内容。
如何实现?多谢!

解决方案 »

  1.   

    page1应该还会有个button吧。page1.aspx//js方式:
    function OpenPage2(){
    var key=document.getElementById('textbox1').value;
    window.location.href='page2.aspx?k='+escape(key);//或者window.open('page2.aspx?k=''+escape(key)+'');
    }//ASP.NET button_OnClick事件Response.Redirect("page2.aspx?key="+Server.UrlEncode(textbox1.Text)) ;
    page2.aspx.cs//page_onlad事件里:
    public string tb="";
    string key=Server.UrlDecode(Request.QueryString["key"]);
    if(key!=null){
    DataTable dt= new getDt(key);
    StringBuilder buildTable=new StringBuilder();
    buildTable.Append("<table>");
    buildTable.Append("<tr><th>链接</th></tr>");
    for(int i=0;i<dt.Rows.Count;i++)
    {
    buildTable.Append("<tr><td>");
    buildTable.Append("<a href=\""+dt.Rows[i][0]+".aspx\">");
    buildTable.Append(dt.Rows[i][1]);
    buildTable.Append("</a></td></tr>");
    }
    buildTable.Append("</table>");
    tb=buildTable.ToString();
    }
    //页面上绑定
    <%=tb%>
      

  2.   

    还有个问题,那个button触发后的函数是先判断textbox1的值,为空的是后跳出模式对话框,不为空的时候跳出page2,这样那个button_OnClick事件就不能那样写了吧?我是初学js asp 很多地方都不是很清楚,谢谢哈!
    大概平判断的函数是这样写的:
     function fordecide(title,msg,w,h,v){//其中变量v是textbox1的内容
          var ti=title;
          var ms=msg;
          var w1=w;
          var h1=h;
          
          if(v=="")
          alertWin(ti,ms,w1,h1);//跳出模式对话框的函数
          if(v!=""){
            function OpenPage2(){
            var key=document.getElementById('textbox1').value;
            window.location.href='page2.aspx?k='+escape(key);//或者window.open('page2.aspx?k=''+escape(key)+'');
    }
         
         }
             
         }
      

  3.   

    上面有地方写错了,
     function fordecide(title,msg,w,h,v){
          var ti=title;
          var ms=msg;
          var w1=w;
          var h1=h;
          
          if(v=="")
          alertWin(ti,ms,w1,h1);
          if(v!=""){
          OpenPage2();
                 
         }
             
         }     function OpenPage2(){
            var key=document.getElementById('textbox1').value;
            window.location.href='page2.aspx?k='+escape(key);//或者window.open('page2.aspx?k=''+escape(key)+'');
    }
      

  4.   

    楼上的动态生成表格提供了很好的思路,多谢!
    但是对于使用stringbuilder 必须要应用名空间:using System.Text;对于传值:
    //js方式:
    function OpenPage2(){
    var key=document.getElementById('textbox1').value;
    window.location.href='page2.aspx?k='+escape(key);//或者window.open('page2.aspx?k=''+escape(key)+'');
    }
    只能前台传,我还没能在后台收到这个变量值后台页面间传值,在VS2008中调试通过的:
    一、使用Querystring 
    Querystring是一种非常简单的传值方式,其缺点就是会把要传送的值显示在浏览器的地址栏中,并且在此方法中不能够传递对象。如果你想传递一个安全性不是那么太重要或者是一个简单的数值时,用此方法最好不过了。下面通过一个小例子来完成传值工作,步骤如下: 
    1、创建一个web   form 
    2、在新建的web   form中放置一个button1,在放置两个TextBox1,TextBox2   
    3、为button按钮创建click事件 
    代码如下: 
    private   void   Button1_Click 
    (object   sender,   System.EventArgs   e) 

      string   url; 
      url= "webform2.aspx?name= "   +   
        TextBox1.Text   +   "&email= "   +   
        TextBox2.Text; 
      Response.Redirect(url); 

    4、新建一个目标页面命名为webform2 
    5、在webform2中放置两个Label1,Label2 
    在webform2的Page_Load中添加如下代码: 
    private   void   Page_Load 
    (object   sender,   System.EventArgs   e) 

      Label1.Text=Request.QueryString[ "name "]; 
      Label2.Text=Request.QueryString[ "email "]; 

    运行,即可看到传递后的结果了。 二、使用Session变量 使用Session变量传值是一种最常见的方式了,此中方式不仅可以把值传递到下一个页面,还可以交叉传递到多个页面,直至把Session变量的值removed后,变量才会消失。举个例子看看: 
    1、创建一个web   form 
    2、在新建的web   form中放置一个button1,在放置两个TextBox1,TextBox2   
    3、为button按钮创建click事件 
    代码如下: 
    private   void   Button1_Click 
    (object   sender,   System.EventArgs   e) 

                    Session[ "name "]=TextBox1.Text; 
      Session[ "email "]=TextBox2.Text; 
      Response.Redirect( "webform2.aspx "); 

    4、新建一个目标页面命名为webform2 
    5、在webform2中放置两个Label1,Label2 
    在webform2的Page_Load中添加如下代码: 
    private   void   Page_Load 
    (object   sender,   System.EventArgs   e) 

      Label1.Text=Session[ "name "].ToString(); 
      Label2.Text=Session[ "email "].ToString(); 
      Session.Remove( "name "); 
      Session.Remove( "email "); 

    运行,即可看到传递后的结果了。 三、使用Server.Transfer 
    虽然这种方法有点复杂,但也不失为一种在页面传值的方式。 
    举个例子看看: 
    1、创建一个web   form 
    2、在新建的web   form中放置一个button1,在放置两个TextBox1,TextBox2   
    3、为button按钮创建click事件 
    代码如下: 
    private   void   Button1_Click 
    (object   sender,   System.EventArgs   e) 

      Server.Transfer( "webform2.aspx "); 

    4、创建过程来返回TextBox1,TextBox2控件的值代码如下: 
    public   string   Name 

      get 
      { 
        return   TextBox1.Text; 
      } 
    } public   string   EMail 

      get 
      { 
        return   TextBox2.Text; 
      } 

    5、新建一个目标页面命名为webform2 
    6、在webform2中放置两个Label1,Label2 
    在webform2的Page_Load中添加如下代码: 
    private   void   Page_Load 
    (object   sender,   System.EventArgs   e) 

      //创建原始窗体的实例 
      WebForm1   wf1; 
      //获得实例化的句柄 
      wf1=(WebForm1)Context.Handler; 
      Label1.Text=wf1.Name; 
      Label2.Text=wf1.EMail; } 
    运行,即可看到传递后的结果了。 
    以上的方法除了transfer的没成功,其他的都成功了