各位大侠,我是新手。
所以请耐心帮我一下,先谢谢喽。现在是这样的,我打算做个简单的论坛(只有一个板块)我把发表的文章内容和回复的文章内容分别存在两张表里(我用的数据库是sql server 2008)我的开发工具是VS2008,语言是C#。我在设计浏览主题的时候,楼主的贴,我直接到一张表里查一把就出来了。关键是回复的部分。回复的部分,我做了一个Web用户控件,然后把控件放在gridview里然后 gridview的SqlSource.SelectCommand  是 select * from [table] where id= [ID] 这样就能知道具体有多少条回复,浏览时WEB页面里显示的模块也正常现在的问题就是,我不知道怎么分别把各条记录填到每个可能重复的Web用户控件中去注:Web用户控件中有 [re_content],[re_time],[re_author] 等标签真诚请教各位大侠应该如何处理。谢谢!

解决方案 »

  1.   


    WebUserControl.ascx:<%@ Control Language="C#" AutoEventWireup="true" CodeFile="WebUserControl.ascx.cs" Inherits="WebUserControl" %>
    <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>WebUserControl.ascx.cs: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;public partial class WebUserControl : System.Web.UI.UserControl
    {
      string a = "ok";
      public string A
      {
        set {
          a = value;
        }
        get
        {
          return a;
        }
      }
        protected void Page_Load(object sender, EventArgs e)
        {
          TextBox1.Text = A;
        }
      
    }
    调用:<%@ Page Language="C#" %><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><script runat="server">  protected void Page_Load( object sender, EventArgs e )
      {
        WebUserControl a = (WebUserControl)Page.LoadControl("~/WebUserControl.ascx");
        a.A = "xxx";
        form1.Controls.Add(a);
      }
    </script><html xmlns="http://www.w3.org/1999/xhtml" >
    <head runat="server">
        <title>无标题页</title>
    </head>
    <body>
        <form id="form1" runat="server">
       
        </form>
    </body>
    </html>http://www.cnblogs.com/terryding/archive/2008/02/01/1061062.html不要完全按照这种格式写,看明白就可以了.主要就是   .Controls.Add(a); 还有那个类的写发,照葫芦画瓢,用几次就会了.
    这个叫"动态添加用户控件",搜索这个词能搜索到很多例子.
      

  2.   

    那你这个不是没有用到dataset 或者 sqldatareader什么的嘛?
      

  3.   

    我想问下2L, 我用你的方法结果问题来了  找不到类型或命名空间名称"WebUserControl"
       这个用户控件需要using什么?
      

  4.   

    你要把他这里的WebUserControl改成你写的那个WebUserControl的CS文件里public partial class XXX : System.Web.UI.UserControl
    class后面的那个的XXX a = (XXX)Page.LoadControl("WebUserControl的路径");
      

  5.   

    不过用的着这么写吗?
    WebUserControl.ascx:<%@ Control Language="C#" AutoEventWireup="true" CodeFile="WebUserControl.ascx.cs" Inherits="WebUserControl" %>
    <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>WebUserControl.ascx.cs: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;public partial class WebUserControl : System.Web.UI.UserControl
    {
      string a = "ok";
      public string A
      {
        set {
          a = value;
        }
        get
        {
          return a;
        }
      }
        protected void Page_Load(object sender, EventArgs e)
        {
          TextBox1.Text = A;
        }
      
    }然后直接把用户控件拖到页面上
     <uc1:WebUserControl1 ID="WebUserControl1_1" A="哈哈" runat="server" />   加上A=“xxx”就是动态添加用户控件了,这个xxx用个变量这样不就行了吗
      

  6.   

    把对应的名字都修改成你的用户控件的名字.
    这里的WebUserControl是个类,和普通的类是一样的,如果不在同一个namespace下就using一下.
    这种动态添加用户控件的方法我以前用过的,是可以的.
      

  7.   

    我本来里面有这句的
    SqlDataSource2.SelectCommand = "SELECT * FROM [restore] where [leave_word_id] =" + ID;
    有多少条回复就重复多少个控件
    但是二楼的form1.Controls.Add(a);
    就又加了这么多个控件。如果想把值填到我原来SqlDataSource2.SelectCommand = "SELECT * FROM [restore] where [leave_word_id] =" + ID;
    得出来的那些重复的控件上,应该怎么写。