该工具可就一些主题对访问者进行询问,页面上所有的字(除了按纽上的),全部由数据库读出,每个问卷的答案多少随便增减,也很方便查阅,关键代码如下,如果喜欢的朋友点连接下载全部源文件http://www.cnblogs.com/files/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 }
新闻热点
疑难解答