您的位置:首页 > 其它

[翻译]用表单字段加亮的方式为用户提供友好的界面

2006-10-01 20:52 337 查看
摘要:这是一篇在www.asp.net找到的文章,详细地址在http://developer.bracora.com/Articles/FormHighlight.aspx,作者是Martin Millar。文章里有句话说的很好:

代码是很简单的。而当你做开发的时候,你有时候或许需要站在用户的角度想一想,因为他们每天八个小时在电脑前做这些数据录入做的时候,是多么的不容易的。

背景[/b][/b]

我们设计的程序往往会有这样的情况,就是一个表单上有很多的内容需要用户来填写,而对于一个不太熟练的用户来说,“看走眼”的事情会经常的发生。

解决方案[/b][/b]

如果当用户在表单里填写一个字段的同时我们把那个字段的颜色边一下,也就是背景颜色,那么会是这个字段明显区别于其它待填写或已填写好的字段,这样用户就可以很容易的找到当前所填写的是哪里。

在这个方案里我们把提交焦点并且出发事件的任务交给客户端的Javascript来完成,通过它,可以利用CSS来动态的改变一个控件的背景颜色。

具体实现[/b][/b]

首先,我们先看下最终效果。请留意下当前获得焦点的那个字段的颜色与其它控件的区别。

.normalfld
.focusfld

Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load
If Not Page.IsPostBack Then
SetHighlightFields(Page.Form)
Me.txtForename.Focus()
End If
End Sub

Sub SetHighlightFields(ByVal frm As Control)
Dim TempCheckbox As CheckBox = Nothing
Dim TempTextBox As TextBox = Nothing
For Each tmpctl As Control In frm.Controls
If TypeOf tmpctl Is TextBox Then
TempTextBox = CType(tmpctl, TextBox)
TempTextBox.Attributes.Add("onFocus", "DoFocus(this);")
TempTextBox.Attributes.Add("onBlur", "DoBlur(this);")
End If
Next
End Sub

Sub ClearFields(ByVal frm As Control)
For Each tmpctl As Control In frm.Controls
If TypeOf tmpctl Is TextBox Then
CType(tmpctl, TextBox).Text = ""
End If
Next
End Sub

做到这里所有的工作就都完成了。用户只要一通过单击或者Tab的方式使控件获得焦点,那么这个字段就会变成高亮的状态。

总结[/b][/b]

当你设计类似那种填写表单的web程序的时候,这篇文章还是提供了几个方法的。如您所见,代码是很简单的。而当你做开发的时候,你有时候或许需要站在用户的角度想一想,因为他们每天八个小时在电脑前做这些数据录入做的时候,是多么的不容易的。

关于作者[/b][/b]

作者是英国一家大型的telecoms and internet公司的程序开发人员。他专著于基于ASP.NET和SqlServer的Web开发,并且是微软的MCSD。在其业余时间开了一个叫做bracora的web设计的公司,http://www.bracora.com,你也可以直接访问他的博客http://www.martinmillar.co.uk

翻译心得:

翻译起来很憋嘴,但是从里面能理解作者的意思,所以干脆就是以自己的理解方式,当然,这种方式实际上是和大家交流和学习中总结出来的,出自于大家的习惯。而国外人思维跨度有时候很难被我们理解,不过,咱们能做的,就是try to understand what they want to tell。

学习心得:

正如作者所说,代码是很简单的。但是,我觉得其里面用到的这个循环编历表单上的控件的方法确实很实用。而对于Foreach的这个东西,说实在的,起初学c#那会儿,怎么的无法理解为什么要有这么一个东西,同是循环体结构却和for这样的结构有这么大的区别。看过这个代码,我想可以给很多初学者解释为什么其存在。不过,任何事物存在都是有其理由的,学习这个东西,就是这样,很多东西,你刚开始不会很理解,甚至理解不上去那个层次,而慢慢的,就会发现,原来这么设计真的是好啊。关键之处,就是不要放弃。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐