如何把答题记录显示到页面上去


今天和娜姐做ITOO过程中做的是关于二次登陆的页面,业务流程大致是这样的:抽题;抽答题记录,然后把答题记录自动填写到页面上去。


问题:


因为ITOO的前台页面是动态加载的,代码如下:

  
List<duoxuantiRecordViewModel> queryduoxuanti = IQuerySqlServiceBll.QueryDuoxuantiRecord(studentID)<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">      </span>
  //遍历多选题,把多选题显示到界面上去  
for (int i = 0; i < queryduoxuanti.Count; i++)
            {
                int j = i + 1;          
                
                string questioncontent = queryduoxuanti[i].QuestionContent;
                string answer1 = queryduoxuanti[i].Answer1;
                string answer2 = queryduoxuanti[i].Answer2;
                string answer3 = queryduoxuanti[i].Answer3;
                string answer4 = queryduoxuanti[i].Answer4;


		//把学生填写的答案放examanwer变量里面
                string examanswer = queryduoxuanti[i].ExamAnswer;
                               
               	//把多选题动态显示到页面上去
                StudentExamQuestion.Append("<h2>" + j + "、" + questioncontent + "</h2>");
                StudentExamQuestion.Append("\r\n");
                StudentExamQuestion.Append("<input  name='sex' style='float:left;'/><h3> A:" + answer1 + "</h3>");
                StudentExamQuestion.Append("<input  name='sex' style='float:left;'/><h3> B:" + answer2 + "</h3>");
                StudentExamQuestion.Append("<input  name='sex' style='float:left;'/><h3> C:" + answer3 + "</h3>");
                StudentExamQuestion.Append("<input  name='sex' style='float:left;'/><h3> D:" + answer4 + "</h3>");


            }

所以我们没办法直接去view页面把自己的答题记录修改在页面上。


解决方案:


所以,我们用了三元表达式。

1. 什么是三元表达式?



采用三元操作符对?:对表达式进行运算,这种操作符比较特别,因为它有三个操作对象,但它确实属于操作符的一种,它最终也会生成一个值。其表达式采取下述形式:

boolean-exp ? value0 : value1


在表达式boolean-exp ? value0 : value1 中,如果“布尔表达式”的结果为true,就计算“value0”,而且这个计算结果也就是操作符最终产生的值。如果“布尔表达式”的结果为false,就计算“value1”,同样,它的结果也就成为了操作符最终产生的值。


当然,也可以换用普通的if-else语句(在后面介绍),但三元操作符更加简洁。尽管引以为傲的就是它是一种简练的语言,而且三元操作符的引入多半就是为了体现这种高效率的编程,但假如你打算频繁使用它,还是要先多作一些思量——因为它很容易就会产生可读性极差的代码。

这种条件操作符的使用目的,有时是为了它的“副作用”,有时是为了它运算生成的值。一般而言,我们需要的是其运算的结果值,这正是这个三元操作符与if-else不同之处。下面便是一个例子:


static int ternary(int i) {
	return i < 10 ? i * 100 : i * 10;
	}

可以看出,上面的代码比起不用三元操作符来说显得非常紧凑

static int alternative(int i) {
	if (i < 10)
	return i * 100;
	else
	return i * 10;
	}

第二种形式更易理解,而且不需要太多的录入。所以在选择使用三元操作符时,请务必仔细考量。

2.使用三元表达式之后的代码


  List<duoxuantiRecordViewModel> queryduoxuanti = IQuerySqlServiceBll.QueryDuoxuantiRecord(studentID);
            for (int i = 0; i < queryduoxuanti.Count; i++)
            {
                int j = i + 1;          
                
                string questioncontent = queryduoxuanti[i].QuestionContent;
                string answer1 = queryduoxuanti[i].Answer1;
                string answer2 = queryduoxuanti[i].Answer2;
                string answer3 = queryduoxuanti[i].Answer3;
                string answer4 = queryduoxuanti[i].Answer4;


                string examanswer = queryduoxuanti[i].ExamAnswer;
                               
               //使用三元表达式:(examanswer.Contains ("A" )? "checked" : " ")
                StudentExamQuestion.Append("<h2>" + j + "、" + questioncontent + "</h2>");
                StudentExamQuestion.Append("\r\n");
                StudentExamQuestion.Append("<input " + (examanswer.Contains ("A" )? "checked" : " ") + " type='checkbox' name='sex' style='float:left;'/><h3> A:" + answer1 + "</h3>");
                StudentExamQuestion.Append("<input " + (examanswer.Contains("B") ? "checked" : " ") + " type='checkbox' name='sex' style='float:left;'/><h3> B:" + answer2 + "</h3>");
                StudentExamQuestion.Append("<input " + (examanswer.Contains("C") ? "checked" : " ") + " type='checkbox' name='sex' style='float:left;'/><h3> C:" + answer3 + "</h3>");
                StudentExamQuestion.Append("<input " + (examanswer.Contains("D") ? "checked" : " ") + " type='checkbox' name='sex' style='float:left;'/><h3> D:" + answer4 + "</h3>");


            }

总结:

我和娜姐当时扯了很多有的没的逻辑办法,还是问了晨阳师姐,告诉我们了三元表达式才知道可以这样子解决问题。很多时候觉得自己学的还是不够,所以我觉得我需要补补知识,多查查网络。

转载于:https://www.cnblogs.com/tanqianqian/p/5975028.html

### 回答1: h5答题项目的html页面是用于展示答题内容和与用户进行交互的界面。页面通常由多个标签构成,每个标签有不同的功能和样式。 首先,页面通常会包含标题标签(例如`<h1>`或`<h2>`),用于显示答题项目的名称和描述,以吸引用户的注意力并让他们了解题目的内容。 接下来,页面会包含题目标签,比如用`<div>`或`<p>`标签来包裹一个或多个题目。题目可以是单选题、多选题或填空题,每个题目通常包含题目文本和选项。 为了让用户进行选择或填写答案,页面会包含选择框或输入框。比如,单选题可以使用`<input type="radio">`标签实现选择,多选题可以使用`<input type="checkbox">`标签实现多项选择,填空题可以使用`<input type="text">`标签实现填写。 页面还可以包含按钮标签,用于用户提交答案或进入下一题。按钮通常使用`<button>`标签,可以加上点击事件来实现特定的操作,例如验证答案或跳转到下一题。 为了给用户提供提示或额外的信息,页面还可以包含提示信息的标签,比如使用`<div>`或`<p>`标签来展示题目解析、正确答案或任何其他需要用户知道的信息。 最后,为了使页面更加美观和易于使用,可以应用CSS样式表到页面上。通过CSS,可以设计页面的布局、颜色、字体和其他视觉效果。 总之,h5答题项目的html页面是为了向用户展示题目、选项和交互界面,并通过CSS样式表提供美观的用户体验。 ### 回答2: H5答题项目的HTML页面是指使用HTML5技术开发的一个用于答题的网页。在该页面中通常会包含题目和选项,玩家需要根据题目选择正确的选项进行答题。 HTML5是一种用于构建和呈现Web页面的标准,它提供了一系列的新功能和API,包括用于增强用户交互和动态效果的Canvas和WebGL,以及用于媒体播放和音频处理的Video和Audio标签。 在H5答题项目的HTML页面中,题目和选项通常以文字和图片的形式呈现,可以使用HTML的文本标签(如<h1>、<p>)和图像标签(如<img>)来实现。 此外,为了使玩家能够选择答案,页面通常会包含单选或多选框,可以使用HTML的<input type="radio">和<input type="checkbox">实现。当玩家选择答案后,可以通过JavaScript代码来处理用户的选择,并给出反馈。 另外,为了提高用户体验和互动性,H5答题项目的HTML页面还可以包含倒计时计时器、进度条、动态效果等功能。这些可以使用HTML5的Canvas或CSS3的动画效果来实现。 总之,H5答题项目的HTML页面是以HTML5技术为基础的一个用于答题的网页,通过使用HTML的文本、图像、表单等元素,以及借助JavaScript和CSS实现各种功能和效果,帮助玩家进行答题和互动。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值