关键代码如下,如果喜欢的朋友点连接下载全部源文件https://files.cnblogs.com/thcjp/survey.rar
1//第一步把调查标题和欢迎词查询出来
2 DataTable dt=db.fill("select name,instruc from survey where id="+sid+"");//把数据从数据库检索到本地表中来
3 title.Text=dt.Rows[0]["name"].ToString();//将标题文本设置为本地表中的第一列(如果不喜欢这里是0,那你设成1嘛,我不负责哈,CPU会爆炸的),列名字为name的值
4 cw.Text=dt.Rows[0]["instruc"].ToString();//这是用户第一次进来显示的字
5
6 //第二步有点复杂,各位看官用心看了,前面我们不是放了一个空的panel控件嘛,下面要做的就是把所有的问题给查询出来,并放到所有需要的控件中,然后再把控件给放到panel里面,这也是这个例题的关键所在
7 DataTable qdt=db.fill("select qid,qlong from question where id="+sid+"");//把问题ID和问题检索出来放在本地内存表QDT中,备用;
8 for(int i=0;i<qdt.Rows.Count;i++)//进入代码段的外层循环,处理调查的每个问题
9 {
10
11 LiteralControl html=new LiteralControl();//literalControl是一个非常基础的控件,用与把HTML脚本动态插入到当前页中去
12 html.Text=qdt.Rows[i]["qlong"].ToString()+":";//把文字交给新控件
13 Panel1.Controls.Add(html);//将赋值后的控件加入到panel1中去
14
15 DropDownList ddl=new DropDownList();//声明一个 dropdownlist 对象
16 string qid=qdt.Rows[i]["qid"].ToString();//把当前问题的ID保存在临时变量中
17 ddl.ID="q"+qid;//给控件加个名字 q 以后,该下拉列表的名字就成了 q1 ,q2这样的了,你有权利不信,出去看下编译后网页的源文件就知道啦
18
19 DataTable adt=db.fill("select answer from answer where qid="+qid+"");//查询出所有这个问题的答案
20 //下面就可以进入代码的层循环了,负责处理问题的每个答案
21 for(int j=0;j<adt.Rows.Count;j++)
22 {
23 ListItem li=new ListItem();//实例化一个新的数据项,每个答案就直接交给该实例项就OK了
24 li.Text=adt.Rows[j]["answer"].ToString();//赋值
25 ddl.Items.Add(li);//放到dropdownlist控件中去
26 }
27 Panel1.Controls.Add(ddl);//把DorpDownList控件加入到Panel里面去
28 LiteralControl html1=new LiteralControl();//最后当然是加个分隔符咯
29 html1.Text="<p>";//我想不用说了吧
30 Panel1.Controls.Add(html1);//我想不用说了吧
31 }
2 DataTable dt=db.fill("select name,instruc from survey where id="+sid+"");//把数据从数据库检索到本地表中来
3 title.Text=dt.Rows[0]["name"].ToString();//将标题文本设置为本地表中的第一列(如果不喜欢这里是0,那你设成1嘛,我不负责哈,CPU会爆炸的),列名字为name的值
4 cw.Text=dt.Rows[0]["instruc"].ToString();//这是用户第一次进来显示的字
5
6 //第二步有点复杂,各位看官用心看了,前面我们不是放了一个空的panel控件嘛,下面要做的就是把所有的问题给查询出来,并放到所有需要的控件中,然后再把控件给放到panel里面,这也是这个例题的关键所在
7 DataTable qdt=db.fill("select qid,qlong from question where id="+sid+"");//把问题ID和问题检索出来放在本地内存表QDT中,备用;
8 for(int i=0;i<qdt.Rows.Count;i++)//进入代码段的外层循环,处理调查的每个问题
9 {
10
11 LiteralControl html=new LiteralControl();//literalControl是一个非常基础的控件,用与把HTML脚本动态插入到当前页中去
12 html.Text=qdt.Rows[i]["qlong"].ToString()+":";//把文字交给新控件
13 Panel1.Controls.Add(html);//将赋值后的控件加入到panel1中去
14
15 DropDownList ddl=new DropDownList();//声明一个 dropdownlist 对象
16 string qid=qdt.Rows[i]["qid"].ToString();//把当前问题的ID保存在临时变量中
17 ddl.ID="q"+qid;//给控件加个名字 q 以后,该下拉列表的名字就成了 q1 ,q2这样的了,你有权利不信,出去看下编译后网页的源文件就知道啦
18
19 DataTable adt=db.fill("select answer from answer where qid="+qid+"");//查询出所有这个问题的答案
20 //下面就可以进入代码的层循环了,负责处理问题的每个答案
21 for(int j=0;j<adt.Rows.Count;j++)
22 {
23 ListItem li=new ListItem();//实例化一个新的数据项,每个答案就直接交给该实例项就OK了
24 li.Text=adt.Rows[j]["answer"].ToString();//赋值
25 ddl.Items.Add(li);//放到dropdownlist控件中去
26 }
27 Panel1.Controls.Add(ddl);//把DorpDownList控件加入到Panel里面去
28 LiteralControl html1=new LiteralControl();//最后当然是加个分隔符咯
29 html1.Text="<p>";//我想不用说了吧
30 Panel1.Controls.Add(html1);//我想不用说了吧
31 }