我们在做用户登陆的时,很多时候我们的密码是区分大小写的,这就存在一个问题.如果你的Caps Lock键是亮着的,尽管你输入的密码是对的,也无法登陆.所以我们有必要在Caps Lock被按下的时候,提示用户.这就是这篇文章所要讲的.
    你阅读过本文,你可以有一下几点收获
    1:拥有一个免费的插件(可以提示Caps Lock)
    2:你会对MicroSoft的验证控件有全新的认识(MicroSoft的验证控件的原理就是这样,当然比这复杂)
    3:你将了解到在Assembly嵌入外部resource

    MQTools控件
    本控件的功能:为web用户提供密码输入时的提示功能
    开发环境:.VS2005
    语言:Javascript,C#
   
   Details:
    mqTools是MicroSoft控件Label上的基础上扩展的.之所以选择Label是因为Label本身已经具体
Text, Font, Width, CssClass等属性,这样我们就可以显示提示信息和控件的外观,但还有一个最重要的属性是需要我们自己去完成的,就是TextBoxControlID属性.这样我们就能指定控件验证的对象.
    1:给Label扩展TextBoxControlID属性
   
 1给asp.net的textbox添加Caps Lock提示using System;
 2给asp.net的textbox添加Caps Lock提示using System.Collections.Generic;
 3给asp.net的textbox添加Caps Lock提示using System.Text;
 4给asp.net的textbox添加Caps Lock提示using System.Web;
 5给asp.net的textbox添加Caps Lock提示using System.Web.UI;
 6给asp.net的textbox添加Caps Lock提示using System.Web.UI.WebControls;
 9给asp.net的textbox添加Caps Lock提示namespace MQTools
10
    2:初始化时隐藏MQTools验证控件:
    我们知道Label被呈现在客户端是的代码是
给asp.net的textbox添加Caps Lock提示<span id="ID" >你已经按下了Caps Lock</span>
    因此想到了通过它的Style属性去空值它的Hidden和Show.所以我们得重写Label控件的AddAttributesToRender方法!其实微软的很多控件也是通过类似的扩展去控制显示,样式等等.
1给asp.net的textbox添加Caps Lock提示protected override void AddAttributesToRender(HtmlTextWriter writer)
2        }
  3:准备工作差不多了.那么我们怎么样去提示呢.由于是当用户开始输入的时候,我们就要提示,所以我想到了Client side代码Javasctipt的事件:onkeypress,所以我们下面要做的就是怎么使我们的输入框触发onkeypress事件!这时我们就要重写
   
 1给asp.net的textbox添加Caps Lock提示 protected override void OnPreRender(EventArgs e)
 2        }
    4:剩下的就是去完成我们的Javascript脚本了.这个没有什么好说的,直接看代码吧
}
    5:怎么在将js脚本嵌入assembly?请看下图,在类库中创建一个js文件,右键查看属性.在生成操作选择"嵌入资源".然后在类库的AssemblyInfo.cs中添加代码如下
   

给asp.net的textbox添加Caps Lock提示[assembly: WebResource("MQTools.JsLib.js""text/javascript")]
给asp.net的textbox添加Caps Lock提示[assembly: WebResource(
"MQTools.JScript1.js""text/javascript")]

    这样我们就可以使用这个js资源了代码如下
   
给asp.net的textbox添加Caps Lock提示// (1) 注册客户端脚本
给asp.net的textbox添加Caps Lock提示
                Page.ClientScript.RegisterClientScriptInclude("MQTools",
给asp.net的textbox添加Caps Lock提示                Page.ClientScript.GetWebResourceUrl(
this.GetType(),
给asp.net的textbox添加Caps Lock提示                                            
"MQTools.JsLib.js"));           
给asp.net的textbox添加Caps Lock提示
最后的效果图如下
给asp.net的textbox添加Caps Lock提示
总结:
    其实我们看到.这个控件自始至终没有任何难度.关键是你能想到怎么去做.特别是要了解控件的执行顺序,这样我们就可以在控件身上大作文章.

相关文章: