javascript技巧

转自:http://topic.csdn.net/u/20080527/10/7f580777-1a3d-44fc-8806-55f9d79d0c65.html

 

(一).确认删除用法:
  1. BtnDel.Attributes.Add(“onclick”,”return confirm(‘”+”确认删除 “+”‘)”);
  2. linktempDelete.Attributes[“onclick”]=”javascript:return  confirm(‘”+”确认删除 “+”‘);”;
  3. private void grdProject_ItemDataBound(object sender, DataGridItemEventArgs e)
  4.
  {
if ((e.Item.ItemType == ListItemType.Item) | (e.Item.ItemType == ListItemType.AlternatingItem))
{
  // 刪除按鈕上的提示部分
  e.Item.Cells[10].Attributes.Add(“onclick”, “return confirm(‘确定删除吗?’);”);

  }
  5.
    <script language=”JavaScript” type=”text/JavaScript”>
function delete_y(e)
        {
    if(event.srcElement.outerText == “删除”)
        event.returnValue=confirm(“确定删除 “);
}
document.onclick=delete_y;
    </script>

(二).跨语言字符串替换
    System.Text.RegularExpressions.Regex.Replace(str1,@” <{1}[^ <>]*>{1}”,””).Replace(“&nbsp;”,””).Replace(“&#092;”,”\\”).Replace(“&#045;”,”-“).Replace(“&amp;”,”&”).Replace(“&lt;”,” <“).Replace(“&gt;”,”>”).Replace(“br”,”\n”);

(三).关闭窗体
  1.
      this.btnClose.Attributes.Add(“onclick”,  “window.close();return false;”);
  2.关闭本窗体间跳转到另一个页面
      this.HyperLink1.NavigateUrl = “javascript:onclick=window.opener.location.assign
        (‘” + “index.aspx”+ ” &Func=Edit&AutoID=” + intAutoid + ‘);window.close();”;
  3.关闭父窗体:
      <INPUT type=”reset” value=’ <%=this._Cancel%>’ onclick=”window.parent.close()”  Class=”Button”>

  4.关闭本弹出窗体,并刷新父页面

      this.Response.Write(” <script language=’javascript’>window.opener.location.reload();window.close(); </script>”);

(四).Web MessageBox 
  1.
      Response.Write(” <script language=javascript> window.alert(‘保存成功1’); </script>”);
  2.
      Response.Write(” <script>alert(‘”+”保存成功!”+”‘); </script>”);
  3.
      this.Page.RegisterStartupScript(“ChiName”,” <script language=’javascript’>alert(‘” + “保存成功!” + “‘) </script>”);

(五).DataGrid中加CheckBox控件模板列.
  请看:  http://blog.csdn.net/chengking/archive/2005/10/08/497520.aspx

(六). window.open() 方法
语法:window.open(pageurl,name,parameters);
window对象的open()方法用于创建一个新的窗口实例,新创建的窗口的外观由参数:parameters指定。新窗口中打开的文档由参数:        pageurl指定。系统能够根据参数:name确定的名称访问该窗口。

        下表为parameters参数表:
        参数          衩始值          说明
        alwaysLowered yes/no 指定窗口隐藏在所有窗口之下。
        alwaysRaised yes/no 指定窗口浮在所有窗口之上。
        dependent yes/no 指定打开的窗口为父窗口的一个了窗口。并随父窗口的关闭而关闭。
        directions yes/no 指定Navigator 2和3的目录栏是否在新窗口中可见。
        height pixel value 设定新窗口的像素高度。
        hotkeys yes/no 在没有菜单栏的新窗口设置安全退出热键。
        innerHeight pixel value 设置新窗口中文档的像素高度。
        innerWidth pixel value 设置新窗口中文档的像素宽度。
        location yes/ no 指明位置栏在新窗口中是否可见。
        menubar yes /no 指明菜单栏在新窗口中是否可见。
        outerHeight pixel value 设定窗口(包括装饰边框)的像素高度。
        outerWidth pixel value 设定窗口(包括装饰边框)的像素宽度。
        resizable yes /no 指明新窗口是否可以调整。
        screenX pixel value 设定新窗口离屏幕边界的像素长度。
        screenY pixel value 设定新窗口离屏幕上边界的像素长度。
        scrollbars yes /no 指明滚动栏在新窗口中是否可见。
        titlebar yes /no 指明菜单题目栏在新窗口是否可见。
        toolbar yes /no 指明工具栏在新窗口中是否可见。
        Width pixel value 设定窗口的像素宽度。
        z-look yes /no 在文档中包含各个 <pplet>标签的数组。
        fullscreen yes / no 打开的窗体是否进行全屏显示
        left pixel value 设定新窗口距屏幕左方的距离
        top pixel value 设定新窗口距屏幕上方的距离
 
      例子:
        <html>
          <head>
              <title>window.open函数 </title>
          </head>
          <body>
              <script language=”javascript”>
                  <!–
                window.open(“”,”name1″,”width=100,height=200,toolbar=no,scrollbars=no,menubar=no,screenX=100,screenY=100″);
                    //–>
              </script>
          </body>
        </html>

(七).location对象   
    href 整个URL字符串.
    protocol 含有URL第一部分的字符串,如http:
    host 包含有URL中主机名:端口号部分的字符串.如//www.cenpok.net/server/
    hostname 包含URL中主机名的字符串.如http://www.cenpok.net
    port 包含URL中可能存在的端口号字符串.
    pathname URL中”/”以后的部分.如~list/index.htm
    hash “#”号(CGI参数)之后的字符串.
    search ” “号(CGI参数)之后的字符串.

(八).按键捕捉
  1.Ctrl+Enter按键捕捉方法
    <body onkeydown=”doKeyDown()”>
    <script language=”JavaScript”>
    <!–
    function doKeyDown()
    {
        if (event.ctrlKey && event.keyCode == 13)
        {
          alert(“You pressed the Ctrl + Enter”)
        }
    }
    //–>
    </script>
    </body>
  2.Alt加快捷键: Alt+A
    <button accessKey=A title=”Alt+A” onclick=”alert(‘Button clicked!’)”>Alt+A </button>
(九).控制输入,非法字符不能输入到TextBox.
    <asp:textbox class=”Text”
        onkeypress=”if (event.keyCode < 48 || event.keyCode >57) event.returnValue = false;”
id=”txtY_Revenue” style=”TEXT-ALIGN: right” runat=”server” Width=”90%” MaxLength=”12″>
    </asp:textbox>
    说明: 此方法控制TextBox只收数字:0~9 , 也自可以定义其它可输入字符,如改成: 65~123,只允许输入: a~z和A~Z 等.

[以下为收藏]

1>屏蔽功能类

1.1 屏蔽键盘所有键
<script language=”javascript”>
<!–
function document.onkeydown(){
  event.keyCode = 0;
  event.returnvalue = false;
}
–>
</script>

1.2 屏蔽鼠标右键

在body标签里加上oncontextmenu=self.event.returnvalue=false

或者

<script language=”javascript”>
<!–
function document.oncontextmenu()
{
  return false;
}
–>
</script>

function nocontextmenu()
{
    if(document.all) {
        event.cancelBubble=true;
        event.returnvalue=false;
        return false;
    }
}

或者

<body onmousedown=”rclick()” oncontextmenu= “nocontextmenu()”>

<script language=”javascript”>
<!–
function rclick()
{
    if(document.all) {
        if (event.button == 2){
            event.returnvalue=false;
        }
    }
}
–>
</script>

1.3 屏蔽 Ctrl+N、Shift+F10、F5刷新、退格键

<script language=”javascript”>
<!–
  //屏蔽鼠标右键、Ctrl+N、Shift+F10、F5刷新、退格键
function window.onhelp(){return false} //屏蔽F1帮助
//function KeyDown(){ 注:本文为引用,应用时发现此句无法实现,经调试采用下面语句代替,如此句可以应用请知道的人指点下,谢谢

function document.onkeydown() {
  if ((window.event.altKey)&&
      ((window.event.keyCode==37)||  //屏蔽 Alt+ 方向键 ←
      (window.event.keyCode==39))){  //屏蔽 Alt+ 方向键 →
    alert(“不准你使用ALT+方向键前进或后退网页!”);
    event.returnvalue=false;
    }

    /* 注:这还不是真正地屏蔽 Alt+ 方向键,
    因为 Alt+ 方向键弹出警告框时,按住 Alt 键不放,
    用鼠标点掉警告框,这种屏蔽方法就失效了。以后若
    有哪位高手有真正屏蔽 Alt 键的方法,请告知。*/

  if ((event.keyCode == 8) &&
      (event.srcElement.type != “text” &&
      event.srcElement.type != “textarea” &&
      event.srcElement.type != “password”) ||          //屏蔽退格删除键 
      (event.keyCode==116)||                            //屏蔽 F5 刷新键
      (event.ctrlKey && event.keyCode==82)){            //Ctrl + R
    event.keyCode=0;
    event.returnvalue=false;
    }
  if ((event.ctrlKey)&&(event.keyCode==78))  //屏蔽 Ctrl+n
    event.returnvalue=false;
  if ((event.shiftKey)&&(event.keyCode==121)) //屏蔽 shift+F10
    event.returnvalue=false;
  if (window.event.srcElement.tagName == “A” && window.event.shiftKey)
      window.event.returnvalue = false;  //屏蔽 shift 加鼠标左键新开一网页
  if ((window.event.altKey)&&(window.event.keyCode==115)){ //屏蔽Alt+F4
      window.showModelessDialog(“about:blank”,””,”dialogWidth:1px;dialogheight:1px”);
      return false;}
  }
/* 另外可以用 window.open 的方法屏蔽 IE 的所有菜单
第一种方法:
  window.open(“你的.htm”, “”,”toolbar=no,location=no,directories=no,menubar=no,scrollbars=no,resizable=yes,status=no,top=0,left=0″)
第二种方法是打开一个全屏的页面:
  window.open(“你的.asp”, “”, “fullscreen=yes”)
*/
//–>
</script>

html5新特性介绍之PageVisibilityAPI

   在HTML5的众多新特性中,有的新特性可能容易被人忽视,又或者不是主流新

特性,但不可忽略,因为估计以后越来越多浏览器支持.今天要介绍的,就是

chrome和ie 10都支持的一个很好的新特性:HTML5中的PageVisibility API,下面例

子讲解下.

   比如在web中,有的时候,用户会经常切换页面,把某个页面最小化后,可能很久时间都不打开某个页面了,要过很久再打开.又或者比如在浏览器中,会打开很多TAB同时,有时WEB应用

甚至想清楚了解用户究竟打开某个页看了多长时间,这个在以往,可能很难去做到(特别是判断

用户最小化或者切换了其他页的TAB).但现在HTML5中,提出了相关的规范API,叫

pagevisibility api,其WC3的规范在如下连接可以找到描述:

http://dvcs.w3.org/hg/webperf/raw-file/tip/specs/PageVisibility/Overview.html

   其中,DocumentVisibility是其接口,有两个属性:document.hidden和

document.visibilityState.

1)document.hidden属性:

     当用户隐藏了页面或者最小化时,该属性返回true

2)document.visibilityState

    返回当前页面的状态,分别为hidden(隐藏不可见),visiable(可见),preview(标准中认为是可选的,暂时没浏览器实现).

    我们先来看个具体的例子,请用chrome去浏览:http://www.samdutton.com/pageVisibility/

    这里例子中,当你新增加了一个TAB时,会发现音乐和动画停止了,当你再次切换回去

时,动画又会继续了,是不是很有趣呢 

     再来看具体的例子,代码如下:

<!DOCTYPE HTML>  
<html>  
<head>  
     <script type="text/javascript">  
          timer = 0;  
          function onLoad(){  
               document.addEventListener("visibilitychange",stateChanged);  
               document.addEventListener("webkitvisibilitychange", stateChanged);  
               document.addEventListener("msvisibilitychange", stateChanged);  
          }  
          function stateChanged(){  
               console.log(document.webkitVisibilityState);  
               if(document.hidden || document.webkitHidden || document.msHidden){  
                    //new tab or window minimized
                    timer = new Date().getTime();  
               }  
               else {  
                    alert('You were away for ' + (new Date().getTime()-timer)/1000+ ' seconds.')  
               }  
          }  
     </script>  
</head>  
<body onLoad="onLoad()">  
</body>  
</html>

    在上面的代码中,同样,在CHROME运行下,在LOAD事件中,监听了相关的

webkitvisibilitychange事件(这个在CHROME下),如果是IE 10,则是

msvisibilitychange事件,然后在回调函数中,开始了计算用户在页面停留的时间,

所以当你打开其他TAB页或者最小化后,再切换回原来这个页,则会JAVASCRIPT

弹出显示:你离开了页面多长时间

    要注意的是,在CHROME中,属性命名为webkitHidden,事件为 webkitvisibilitychange事件,而在IE 10中,属性为msHidden 和

msVisibilityState.

   参考资料:http://blogs.msdn.com/b/ie/archive/2011/07/08/using-pc-hardware-more-efficiently-in-html5-new-web-performance-apis-part-2.aspx

    http://code.google.com/chrome/whitepapers/pagevisibility.html

B/S开发中常用的javaScript

一、验证类
1、数字验证内
1.1 整数
1.2 大于0的整数 (用于传来的ID的验证)
1.3 负整数的验证
1.4 整数不能大于iMax
1.5 整数不能小于iMin
2、时间类
2.1 短时间,形如 (13:04:06)
2.2 短日期,形如 (2003-12-05)
2.3 长时间,形如 (2003-12-05 13:04:06)
2.4 只有年和月。形如(2003-05,或者2003-5)
2.5 只有小时和分钟,形如(12:03)
3、表单类
3.1 所有的表单的值都不能为空
3.2 多行文本框的值不能为空。
3.3 多行文本框的值不能超过sMaxStrleng
3.4 多行文本框的值不能少于sMixStrleng
3.5 判断单选框是否选择。
3.6 判断复选框是否选择.
3.7 复选框的全选,多选,全不选,反选
3.8 文件上传过程中判断文件类型
4、字符类
4.1 判断字符全部由a-Z或者是A-Z的字字母组成
4.2 判断字符由字母和数字组成。
4.3 判断字符由字母和数字,下划线,点号组成.且开头的只能是下划线和字母
4.4 字符串替换函数.Replace();
5、浏览器类
5.1 判断浏览器的类型
5.2 判断ie的版本
5.3 判断客户端的分辨率

6、结合类
6.1 email的判断。
6.2 手机号码的验证
6.3 身份证的验证

二、功能类
1、时间与相关控件类
1.1 日历
1.2 时间控件
1.3 万年历
1.4 显示动态显示时钟效果(文本,如OA中时间)
1.5 显示动态显示时钟效果 (图像,像手表)
2、表单类
2.1 自动生成表单
2.2 动态添加,修改,删除下拉框中的元素
2.3 可以输入内容的下拉框
2.4 多行文本框中只能输入iMax文字。如果多输入了,自动减少到iMax个文字(多用于短信发送)

3、打印类
3.1 打印控件
4、事件类
4.1 屏蔽右键
4.2 屏蔽所有功能键
4.3 –> 和<– F5 F11,F9,F1
4.4 屏蔽组合键ctrl+N
5、网页设计类
5.1 连续滚动的文字,图片(注意是连续的,两段文字和图片中没有空白出现)
5.2 html编辑控件类
5.3 颜色选取框控件
5.4 下拉菜单
5.5 两层或多层次的下拉菜单
5.6 仿IE菜单的按钮。(效果如rongshuxa.com的导航栏目)
5.7 状态栏,title栏的动态效果(例子很多,可以研究一下)
5.8 双击后,网页自动滚屏
6、树型结构。
6.1 asp+SQL版
6.2 asp+xml+sql版
6.3 java+sql或者java+sql+xml
7、无边框效果的制作
8、连动下拉框技术
9、文本排序
一、验证类
1、数字验证内
1.1 整数
/^(-|\+) \d+$/.test(str)
1.2 大于0的整数 (用于传来的ID的验证)
/^\d+$/.test(str)
1.3 负整数的验证
/^-\d+$/.test(str)
2、时间类
2.1 短时间,形如 (13:04:06)
function isTime(str)
{
var a = str.match(/^(\d{1,2})( (\d{1,2})\2(\d{1,2})$/);
if (a == null) {alert(‘输入的参数不是时间格式’); return false;}
if (a[1]>24 || a[3]>60 || a[4]>60)
{
alert(“时间格式不对”;
return false
}
return true;
}
2.2 短日期,形如 (2003-12-05)
function strDateTime(str)
{
var r = str.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/);
if(r==null)return false;
var d= new Date(r[1], r[3]-1, r[4]);
return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]);
}
2.3 长时间,形如 (2003-12-05 13:04:06)
function strDateTime(str)
{
var reg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2})\d{1,2})\d{1,2})$/;
var r = str.match(reg);
if(r==null)return false;
var d= new Date(r[1], r[3]-1,r[4],r[5],r[6],r[7]);
return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]&&d.getHours()==r[5]&&d.getMinutes()==r[6]&&d.getSeconds()==r[7]);
}
2.4 只有年和月。形如(2003-05,或者2003-5)
2.5 只有小时和分钟,形如(12:03)
3、表单类
3.1 所有的表单的值都不能为空
<input onblur=”if(this.value.replace(/^\s+|\s+$/g,’)==’)alert(‘不能为空!’)”>
3.2 多行文本框的值不能为空。
3.3 多行文本框的值不能超过sMaxStrleng
3.4 多行文本框的值不能少于sMixStrleng
3.5 判断单选框是否选择。
3.6 判断复选框是否选择.
3.7 复选框的全选,多选,全不选,反选
3.8 文件上传过程中判断文件类型
4、字符类
4.1 判断字符全部由a-Z或者是A-Z的字字母组成
<input onblur=”if(/[^a-zA-Z]/g.test(this.value))alert(‘有错’)”>
4.2 判断字符由字母和数字组成。
<input onblur=”if(/[^0-9a-zA-Z]/g.test(this.value))alert(‘有错’)”>
4.3 判断字符由字母和数字,下划线,点号组成.且开头的只能是下划线和字母
/^([a-zA-z_]{1})([\w]*)$/g.test(str)
4.4 字符串替换函数.Replace();
5、浏览器类
5.1 判断浏览器的类型
window.navigator.appName
5.2 判断ie的版本
window.navigator.appVersion
5.3 判断客户端的分辨率
window.screen.height; window.screen.width;

6、结合类
6.1 email的判断。
function ismail(mail)
{
return(new RegExp(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/).test(mail));
}
6.2 手机号码的验证
6.3 身份证的验证
function isIdCardNo(num)
{
if (isNaN(num)) {alert(“输入的不是数字!”; return false;}
var len = num.length, re;
if (len == 15)
re = new RegExp(/^(\d{6})() (\d{2})(\d{2})(\d{2})(\d{3})$/);
else if (len == 18)
re = new RegExp(/^(\d{6})() (\d{4})(\d{2})(\d{2})(\d{3})(\d)$/);
else {alert(“输入的数字位数不对!”; return false;}
var a = num.match(re);
if (a != null)
{
if (len==15)
{
var D = new Date(“19″+a[3]+”/”+a[4]+”/”+a[5]);
var B = D.getYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5];
}
else
{
var D = new Date(a[3]+”/”+a[4]+”/”+a[5]);
var B = D.getFullYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5];
}
if (!B) {alert(“输入的身份证号 “+ a[0] +” 里出生日期不对!”; return false;}
}
return true;
}
3.7 复选框的全选,多选,全不选,反选
<form name=hrong>
<input type=checkbox name=All onclick=”checkAll(‘mm’)”>全选<br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/><br/>
<input type=checkbox name=All2 onclick=”checkAll(‘mm2’)”>全选<br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>
</form>
<SCRIPT LANGUAGE=”JavaScript”>
function checkAll(str)
{
var a = document.getElementsByName(str);
var n = a.length;
for (var i=0; i<n; i++)
a[i].checked = window.event.srcElement.checked;
}
function checkItem(str)
{
var e = window.event.srcElement;
var all = eval(“document.hrong.”+ str);
if (e.checked)
{
var a = document.getElementsByName(e.name);
all.checked = true;
for (var i=0; i<a.length; i++)
{
if (!a[i].checked){ all.checked = false; break;}
}
}
else all.checked = false;
}
</SCRIPT>
3.8 文件上传过程中判断文件类型
<input type=file onchange=”alert(this.value.match(/^(.*)(\.)(.{1,8})$/)[3])”>
画图:
<OBJECT
id=S
style=”LEFT: 0px; WIDTH: 392px; TOP: 0px; HEIGHT: 240px”
height=240
width=392
classid=”clsid:369303C2-D7AC-11D0-89D5-00A0C90833E6″>
</OBJECT>
<SCRIPT>
S.DrawingSurface.ArcDegrees(0,0,0,30,50,60);
S.DrawingSurface.ArcRadians(30,0,0,30,50,60);
S.DrawingSurface.Line(10,10,100,100);
</SCRIPT>
写注册表:
<SCRIPT>
var WshShell = WScript.CreateObject(“WScript.Shell”;
WshShell.RegWrite (“HKCU\\Software\\ACME\\FortuneTeller\\”, 1, “REG_BINARY”;
WshShell.RegWrite (“HKCU\\Software\\ACME\\FortuneTeller\\MindReader”, “Goocher!”, “REG_SZ”;
var bKey = WshShell.RegRead (“HKCU\\Software\\ACME\\FortuneTeller\\”;
WScript.Echo (WshShell.RegRead (“HKCU\\Software\\ACME\\FortuneTeller\\MindReader”);
WshShell.RegDelete (“HKCU\\Software\\ACME\\FortuneTeller\\MindReader”;
WshShell.RegDelete (“HKCU\\Software\\ACME\\FortuneTeller\\”;
WshShell.RegDelete (“HKCU\\Software\\ACME\\”;
</SCRIPT>
TABLAE相关(客户端动态增加行列)
<HTML>
<SCRIPT LANGUAGE=”JScript”>
function numberCells() {
var count=0;
for (i=0; i < document.all.mytable.rows.length; i++) {
for (j=0; j < document.all.mytable.rows(i).cells.length; j++) {
document.all.mytable.rows(i).cells(j).innerText = count;
count++;
}
}
}
</SCRIPT>
<BODY onload=”numberCells()”>
<TABLE id=mytable border=1>
<TR><TH> </TH><TH> </TH><TH> </TH><TH> </TH></TR>
<TR><TD> </TD><TD> </TD><TD> </TD><TD> </TD></TR>
<TR><TD> </TD><TD> </TD><TD> </TD><TD> </TD></TR>
</TABLE>
</BODY>
</HTML>
1.身份证严格验证:

var aCity={11:”北京”,12:”天津”,13:”河北”,14:”山西”,15:”内蒙古”,21:”辽宁”,22:”吉林”,23:”黑龙江”,31:”上海”,32:”江苏”,33:”浙江”,34:”安徽”,35:”福建”,36:”江西”,37:”山东”,41:”河南”,42:”湖北”,43:”湖南”,44:”广东”,45:”广西”,46:”海南”,50:”重庆”,51:”四川”,52:”贵州”,53:”云南”,54:”西藏”,61:”陕西”,62:”甘肃”,63:”青海”,64:”宁夏”,65:”新疆”,71:”台湾”,81:”香港”,82:”澳门”,91:”国外”}

function cidInfo(sId){
var iSum=0
var info=””
if(!/^\d{17}(\d|x)$/i.test(sId))return false;
sId=sId.replace(/x$/i,”a”;
if(aCity[parseInt(sId.substr(0,2))]==null)return “Error:非法地区”;
sBirthday=sId.substr(6,4)+”-“+Number(sId.substr(10,2))+”-“+Number(sId.substr(12,2));
var d=new Date(sBirthday.replace(/-/g,”/”)
if(sBirthday!=(d.getFullYear()+”-“+ (d.getMonth()+1) + “-” + d.getDate()))return “Error:非法生日”;
for(var i = 17;i>=0;i –) iSum += (Math.pow(2,i) % 11) * parseInt(sId.charAt(17 – i),11)
if(iSum%11!=1)return “Error:非法证号”;
return aCity[parseInt(sId.substr(0,2))]+”,”+sBirthday+”,”+(sId.substr(16,1)%2 “男”:”女”
}
document.write(cidInfo(“380524198002300016″,”<br/>”;
document.write(cidInfo(“340524198002300019″,”<br/>”
document.write(cidInfo(“340524197711111111″,”<br/>”
document.write(cidInfo(“34052419800101001x”,”<br/>”;

2.验证IP地址
<SCRIPT LANGUAGE=”JavaScript”>
function isip(s){
var check=function(v){try{return (v<=255 && v>=0)}catch(x){return false}};
var re=s.split(“.”
return (re.length==4) (check(re[0]) && check(re[1]) && check(re[2]) && check(re[3])):false
}
var s=”202.197.78.129″;
alert(isip(s))
</SCRIPT>

3.加sp1后还能用的无边框窗口!!
<HTML XMLNS:IE>
<meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″>
<IEownload ID=”include” STYLE=”behavior:url(#default#download)” />
<title>Chromeless Window</title>
<SCRIPT LANGUAGE=”JScript”>
/*— Special Thanks For andot —*/
/*
This following code are designed and writen by Windy_sk <seasonx@163.net>
You can use it freely, but u must held all the copyright items!
*/
/*— Thanks For andot Again —*/
var CW_width = 400;
var CW_height = 300;
var CW_top = 100;
var CW_left = 100;
var CW_url = “/”;
var New_CW = window.createPopup();
var CW_Body = New_CW.document.body;
var content = “”;
var CSStext = “margin:1px;color:black; border:2px outset;border-style:expression(onmouseout=onmouseup=function(){this.style.borderStyle=’outset’}, onmousedown=function(){if(event.button!=2)this.style.borderStyle=’inset’});background-color:buttonface;width:16px;height:14px;font-size:12px;line-height:11px;cursorefault;”;
//Build Window
include.startDownload(CW_url, function(source){content=source});
function insert_content(){
var temp = “”;
CW_Body.style.overflow = “hidden”;
CW_Body.style.backgroundColor = “white”;
CW_Body.style.border = “solid black 1px”;
content = content.replace(/<a ([^>]*)>/g,”<a onclick=’parent.open(this.href);return false’ $1>”;
temp += “<table width=100% height=100% cellpadding=0 cellspacing=0 border=0>”;
temp += “<tr style=’;font-size:12px;background:#0099CC;height:20;cursor:default’ ondblclick=\”Max.innerText=Max.innerText==’1′ ‘2’:’1′;parent.if_max=!parent.if_max;parent.show_CW();\” onmouseup=’parent.drag_up(event)’ onmousemove=’parent.drag_move(event)’ onmousedown=’parent.drag_down(event)’ onselectstart=’return false’ oncontextmenu=’return false’>”;
temp += “<td style=’color:#ffffff;padding-left:5px’>Chromeless Window For IE6 SP1</td>”;
temp += “<td style=’color:#ffffff;padding-right:5px;’ align=right>”;
temp += “<span id=Help onclick=\”alert(‘Chromeless Window For IE6 SP1 – Ver 1.0\\n\\nCode By Windy_sk\\n\\nSpecial Thanks For andot’)\” style=\””+CSStext+”font-family:System;padding-right:2px;\”> </span>”;
temp += “<span id=Min onclick=’parent.New_CW.hide();parent.blur()’ style=\””+CSStext+”font-family:Webdings;\” title=’Minimum’>0</span>”;
temp += “<span id=Max onclick=\”this.innerText=this.innerText==’1′ ‘2’:’1′;parent.if_max=!parent.if_max;parent.show_CW();\” style=\””+CSStext+”font-family:Webdings;\” title=’Maximum’>1</span>”;
temp += “<span id=Close onclick=’parent.opener=null;parent.close()’ style=\””+CSStext+”font-family:System;padding-right:2px;\” title=’Close’>x</span>”;
temp += “</td></tr><tr><td colspan=2>”;
temp += “<div id=include style=’overflow:scroll;overflow-x:hidden;overflow-y:auto; HEIGHT: 100%; width:”+CW_width+”‘>”;
temp += content;
temp += “</div>”;
temp += “</td></tr></table>”;
CW_Body.innerHTML = temp;
}
setTimeout(“insert_content()”,1000);
var if_max = true;
function show_CW(){
window.moveTo(10000, 10000);
if(if_max){
New_CW.show(CW_top, CW_left, CW_width, CW_height);
if(typeof(New_CW.document.all.include)!=”undefined”{
New_CW.document.all.include.style.width = CW_width;
New_CW.document.all.Max.innerText = “1”;
}

}else{
New_CW.show(0, 0, screen.width, screen.height);
New_CW.document.all.include.style.width = screen.width;
}
}
window.onfocus = show_CW;
window.onresize = show_CW;
// Move Window
var drag_x,drag_y,draging=false
function drag_move(e){
if (draging){
New_CW.show(e.screenX-drag_x, e.screenY-drag_y, CW_width, CW_height);
return false;
}
}
function drag_down(e){
if(e.button==2)return;
if(New_CW.document.body.offsetWidth==screen.width && New_CW.document.body.offsetHeight==screen.height)return;
drag_x=e.clientX;
drag_y=e.clientY;
draging=true;
e.srcElement.setCapture();
}
function drag_up(e){
draging=false;
e.srcElement.releaseCapture();
if(New_CW.document.body.offsetWidth==screen.width && New_CW.document.body.offsetHeight==screen.height) return;
CW_top = e.screenX-drag_x;
CW_left = e.screenY-drag_y;
}
</SCRIPT>
</HTML>
电话号码的验证
要求:
  (1)电话号码由数字、”(“、””和”-“构成
  (2)电话号码为3到8位
  (3)如果电话号码中包含有区号,那么区号为三位或四位
  (4)区号用”(“、””或”-“和其他部分隔开
  (5)移动电话号码为11或12位,如果为12位,那么第一位为0
  (6)11位移动电话号码的第一位和第二位为”13″
  (7)12位移动电话号码的第二位和第三位为”13″
  根据这几条规则,可以与出以下正则表达式:
  (^[0-9]{3,4}\-[0-9]{3,8}$)|(^[0-9]{3,8}$)|(^\([0-9]{3,4}\)[0-9]{3,8}$)|(^0{0,1}13[0-9]{9}$)
<script language=”javascript”>
function PhoneCheck(s) {
var str=s;
var reg=/(^[0-9]{3,4}\-[0-9]{3,8}$)|(^[0-9]{3,8}$)|(^\([0-9]{3,4}\)[0-9]{3,8}$)|(^0{0,1}13[0-9]{9}$)/
alert(reg.test(str));
}

<input type=text name=”iphone”>
<input type=button onclick=”PhoneCheck(document.all.iphone.value)” value=”Check”>
具有在输入非数字字符不回显的效果,即对非数字字符的输入不作反应。
function numbersonly(field,event){
var key,keychar;
if(window.event){
key = window.event.keyCode;
}
else if (event){
key = event.which;
}
else{
return true
}
keychar = String.fromCharCode(key);
if((key == null)||(key == 0)||(key == 8)||(key == 9)||(key == 13)||(key == 27)){
return true;
}
else if((“0123456789.”.indexOf(keychar)>-1){
window.status = “”;
return true;
}
else {
window.status = “Field excepts numbers only”;
return false;
}
}
验证ip
str=document.RegExpDemo.txtIP.value;
if(/^(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})$/.test(str)==false)
{
window.alert(‘错误的IP地址格式’);
document.RegExpDemo.txtIP.select();
document.RegExpDemo.txtIP.focus();
return;
}
if(RegExp.$1<1 || RegExp.$1>254||RegExp.$2<0||RegExp.$2>254||RegExp.$3<0||RegExp.$3>254||RegExp.$4<1||RegExp.$4>254)
{
window.alert(‘错误的IP地址’);
document.RegExpDemo.txtIP.select();
document.RegExpDemo.txtIP.focus();
return;
}
//剔除 如 010.020.020.03 前面 的0
var str=str.replace(/0(\d)/g,”$1″;
str=str.replace(/0(\d)/g,”$1″;
window.alert(str);
//一下是取数据的类
//Obj参数指定数据的来源(限定Table),默认第一行为字段名称行
//GetTableData类提供MoveNext方法,参数是表的行向上或向下移动的位数,正数向下移动,负数向上.
//GetFieldData方法获得指定的列名的数据
//Sort_desc方法对指定的列按降序排列
//Sort_asc方法对指定的列按升序排列
//GetData方法返回字段值为特定值的数据数组,提供数据,可以在外部进行其他处理
//Delete方法删除当前记录,数组减少一行
//初始化,Obj:table的名字,Leftlen:左面多余数据长度,Rightlen:右面多余数据长度,
function GetTableData(Obj,LeftLen,RightLen){
var MyObj=document.all(Obj);
var iRow=MyObj.rows.length;
var iLen=MyObj.rows[0].cells.length;
var i,j;
TableData=new Array();
for (i=0;i< iRow;i++){
TableData[i]=new Array();
for (j=0;j<iLen;j++){
TableStr=MyObj.rows(i).cells(j).innerText;
TableStr=TableStr.substring(LeftLen, TableStr.length-RightLen).Trim();
TableStr=TableStr.replace(/ /gi,””.replace(/\r\n/ig,””;
TableData[i][j]=TableStr;
}
}

this.TableData=TableData;
this.cols=this.TableData[0].length;
this.rows=this.TableData.length;
this.rowindex=0;
}
function movenext(Step){
if (this.rowindex>=this.rows){
return
}
if (Step==”” || typeof(Step)==”undefined” {
if (this.rowindex<this.rows-1)
this.rowindex++;
return;
}
else{
if (this.rowindex + Step<=this.rows-1 && this.rowindex + Step>=0 {
this.rowindex=this.rowindex + Step;
}
else
{
if (this.rowindex + Step<0){
this.rowindex= 0;
return;
}
if (this.rowindex + Step>this.rows-1){
this.rowindex= this.rows-1;
return;
}
}
}
}
function getfielddata(Field){
var colindex=-1;
var i=0;
if (typeof(Field) == “number”{
colindex=Field;
}
else
{
for (i=0;i<this.cols && this.rowindex<this.rows ;i++){
if (this.TableData[0][i]==Field){
colindex=i;
break;
}
}
}
if (colindex!=-1) {
return this.TableData[this.rowindex][colindex];
}
}

function sort_desc(){//降序
var colindex=-1;
var highindex=-1;
desc_array=new Array();
var i,j;
for (n=0; n<arguments.length; n++){
Field=arguments[arguments.length-1-n];
for (i=0;i<this.cols;i++){
if (this.TableData[0][i]==Field){
colindex=i;
break;
}
}
if ( colindex==-1
return;
else
{
desc_array[0]=this.TableData[0];
for(i=1;i<this.rows;i++){
desc_array[i]=this.TableData[1];
highindex=1;
for(j=1;j<this.TableData.length;j++){
if (desc_array[i][colindex]<this.TableData[j][colindex]){
desc_array[i]=this.TableData[j];
highindex=j;
}

}
if (highindex!=-1)
this.TableData=this.TableData.slice(0,highindex).concat(this.TableData.slice(highindex+1,this.TableData.length));
}
}
this.TableData=desc_array;
}
return;
}

function sort_asc(){//升序
var colindex=-1;
var highindex=-1;
var i,j;
for (n=0; n<arguments.length; n++){
asc_array=new Array();
Field=arguments[arguments.length-1-n];
for (i=0;i<this.cols;i++){
if (this.TableData[0][i]==Field){
colindex=i;
break;
}
}
if ( colindex==-1
return;
else
{
asc_array[0]=this.TableData[0];
for(i=1;i<this.rows;i++){
asc_array[i]=this.TableData[1];
highindex=1;
for(j=1;j<this.TableData.length;j++){//找出最小的列值
if (asc_array[i][colindex]>this.TableData[j][colindex]){
asc_array[i]=this.TableData[j];
highindex=j;

}

}
if (highindex!=-1)
this.TableData=this.TableData.slice(0,highindex).concat(this.TableData.slice(highindex+1,this.TableData.length));

}
}
this.TableData=asc_array;
}
return;
}
function getData(Field,FieldValue){
var colindex=-1;
var i,j;
GetData=new Array();
if (typeof(Field)==”undefined” || typeof(FieldValue)==”undefined” {
return this.TableData;
}

for(j=0;j<this.cols;j++){
if (this.TableData[0][j]==Field){
colindex=j;
}
}
if (colindex!=-1){

for(i=1;i<this.rows;i++){
if (this.TableData[i][colindex]==FieldValue){
GetData[i]=new Array();
GetData[i]=this.TableData[i];
}
}
}
return GetData;
}
function DeletE(){
this.TableData=this.TableData.slice(0,this.rowindex).concat(this.TableData.slice(this.rowindex+1,this.TableData.length));
this.rows=this.TableData.length;
return;
}
function updateField(Field,FieldValue){
var colindex=-1;
var i=0;
if (typeof(Field) == “number”{
colindex=Field;
}
else
{
for (i=0;i<this.cols && this.rowindex<this.rows ;i++){
if (this.TableData[0][i]==Field){
colindex=i;
break;
}
}
}
if (colindex!=-1) {
this.TableData[this.rowindex][colindex]=FieldValue;
}
}
function movefirst(){
this.rowindex=0;
}
function movelast(){
this.rowindex=this.rows-1;
}
function String.prototype.Trim() {return this.replace(/(^\s*)|(\s*$)/g,””;}
GetTableData.prototype.MoveNext = movenext;
GetTableData.prototype.GetFieldData = getfielddata;
GetTableData.prototype.Sort_asc = sort_asc;
GetTableData.prototype.Sort_desc = sort_desc;
GetTableData.prototype.GetData = getData;
GetTableData.prototype.Delete = DeletE;
GetTableData.prototype.UpdateField = updateField;
GetTableData.prototype.MoveFirst = movefirst;
具体的例子:http://202.119.73.208/NetEAn/com/test/jsprint.htm
在每个文本框的onblur事件中调用校验代码,并且每个文本框中onKeyDown事件中写一个enter转tab函数
//回车键换为tab
function enterToTab()
{
if(event.srcElement.type != ‘button’ && event.srcElement.type != ‘textarea’
&& event.keyCode == 13)
{
event.keyCode = 9;
}
}
有时候还需要自由编辑表格—
给大家一个自由编辑表格的小例子,写的有点乱,呵呵:)
//===============================start================================
<HTML>
<HEAD>
<META http-equiv=”Content-Type” content=”text/html; charset=gb2312″>
<TITLE>测试修改表格</TITLE>
<STYLE>
/*提示层的样式*/
div
{
BORDER-RIGHT: #80c144 1px solid;
BORDER-TOP: #80c144 1px solid;
VISIBILITY: hidden;
BORDER-LEFT: #80c144 1px solid;
CURSOR: default;
LINE-HEIGHT: 20px;
BORDER-BOTTOM: #80c144 1px solid;
FONT-FAMILY: 宋体;
font-size:12px;
POSITION: absolute;
BACKGROUND-COLOR: #f6f6f6;
TOP:30px;
LEFT:30px;
}
/*tr的样式*/
tr
{
font-family: “宋体”;
color: #000000;
background-color: #C1DBF5;
font-size: 12px
}
/*table脚注样式*/
.TrFoot
{
FONT-SIZE: 12px;
font-family:”宋体”, “Verdana”, “Arial”;
BACKGROUND-COLOR: #6699CC;
COLOR:#FFFFFF;
height: 25;
}
/*trhead属性*/
.TrHead
{
FONT-SIZE: 13px;
font-family:”宋体”, “Verdana”, “Arial”;
BACKGROUND-COLOR: #77AADD;
COLOR:#FFFFFF;
height: 25;
}
/*文本框样式*/
INPUT
{
BORDER-COLOR: #AACEF7 #AACEF7 #AACEF7 #AACEF7;
BORDER-RIGHT: 1px solid;
BORDER-TOP: 1px solid;
BORDER-LEFT: 1px solid;
BORDER-BOTTOM: 1px solid;
FONT-SIZE: 12px;
FONT-FAMILY: “宋体”,”Verdana”;
color: #000000;
BACKGROUND-COLOR: #E9EFF5;
}
/*button样式*/
button
{
BORDER-COLOR: #AACEF7 #AACEF7 #AACEF7 #AACEF7;
BACKGROUND-COLOR: #D5E4F3;
CURSOR: hand;
FONT-SIZE:12px;
BORDER-RIGHT: 1px solid;
BORDER-TOP: 1px solid;
BORDER-LEFT: 1px solid;
BORDER-BOTTOM: 1px solid;
COLOR: #000000;
}
</STYLE>
</HEAD>
<BODY>
<SCRIPT language = “JavaScript”>
<!–全局变量
//标志位,值为false代表未打开一个编辑框,值为true为已经打开一个编辑框开始编辑
var editer_table_cell_tag = false;
//开启编辑功能标志,值为true时为允许编辑
var run_edit_flag = false;
//–>
</SCRIPT>
<SCRIPT language = “JavaScript”>
<!–
/**
* 编辑表格函数
* 单击某个单元格可以对里面的内容进行自由编辑
* @para tableID 为要编辑的table的id
* @para noEdiID 为不要编辑的td的ID,比如说table的标题
* 可以写为<TD id=”no_editer”>自由编辑表格</TD>
* 此时该td不可编辑
*/
function editerTableCell(tableId,noEdiId)
{
var tdObject = event.srcElement;
var tObject = ((tdObject.parentNode).parentNode).parentNode;
if(tObject.id == tableId &&tdObject.id != noEdiId&&editer_table_cell_tag == false && run_edit_flag == true)
{
tdObject.innerHTML = “<input type=text id=edit_table_txt name=edit_table_txt value=”+tdObject.innerText+” size=’15’ onKeyDown=’enterToTab()’> <input type=button value=’ 确定 ‘ onclick=’certainEdit()’>”;
edit_table_txt.focus();
edit_table_txt.select();
editer_table_cell_tag = true;
//修改按钮提示信息
editTip.innerText = “请先点确定按钮确认修改!”;
}
else
{
return false;
}
}
/**
* 确定修改
*/
function certainEdit()
{
var bObject = event.srcElement;
var tdObject = bObject.parentNode;
var txtObject = tdObject.firstChild;
tdObject.innerHTML = txtObject.value;
//代表编辑框已经关闭
editer_table_cell_tag = false;
//修改按钮提示信息
editTip.innerText = “请单击某个单元格进行编辑!”;
}
function enterToTab()
{
if(event.srcElement.type != ‘button’ && event.srcElement.type != ‘textarea’
&& event.keyCode == 13)
{
event.keyCode = 9;
}
}
/**
* 控制是否编辑
*/
function editStart()
{
if(event.srcElement.value == “开始编辑”
{
event.srcElement.value = “编辑完成”;
run_edit_flag = true;
}
else
{
//如果当前没有编辑框,则编辑成功,否则,无法提交
//必须按确定按钮后才能正常提交
if(editer_table_cell_tag == false)
{
alert(“编辑成功结束!”;
event.srcElement.value = “开始编辑”;
run_edit_flag = false;
}
}
}
/**
* 根据不同的按钮提供不同的提示信息
*/
function showTip()
{
if(event.srcElement.value == “编辑完成”
{
editTip.style.top = event.y + 15;
editTip.style.left = event.x + 12;
editTip.style.visibility = “visible”;
}
else
{
editTip.style.visibility = “hidden”;
}
}
–>
</SCRIPT>
<TABLE id=”editer_table” width=”100%” align=”center”
onclick=”editerTableCell(‘editer_table’,’no_editer’)”>
<TR class=”TrHead”>
<TD colspan=”3″ align=”center” id=”no_editer”>自由编辑表格</TD>
</TR>
<TR>
<TD width=”33%”>单击开始编辑按钮,然后点击各单元格编辑</TD>
<TD width=”33%”>2</TD>
<TD width=”33%”>3</TD>
</TR>
<TR>
<TD width=”33%”>4</TD>
<TD width=”33%”>5</TD>
<TD width=”33%”>6</TD>
</TR>
<TR>
<TD width=”33%”>one</TD>
<TD width=”33%”>two</TD>
<TD width=”33%”>three</TD>
</TR>
<TR>
<TD width=”33%”>four</TD>
<TD width=”33%”>five</TD>
<TD width=”33%”>six</TD>
</TR>
<TR class=”TrFoot”>
<TD colspan=”3″ align=”center” id=”no_editer”>
<INPUT type=”button” class=”bt” value=”开始编辑” onClick=”editStart()” onMouseOver=”showTip()” onMouseMove=”showTip()” onMouseOut=”editTip.style.visibility = ‘hidden’;”>
</TD>
</TR>
</TABLE>
</BODY>
<DIV id=”editTip”>请单击某个单元格进行编辑!</DIV>
</HTML>

强大的HTML5

        前些天看了一些HTML5方面的资料,感觉的确很强大,firefox和chrome目前已经支持了一些特性,例如canvas和本地存储等等,今天花了一个晚上的时间实践了一把canvas,做了一个比较简单的web版的贪吃蛇,开发起来的确还是挺方便的,就像当年用TurboC做贪吃蛇的感觉差不多。

        网上最近好像很多文章都在讨论,HTML5是否会取代Flash,之前没接触过的时候一直以为HTML和Flash并没有可比性,但通过对HTML5的了解,改变了这种观点,HTML5的亮点很多,光是canvas、本地存储和web socket这几个特性,就能够做很多以前做不到的功能,想想看,使用canvas可以定制我们需要的界面甚至各种交互的控件,本地存储解决了以前脚本无法访问本地文件只能使用cookie保存数据的问题,web socket在网络游戏等方面更是可以发挥作用。所以现在感觉,HTML5替代Flash并非不可能,只要解决浏览器的兼容性问题和性能问题,Flash基本上就可以ByeBye了。

 

 

http://xiaowei.sinaapp.com/snake.html

一段asp转php

版权声明:原创作品,允许转载,转载时请务必以超链接形式标明文章原始出版、作者信息和本声明。否则将追究法律责任。http://blog.csdn.net/mayongzhan – 马永占,myz,mayongzhan

程序是共通的…
下面是asp转php的代码
虽然有的地方不太清楚.基本上还是可以看出.任何语言都是可以互相转换的.
上面是php下面是asp
< php
//————————————————————————————-
class clsThief
{
//__________________
private $value_;
private $src_;
private $isGet_;
public function setSrc($str)
{
$this->src_ = $str;
}
public function getSrc()
{
return $this->src_;
}
public function getValue()
{
return $this->value_;
}
public function getVersion()
{
return “Version 2005”;
}
function __construct()
{
$this->value_ = “”;
$this->$src_ = “”;
$this->isGet_ = false;
}
function __construct()
{
//construct
}
public function bytesToBstr($body,$cset)
{
$objstream = new Server.CreateObject(“adodb.stream”);//这个地方是什么…流 
$objstream->Type = 1;
//…
$text = $objstream->ReadText;//这里是要返回   
$objstream->Close;
$objstream = null;
}
public function steal()
{
if ($this->src_ == “”) {
$http = new server.createobject(“MSXML2.XMLHTTP”);//这里是xml  
$http->open ;//…
//…
if ($http->readystate!=4) {
exit();//这里是中指执行
}
$this->value_ = $this->bytesToBstr(Http.responseBody,”GB2312″);
$this->isGet_ = true;
$http = null;
if ($err->nulber!=0) { //这个应该不对
$err->Clear;
}
else {
echo “<script language=’javascript’>alert(‘请先设置src属性!’);</script>”;
}
}
}
public function change($oldStr,$str)
{
if ($this->isGet_ = false) {
$this->steal();
$this->value_ = str_replace($this->value_,$oldStr,$str);//这里用的是php的函数
}
}
public function cutX($head,$bot)
{
if ($this->isGet_ = false) {
$this->steal();
if (strstr($this->value_, $head) && strstr($this->value_,$bot)) {//在$this->value中寻找$head ,找到返回true
$this->value_ = false;//这里是什么….
}
else {
$this->value_ = “<p align=’center’>单词不存在</p>”;
}
}
}
}
 >
<html><head>
< php $wd=$_REQUEST[‘word’];
$myThief=new clsThief;
$myThief->src = “http://www.baidu.com/baidu ie=gb2312&bs=&sr=&z=&ct=1048576&cl=3&f=8&word=”.wd;
$myThief->steal;
$myThief->cutX(“<ol>”,”</ol>”);//这里是什么
$myThief->change(“src=’IMAGES/”,”src=’http://www.baidu.com/IMAGES/”);
$myThief->change(“<br>以上结果由 <a href=’http://www.dreye.com.cn’ target=’_blank’>Dr.eye译典通字典</a> 提供”,””);
$page = $myThief->value;
$myThief=null;
$page=””.page.””;//这个有什么意义…
 >
<title>< php echo $wd; >解释</title>
<meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″><style type=”text/css”>
td,body{font-size:14.8px;color:#000}a:link{color:#000066;text-decoration:none}a:visited{COLOR:#000066;
TEXT-DECORATION:none}a:active{color:red;text-decoration:none}a:hover{color:green;text-decoration:underline}
.unnamed1 { font-size: 9pt; line-height: 20px}
.font12_bold{
font-size:12px;
color:#000000;
font-weight:bold;
}
</style>
<style type=”text/css”>
.ptitle {margin-top:3px; font-weight:bold}
.pcixin {margin – top : 3px; color = #FF0000}
.pexplain {margin-top:3px; margin-left:20px}
.pnewword {margin-top:3px; margin-right:10px; font-size:12; color:#9d0006; font-weight:bold}
.peng {margin-top:3px; margin-left:40px; font-size:16; color:#0000A0; font-weight:bold}
.pchi {margin-top:3px; margin-left:40px; font-size:16; color:#800040}
font.engi {color:#FF00FF; font-style:italic}
font.chinese {font-weight:normal; font-size:24; color:#008080}
#ft{clear:both;line-height:20px;background:#E6E6E6;text-align:center}
#ft,#ft *{color:#77C;font-size:12px;”” align=left>#ft span{color:#666}
.sb{height:2em;width:5.6em;font-size:14px;}
.kw{font-size:16px;height:1.78em;padding-top:2px;}</style></head>
<body><div align=”center”>
<p><a href=””><font color=”#FF0000″ size=”+1″><strong>英汉词典</strong></font></a></p>
</div>
<br>
<table width=”770″ border=”0″ align=”center” cellpadding=”0″ cellspacing=”0″>
<tr>
<td colspan=”4″><div align=”center”>
<form name=”f1″ action=”index.asp”>
<input name=”word” type=”text” id=”word” class=kw>
<input type=submit value=词典搜索 class=sb></form>
</div></td>
</tr>
<tr>
<td height=”30″ colspan=”4″>
<div align=”center”><font color=”green” size=”3″><strong>< php echo $wd; > 的解释</strong></font></div></td>
</tr>
</table>
<table width=”500″ border=”0″ align=”center” cellpadding=”0″ cellspacing=”0″ class=”bm81″>
<tr>
<td>< php echo $page; >/td>
</tr>
</table>
</body></html>
——————————————-
——————————————-
———–MyZ的分割线————-
——————————————-
<%
‘————————————————————————————-
Class clsThief
‘____________________
Private value_
Private src_
Private isGet_
public property let src(str) ‘
src_=str
end property
public property get value ‘
value=value_
end property
Public Property get Version
Version=”Version 2005″
End Property
private sub class_initialize()
value_=””
src_=””
isGet_= false
end sub
private sub class_terminate()
end sub
private Function BytesToBstr(body,Cset) ‘
dim objstream
set objstream = Server.CreateObject(“adodb.stream”)
objstream.Type = 1
objstream.Mode =3
objstream.Open
objstream.Write body
objstream.Position = 0
objstream.Type = 2
objstream.Charset = Cset
BytesToBstr = objstream.ReadText
objstream.Close
set objstream = nothing
End Function
public sub steal() ‘
if src_<>”” then
dim Http
set Http=server.createobject(“MSXML2.XMLHTTP”)
Http.open “GET”,src_ ,false
Http.send()
if Http.readystate<>4 then
exit sub
end if
value_=BytesToBSTR(Http.responseBody,”GB2312″)
isGet_= True
set http=nothing
if err.number<>0 then err.Clear
else
response.Write(“<script>alert(“”请先设置src属性!””)</script>”)
end if
end sub
public sub change(oldStr,str)
if isGet_= false then call steal()
value_=replace(value_ , oldStr,str)
end sub
public sub cutX(head,bot)
if isGet_= false then call steal()
if instr(value_,head)>0 and instr(value_,bot)>0 then
value_=mid(value_ ,instr(value_ ,head),instr(value_ ,bot)-instr(value_ ,head)+len(bot))
else
value_= “<p align=””center””>单词不存在”
end if
end sub
end class
%>
<html><head>
<%wd=request(“word”)
dim myThief,page
set myThief=new clsThief
myThief.src=”http://www.baidu.com/baidu ie=gb2312&bs=&sr=&z=&ct=1048576&cl=3&f=8&word=”&wd&””
myThief.steal
myThief.cutX “<ol>”,”</ol>”
myThief.change “src=””IMAGES/”,”src=””http://www.baidu.com/IMAGES/”
myThief.change “<br>以上结果由 <a href=””http://www.dreye.com.cn”” target=_blank>Dr.eye译典通字典</a> 提供”,””
page=myThief.value
set myThief=nothing
page=””&page&””
%>
<title><%=wd%>解释</title>
<meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″><style type=”text/css”>
td,body{font-size:14.8px;color:#000}a:link{color:#000066;text-decoration:none}a:visited{COLOR:#000066;
TEXT-DECORATION:none}a:active{color:red;text-decoration:none}a:hover{color:green;text-decoration:underline}
.unnamed1 { font-size: 9pt; line-height: 20px}
.font12_bold{
font-size:12px;
color:#000000;
font-weight:bold;
}
</style>
<style type=”text/css”>
.ptitle {margin-top:3px; font-weight:bold}
.pcixin {margin – top : 3px; color = #FF0000}
.pexplain {margin-top:3px; margin-left:20px}
.pnewword {margin-top:3px; margin-right:10px; font-size:12; color:#9d0006; font-weight:bold}
.peng {margin-top:3px; margin-left:40px; font-size:16; color:#0000A0; font-weight:bold}
.pchi {margin-top:3px; margin-left:40px; font-size:16; color:#800040}
font.engi {color:#FF00FF; font-style:italic}
font.chinese {font-weight:normal; font-size:24; color:#008080}
#ft{clear:both;line-height:20px;background:#E6E6E6;text-align:center}
#ft,#ft *{color:#77C;font-size:12px;”” align=left>#ft span{color:#666}
.sb{height:2em;width:5.6em;font-size:14px;}
.kw{font-size:16px;height:1.78em;padding-top:2px;}</style></head>
<body><div align=”center”>
<p><a href=””><font color=”#FF0000″ size=”+1″><strong>英汉词典</strong></font></a></p>
</div>
<br>
<table width=”770″ border=”0″ align=”center” cellpadding=”0″ cellspacing=”0″>
<tr>
<td colspan=”4″><div align=”center”>
<form name=”f1″ action=”index.asp”>
<input name=”word” type=”text” id=”word” class=kw>
<input type=submit value=词典搜索 class=sb></form>
</div></td>
</tr>
<tr>
<td height=”30″ colspan=”4″>
<div align=”center”><font color=”green” size=”3″><strong><%=wd%> 的解释</strong></font></div></td>
</tr>
</table>
<table width=”500″ border=”0″ align=”center” cellpadding=”0″ cellspacing=”0″ class=”bm81″>
<tr>
<td><%response.write(page) %></td>
</tr>
</table>
</body></html>
很对不住了.能改的我都改了…其他的忘了很多…有些不熟…..
by mayongzhan

asp.net发布的网站,图片显示不出来解决方案

 

转自:http://apps.hi.baidu.com/share/detail/15251980

 

 

        遇到这种问题,最有可能的原因是有些图片没有包含到项目里面去,这样在部署项目的时候,因为这些图片没有包含在项目中而没有拷贝到虚拟目录下,从而导致图片无法显示。检查方法是: 选中项目,点“显示所有文件”,看看是不是这些图片显示的是白色的,如果是,如果确实没有包含在项目中,点右键“包含在项目中”就可以了。

如果不是这个问题,请再检查一下以下几个问题:

a.你上传的图片的位置是否和你网页中的链接路径一致。
b.你的图片文件的文件名是否是合法文件名,图片文件名大小写是否正确。
c.图片文件名是否带有汉字,你的文件名应由英文字母和数字组成。
d.你的图片文件是否也同时上传了等问题。

        另外,这里简单说一下.net部署网站的方法:

(1) 打开项目,在解决方案上,点右键“添加新项目”->“其他项目类型”->“安装和部署”,如果是web网站就选择“web安装项目”,然后选择存放的路径 点“确定”,默认这个项目的文件名为WebSetup1。这样在该解决方案中就会出现一个新的项目文件,也就是我们建的安装文件。

(2)在新建的项目文件WebSetup1中,点右键“添加项目输出”,然后选择主项目,选择“主输出”和“内容文件”,点确定。

(3)选中项目文件WebSetup1,点右键“生成”,就生成了setup.exe 和setup.msi文件,在你指定存放的路径下面的debug文件夹下。

(4)双击setup.msi安装,输入虚拟目录名称为你想指定的虚拟目录名称(假设虚拟目录叫WebSetup),点确定。

(5)打开ie浏览器,输入网址:http://127.0.0.1/WebSetup/default.aspx (如果你的主文件是default.aspx 的话)就可以访问了,这样本局域网内的其他电脑也都可以访问你发布的网站了。

    ^_^

正则表达式集锦

正则表达式用于字符串处理,表单验证等场合,实用高效,但用到时总是不太把握,以致往往要上网查一番。我将一些常用的表达式收藏在这里,作备忘之用。本贴随时会更新。

匹配中文字符的正则表达式: [\u4e00-\u9fa5]

匹配双字节字符(包括汉字在内):[^\x00-\xff]

应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)

String.prototype.len=function(){return this.replace([^\x00-\xff]/g,”aa”).length;}

匹配空行的正则表达式:\n[\s| ]*\r

匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/

匹配首尾空格的正则表达式:(^\s*)|(\s*$)

String.prototype.trim = function()
{
return this.replace(/(^\s*)|(\s*$)/g, “”);
}

利用正则表达式分解和转换IP地址:

下面是利用正则表达式匹配IP地址,并将IP地址转换成对应数值的Javascript程序:

function IP2V(ip)
{
re=/(\d+)\.(\d+)\.(\d+)\.(\d+)/g //匹配IP地址的正则表达式
if(re.test(ip))
{
return RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
}
else
{
throw new Error(“Not a valid IP address!”)
}
}

不过上面的程序如果不用正则表达式,而直接用split函数来分解可能更简单,程序如下:

var ip=”10.100.20.168″
ip=ip.split(“.”)
alert(“IP值是:”+(ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1))

匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*

匹配网址URL的正则表达式:http://([\w-]+\.)+[\w-]+(/[\w- ./ %&=]*) 

利用正则表达式去除字串中重复的字符的算法程序:[注:此程序不正确,原因见本贴回复]

var s=”abacabefgeeii”
var s1=s.replace(/(.).*\1/g,”$1″)
var re=new RegExp(“[“+s1+”]”,”g”)
var s2=s.replace(re,””)
alert(s1+s2) //结果为:abcefgi

我原来在CSDN上发贴寻求一个表达式来实现去除重复字符的方法,最终没有找到,这是我能想到的最简单的实现方法。思路是使用后向引用取出包括重复的字符,再以重复的字符建立第二个表达式,取到不重复的字符,两者串连。这个方法对于字符顺序有要求的字符串可能不适用。

得用正则表达式从URL地址中提取文件名的javascript程序,如下结果为page1

s=”http://www.9499.net/page1.htm”
s=s.replace(/(.*\/){0,}([^\.]+).*/ig,”$2″)
alert(s)

利用正则表达式限制网页表单里的文本框输入内容:

用正则表达式限制只能输入中文:onkeyup=”value=value.replace(/[^\u4E00-\u9FA5]/g,”)” onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^\u4E00-\u9FA5]/g,”))”

用正则表达式限制只能输入全角字符:onkeyup=”value=value.replace(/[^\uFF00-\uFFFF]/g,”)” onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^\uFF00-\uFFFF]/g,”))”

用正则表达式限制只能输入数字:onkeyup=”value=value.replace(/[^\d]/g,”) “onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^\d]/g,”))”

用正则表达式限制只能输入数字和英文:onkeyup=”value=value.replace(/[\W]/g,”) “onbeforepaste=”clipboardData.setData(‘text’,clipboardData.getData(‘text’).replace(/[^\d]/g,”))”

正则表达式,相关链接
http://blog.csdn.net/laily/category/19548.aspx
http://blog.csdn.net/laily/archive/2004/06/30/30525.aspx 微软的正则表达式教程(五):选择/编组和后向引用

http://blog.csdn.net/laily/archive/2004/06/30/30522.aspx 微软的正则表达式教程(四):限定符和定位符

http://blog.csdn.net/laily/archive/2004/06/30/30517.aspx 微软的正则表达式教程(三):字符匹配

http://blog.csdn.net/laily/archive/2004/06/30/30514.aspx 微软的正则表达式教程(二):正则表达式语法和优先权顺序

http://blog.csdn.net/laily/archive/2004/06/30/30511.aspx 微软的正则表达式教程(一):正则表达式简介

http://blog.csdn.net/laily/archive/2004/06/30/30360.aspx 小程序大作为:高级查找/替换、正则表达式练习器、Javascript脚本程序调试器

http://blog.csdn.net/laily/archive/2004/06/24/25872.aspx 经典正则表达式

正则表达式,正规表达式,正则表达式匹配,正则表达式语法,模式匹配,正规表达式匹配 javascript正则表达式 ASP正则表达式 ASP.NET正则表达式 C#正则表达式 JSP正则表达式 PHP正则表达式 VB.NET正则表达式 VBSCript正则表达式编程 delphi正则表达式 jscript

正则表达式 regular expression
正则表达式 RegExp
模式 pattern
匹配 Match
.NET命名空间: System.Text.RegularExpression

补充:
^\d+$  //匹配非负整数(正整数 + 0)
^[0-9]*[1-9][0-9]*$  //匹配正整数
^((-\d+)|(0+))$  //匹配非正整数(负整数 + 0)
^-[0-9]*[1-9][0-9]*$  //匹配负整数
^- \d+$    //匹配整数
^\d+(\.\d+) $  //匹配非负浮点数(正浮点数 + 0)
^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$  //匹配正浮点数
^((-\d+(\.\d+) )|(0+(\.0+) ))$  //匹配非正浮点数(负浮点数 + 0)
^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$  //匹配负浮点数
^(- \d+)(\.\d+) $  //匹配浮点数
^[A-Za-z]+$  //匹配由26个英文字母组成的字符串
^[A-Z]+$  //匹配由26个英文字母的大写组成的字符串
^[a-z]+$  //匹配由26个英文字母的小写组成的字符串
^[A-Za-z0-9]+$  //匹配由数字和26个英文字母组成的字符串
^\w+$  //匹配由数字、26个英文字母或者下划线组成的字符串
^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$    //匹配email地址
^[a-zA-z]+://匹配(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\ \S*) $  //匹配url

利用正则表达式去除字串中重复的字符的算法程序:

var s=”abacabefgeeii”
var s1=s.replace(/(.).*\1/g,”$1″)
var re=new RegExp(“[“+s1+”]”,”g”)
var s2=s.replace(re,””)
alert(s1+s2) //结果为:abcefgi
===============================
如果var s = “abacabefggeeii”
结果就不对了,结果为:abeicfgg
正则表达式的能力有限

1.确认有效电子邮件格式
下面的代码示例使用静态 Regex.IsMatch 方法验证一个字符串是否为有效电子邮件格式。如果字符串包含一个有效的电子邮件地址,则 IsValidEmail 方法返回 true,否则返回 false,但不采取其他任何操作。您可以使用 IsValidEmail,在应用程序将地址存储在数据库中或显示在 ASP.NET 页中之前,筛选出包含无效字符的电子邮件地址。

[Visual Basic]
Function IsValidEmail(strIn As String) As Boolean
‘ Return true if strIn is in valid e-mail format.
Return Regex.IsMatch(strIn, (“^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\] )$”)
End Function
[C#]
bool IsValidEmail(string strIn)
{
// Return true if strIn is in valid e-mail format.
return Regex.IsMatch(strIn, @”^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\] )$”);
}

2.清理输入字符串
下面的代码示例使用静态 Regex.Replace 方法从字符串中抽出无效字符。您可以使用这里定义的 CleanInput 方法,清除掉在接受用户输入的窗体的文本字段中输入的可能有害的字符。CleanInput 在清除掉除 @、-(连字符)和 .(句点)以外的所有非字母数字字符后返回一个字符串。

[Visual Basic]
Function CleanInput(strIn As String) As String
‘ Replace invalid characters with empty strings.
Return Regex.Replace(strIn, “[^\w\.@-]”, “”)
End Function
[C#]
String CleanInput(string strIn)
{
// Replace invalid characters with empty strings.
return Regex.Replace(strIn, @”[^\w\.@-]”, “”);
}

3.更改日期格式
以下代码示例使用 Regex.Replace 方法来用 dd-mm-yy 的日期形式代替 mm/dd/yy 的日期形式。

[Visual Basic]
Function MDYToDMY(input As String) As String
Return Regex.Replace(input, _
“\b( <month>\d{1,2})/( <day>\d{1,2})/( <year>\d{2,4})\b”, _
“${day}-${month}-${year}”)
End Function
[C#]
String MDYToDMY(String input)
{
return Regex.Replace(input,
“\\b( <month>\\d{1,2})/( <day>\\d{1,2})/( <year>\\d{2,4})\\b”,
“${day}-${month}-${year}”);
}
Regex 替换模式
本示例说明如何在 Regex.Replace 的替换模式中使用命名的反向引用。其中,替换表达式 ${day} 插入由 ( <day>…) 组捕获的子字符串。

有几种静态函数使您可以在使用正则表达式操作时无需创建显式正则表达式对象,而 Regex.Replace 函数正是其中之一。如果您不想保留编译的正则表达式,这将给您带来方便

4.提取 URL 信息
以下代码示例使用 Match.Result 来从 URL 提取协议和端口号。例如,“http://www.contoso.com:8080/letters/readme.html”将返回“http:8080”。

[Visual Basic]
Function Extension(url As String) As String
Dim r As New Regex(“^( <proto>\w+)://[^/]+ ( <port>:\d+) /”, _
RegexOptions.Compiled)
Return r.Match(url).Result(“${proto}${port}”)
End Function
[C#]
String Extension(String url)
{
Regex r = new Regex(@”^( <proto>\w+)://[^/]+ ( <port>:\d+) /”,
RegexOptions.Compiled);
return r.Match(url).Result(“${proto}${port}”);
}

  一、正则表达式基础知识
  我们先从简单的开始。假设你要搜索一个包含字符“cat”的字符串,搜索用的正则表达式就是“cat”。如果搜索对大小写不敏感,单词“catalog”、“Catherine”、“sophisticated”都可以匹配。也就是说:

  1.1句点符号
  假设你在玩英文拼字游戏,想要找出三个字母的单词,而且这些单词必须以“t”字母开头,以“n”字母结束。另外,假设有一本英文字典,你可以用正则表达式搜索它的全部内容。要构造出这个正则表达式,你可以使用一个通配符  句点符号“.”。这样,完整的表达式就是“t.n”,它匹配“tan”、“ten”、“tin”和“ton”,还匹配“t#n”、“tpn”甚至“tn”,还有其他许多无意义的组合。这是因为句点符号匹配所有字符,包括空格、Tab字符甚至换行符:

  1.2方括号符号
  为了解决句点符号匹配范围过于广泛这一问题,你可以在方括号(“[]”)里面指定看来有意义的字符。此时,只有方括号里面指定的字符才参与匹配。也就是说,正则表达式“t[aeio]n”只匹配“tan”、“Ten”、“tin”和“ton”。但“Toon”不匹配,因为在方括号之内你只能匹配单个字符:

  1.4表示匹配次数的符号
  表一显示了表示匹配次数的符号,这些符号用来确定紧靠该符号左边的符号出现的次数:

  假设我们要在文本文件中搜索美国的社会安全号码。这个号码的格式是999-99-9999。用来匹配它的正则表达式如图一所示。在正则表达式中,连字符(“-”)有着特殊的意义,它表示一个范围,比如从0到9。因此,匹配社会安全号码中的连字符号时,它的前面要加上一个转义字符“\”。

  图一:匹配所有123-12-1234形式的社会安全号码
  假设进行搜索的时候,你希望连字符号可以出现,也可以不出现  即,999-99-9999和 9999都属于正确的格式。这时,你可以在连字符号后面加上“?”数量限定符号,如图二所示:

  图二:匹配所有123-12-1234和123121234形式的社会安全号码
  下面我们再来看另外一个例子。美国汽车牌照的一种格式是四个数字加上二个字母。它的正则表达式前面是数字部分“[0-9]{ 4}”,再加上字母部分“[A-Z]{ 2}”。图三显示了完整的正则表达式。

  图三:匹配典型的美国汽车牌照号码,如8836KV
  1.5“否”符号
  “^”符号称为“否”符号。如果用在方括号内,“^”表示不想要匹配的字符。例如,图四的正则表达式匹配所有单词,但以“X”字母开头的单词除外。

  图四:匹配所有单词,但“X”开头的除外
  1.6圆括号和空白符号
  假设要从格式为“June26,1951”的生日日期中提取出月份部分,用来匹配该日期的正则表达式可以如图五所示:

  图五:匹配所有MothDD,YYYY格式的日期
  新出现的“\s”符号是空白符号,匹配所有的空白字符,包括Tab字符。如果字符串正确匹配,接下来如何提取出月份部分呢?只需在月份周围加上一个圆括号创建一个组,然后用OROAPI(本文后面详细讨论)提取出它的值。修改后的正则表达式如图六所示:

  图六:匹配所有MonthDD,YYYY格式的日期,定义月份值为第一个组
  1.7其它符号
  为简便起见,你可以使用一些为常见正则表达式创建的快捷符号。如表二所示:
  表二:常用符号

  例如,在前面社会安全号码的例子中,所有出现“[0-9]”的地方我们都可以使用“\d”。修改后的正则表达式如图七所示:


/*————————
功能:替换任何空白字符
————————-*/
function TrimString (strVal)
{
strTmp = strVal + “”;
if (strTmp.length == 0)
return (strTmp);
reVal = /^\s*/;
strTmp = strTmp.replace (reVal, ”);
reVal = /\s*$/;
return (strTmp.replace (reVal, ”));
}

/*————————
功能:检测是否是有效数字
————————-*/
function Check_Num( num )
{
num = ( TrimString( num ) );
if (num.length == 0)
return (false);
return ( Number( num ) );
}

/*————————
功能:检测是否是有效日期
————————-*/
function Check_Date (strDate)
{
strDate = (TrimString (strDate));
if (strDate.length == 0)
return (false);
reVal = /^([1-2]\d{3})[\/|\-](0 [1-9]|10|11|12)[\/|\-]([1-2] [0-9]|0[1-9]|30|31)$/;
return (reVal.test (strDate));
}

/*————————
功能:检测是否是有效Email
————————-*/
function Check_Email (strEmail)
{
strEmail = (TrimString (strEmail));
if (strEmail.length == 0)
return (false);

reVal = /^[\-!#\$%&’\*\+\\\.\/0-9=\ A-Z\^_`a-z{|}~]+@[\-!#\$%&’\*\+\\\.\/0-9=\ A-Z\^_`a-z{|}~]+(\.[\-!#\$%&’\*\+\\\.\/0-9=\ A-Z\^_`a-z{|}~]+)+$/;
return (reVal.test (strEmail));
}

/*————————
功能:检测是否是有效时间
————————-*/
function Check_Time (strTime)
{
strTime = (TrimString (strTime));
if (strTime.length == 0)
return (false);

reVal = /^(([0-9]|[01][0-9]|2[0-3])(:([0-9]|[0-5][0-9])){0,2}|(0 [0-9]|1[0-1])(:([0-9]|[0-5][0-9])){0,2}\s [aApP][mM]) $/;
return (reVal.test (strTime));
}

/*————————
功能:检测是否是有效日期特定格式
————————-*/
function Check_Date_1 (strDate)
{
strDate = (TrimString (strDate));
if (strDate.length == 0)
return (false);
reVal = /^([1-2]\d{3})[\/](0 [1-9]|10|11|12)[\/]([1-2] [0-9]|0[1-9]|30|31)$/;
return (reVal.test (strDate));
}

/*————————
功能:检测是否是有效日期特定格式
————————-*/
function Check_Date_2 (strDate)
{
strDate = (TrimString (strDate));
if (strDate.length == 0)
return (false);
reVal = /^([1-2]\d{3})[\-](0[1-9]|10|11|12)[\-]([1-2][0-9]|0[1-9]|30|31)$/;
return (reVal.test (strDate));
}

/*————————————–
功能:换行定行
—————————————*/
function enter( form, temp )
{
if ( window.event.keyCode == 13 )
{
eval( form + temp + “.focus()” );
eval( form + temp + “.select()” );
}
else
return (false);
}

/*————————————–
功能:检查字符串长度
—————————————*/
function ByteString (strVal)
{
nLen = 0;

for (i = 0; i < strVal.length; i ++)
{
if (strVal.charCodeAt (i) > 255)
nLen += 2;
else
nLen ++;
};
return (nLen);
}

/*————————————–
功能:按要求截取字符串长度
—————————————*/
function SubString(strVal,nStrLen)
{
nLen = 0;
nTemp = 0;
for (i = 0; i < strVal.length; i ++)
{
if (strVal.charCodeAt (i) > 255)
nLen += 2;
else
nLen ++;
if(nLen <= nStrLen)
nTemp = i;
else
break;
};
return(strVal.substr(0,nTemp+1));
}

/*————————
功能:检测密码,密码只能由英文字母、数字、减号、下划线、$、#、*、(和)构成,且首位必须是英文字母
————————-*/
function Check_Pass( strPass )
{
strPass = ( TrimString( strPass ) );
if (strPass.length == 0)
return (false);
reVal = /^[a-zA-Z]{1}[a-zA-Z0-9-_$#*()]{0,29}$/;
return ( reVal.test (strPass) );
}

这是所有的,不过是PHP的,你自己转换一下吧~~


#re: 正则表达式 2005-02-28 00:59 yongsheng

^(((19)|(20))\d{2})(((((-|/)0 )|0)[1-9])|((-|/) 1[0-2]))((((((-|/)0 )|0)[1-9])|((-|/) [1-2][0-9]))|((-|/) 3[0-1]))$

2004-1-1格式

#re: 正则表达式 2005-03-07 14:33 yongsheng

一、验证类
1、数字验证内
1.1 整数
1.2 大于0的整数 (用于传来的ID的验证)
1.3 负整数的验证
1.4 整数不能大于iMax
1.5 整数不能小于iMin
2、时间类
2.1 短时间,形如 (13:04:06)
2.2 短日期,形如 (2003-12-05)
2.3 长时间,形如 (2003-12-05 13:04:06)
2.4 只有年和月。形如(2003-05,或者2003-5)
2.5 只有小时和分钟,形如(12:03)
3、表单类
3.1 所有的表单的值都不能为空
3.2 多行文本框的值不能为空。
3.3 多行文本框的值不能超过sMaxStrleng
3.4 多行文本框的值不能少于sMixStrleng
3.5 判断单选框是否选择。
3.6 判断复选框是否选择.
3.7 复选框的全选,多选,全不选,反选
3.8 文件上传过程中判断文件类型
4、字符类
4.1 判断字符全部由a-Z或者是A-Z的字字母组成
4.2 判断字符由字母和数字组成。
4.3 判断字符由字母和数字,下划线,点号组成.且开头的只能是下划线和字母
4.4 字符串替换函数.Replace();
5、浏览器类
5.1 判断浏览器的类型
5.2 判断ie的版本
5.3 判断客户端的分辨率

6、结合类
6.1 email的判断。
6.2 手机号码的验证
6.3 身份证的验证

二、功能类

1、时间与相关控件类
1.1 日历
1.2 时间控件
1.3 万年历
1.4 显示动态显示时钟效果(文本,如OA中时间)
1.5 显示动态显示时钟效果 (图像,像手表)
2、表单类
2.1 自动生成表单
2.2 动态添加,修改,删除下拉框中的元素
2.3 可以输入内容的下拉框
2.4 多行文本框中只能输入iMax文字。如果多输入了,自动减少到iMax个文字(多用于短信发送)

3、打印类
3.1 打印控件
4、事件类
4.1 屏蔽右键
4.2 屏蔽所有功能键
4.3 –> 和<– F5 F11,F9,F1
4.4 屏蔽组合键ctrl+N
5、网页设计类
5.1 连续滚动的文字,图片(注意是连续的,两段文字和图片中没有空白出现)
5.2 html编辑控件类
5.3 颜色选取框控件
5.4 下拉菜单
5.5 两层或多层次的下拉菜单
5.6 仿IE菜单的按钮。(效果如rongshuxa.com的导航栏目)
5.7 状态栏,title栏的动态效果(例子很多,可以研究一下)
5.8 双击后,网页自动滚屏
6、树型结构。
6.1 asp+SQL版
6.2 asp+xml+sql版
6.3 java+sql或者java+sql+xml
7、无边框效果的制作
8、连动下拉框技术
9、文本排序

一、验证类
1、数字验证内
1.1 整数
/^(-|\+) \d+$/.test(str)
1.2 大于0的整数 (用于传来的ID的验证)
/^\d+$/.test(str)
1.3 负整数的验证
/^-\d+$/.test(str)
2、时间类
2.1 短时间,形如 (13:04:06)
function isTime(str)
{
var a = str.match(/^(\d{1,2})(:) (\d{1,2})\2(\d{1,2})$/);
if (a == null) {alert(‘输入的参数不是时间格式’); return false;}
if (a[1]>24 || a[3]>60 || a[4]>60)
{
alert(“时间格式不对”);
return false
}
return true;
}
2.2 短日期,形如 (2003-12-05)
function strDateTime(str)
{
var r = str.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/);
if(r==null)return false;
var d= new Date(r[1], r[3]-1, r[4]);
return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]);
}
2.3 长时间,形如 (2003-12-05 13:04:06)
function strDateTime(str)
{
var reg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/;
var r = str.match(reg);
if(r==null)return false;
var d= new Date(r[1], r[3]-1,r[4],r[5],r[6],r[7]);
return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]&&d.getHours()==r[5]&&d.getMinutes()==r[6]&&d.getSeconds()==r[7]);
}
2.4 只有年和月。形如(2003-05,或者2003-5)
2.5 只有小时和分钟,形如(12:03)
3、表单类
3.1 所有的表单的值都不能为空
<input onblur=”if(this.value.replace(/^\s+|\s+$/g,”)==”)alert(‘不能为空!’)”>
3.2 多行文本框的值不能为空。
3.3 多行文本框的值不能超过sMaxStrleng
3.4 多行文本框的值不能少于sMixStrleng
3.5 判断单选框是否选择。
3.6 判断复选框是否选择.
3.7 复选框的全选,多选,全不选,反选
3.8 文件上传过程中判断文件类型
4、字符类
4.1 判断字符全部由a-Z或者是A-Z的字字母组成
<input onblur=”if(/[^a-zA-Z]/g.test(this.value))alert(‘有错’)”>
4.2 判断字符由字母和数字组成。
<input onblur=”if(/[^0-9a-zA-Z]/g.test(this.value))alert(‘有错’)”>
4.3 判断字符由字母和数字,下划线,点号组成.且开头的只能是下划线和字母
/^([a-zA-z_]{1})([\w]*)$/g.test(str)
4.4 字符串替换函数.Replace();
5、浏览器类
5.1 判断浏览器的类型
window.navigator.appName
5.2 判断ie的版本
window.navigator.appVersion
5.3 判断客户端的分辨率
window.screen.height; window.screen.width;

6、结合类
6.1 email的判断。
function ismail(mail)
{
return(new RegExp(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/).test(mail));
}
6.2 手机号码的验证
6.3 身份证的验证
function isIdCardNo(num)
{
if (isNaN(num)) {alert(“输入的不是数字!”); return false;}
var len = num.length, re;
if (len == 15)
re = new RegExp(/^(\d{6})() (\d{2})(\d{2})(\d{2})(\d{3})$/);
else if (len == 18)
re = new RegExp(/^(\d{6})() (\d{4})(\d{2})(\d{2})(\d{3})(\d)$/);
else {alert(“输入的数字位数不对!”); return false;}
var a = num.match(re);
if (a != null)
{
if (len==15)
{
var D = new Date(“19″+a[3]+”/”+a[4]+”/”+a[5]);
var B = D.getYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5];
}
else
{
var D = new Date(a[3]+”/”+a[4]+”/”+a[5]);
var B = D.getFullYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5];
}
if (!B) {alert(“输入的身份证号 “+ a[0] +” 里出生日期不对!”); return false;}
}
return true;
}

3.7 复选框的全选,多选,全不选,反选
<form name=hrong>
<input type=checkbox name=All onclick=”checkAll(‘mm’)”>全选<br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/><br/>

<input type=checkbox name=All2 onclick=”checkAll(‘mm2’)”>全选<br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>

</form>

<SCRIPT LANGUAGE=”JavaScript”>
function checkAll(str)
{
var a = document.getElementsByName(str);
var n = a.length;
for (var i=0; i<n; i++)
a[i].checked = window.event.srcElement.checked;
}
function checkItem(str)
{
var e = window.event.srcElement;
var all = eval(“document.hrong.”+ str);
if (e.checked)
{
var a = document.getElementsByName(e.name);
all.checked = true;
for (var i=0; i<a.length; i++)
{
if (!a[i].checked){ all.checked = false; break;}
}
}
else all.checked = false;
}
</SCRIPT>

3.8 文件上传过程中判断文件类型
<input type=file onchange=”alert(this.value.match(/^(.*)(\.)(.{1,8})$/)[3])”>

画图:
<OBJECT
id=S
style=”LEFT: 0px; WIDTH: 392px; TOP: 0px; HEIGHT: 240px”
height=240
width=392
classid=”clsid:369303C2-D7AC-11D0-89D5-00A0C90833E6″>
</OBJECT>
<SCRIPT>
S.DrawingSurface.ArcDegrees(0,0,0,30,50,60);
S.DrawingSurface.ArcRadians(30,0,0,30,50,60);
S.DrawingSurface.Line(10,10,100,100);
</SCRIPT>

写注册表:
<SCRIPT>
var WshShell = WScript.CreateObject(“WScript.Shell”);
WshShell.RegWrite (“HKCU\\Software\\ACME\\FortuneTeller\\”, 1, “REG_BINARY”);
WshShell.RegWrite (“HKCU\\Software\\ACME\\FortuneTeller\\MindReader”, “Goocher!”, “REG_SZ”);
var bKey = WshShell.RegRead (“HKCU\\Software\\ACME\\FortuneTeller\\”);
WScript.Echo (WshShell.RegRead (“HKCU\\Software\\ACME\\FortuneTeller\\MindReader”));
WshShell.RegDelete (“HKCU\\Software\\ACME\\FortuneTeller\\MindReader”);
WshShell.RegDelete (“HKCU\\Software\\ACME\\FortuneTeller\\”);
WshShell.RegDelete (“HKCU\\Software\\ACME\\”);
</SCRIPT>

TABLAE相关(客户端动态增加行列)
<HTML>
<SCRIPT LANGUAGE=”JScript”>
function numberCells() {
var count=0;
for (i=0; i < document.all.mytable.rows.length; i++) {
for (j=0; j < document.all.mytable.rows(i).cells.length; j++) {
document.all.mytable.rows(i).cells(j).innerText = count;
count++;
}
}
}
</SCRIPT>
<BODY onload=”numberCells()”>
<TABLE id=mytable border=1>
<TR><TH>&nbsp;</TH><TH>&nbsp;</TH><TH>&nbsp;</TH><TH>&nbsp;</TH></TR>
<TR><TD>&nbsp;</TD><TD>&nbsp;</TD><TD>&nbsp;</TD><TD>&nbsp;</TD></TR>
<TR><TD>&nbsp;</TD><TD>&nbsp;</TD><TD>&nbsp;</TD><TD>&nbsp;</TD></TR>
</TABLE>
</BODY>
</HTML>

1.身份证严格验证:

<script>
var aCity={11:”北京”,12:”天津”,13:”河北”,14:”山西”,15:”内蒙古”,21:”辽宁”,22:”吉林”,23:”黑龙江”,31:”上海”,32:”江苏”,33:”浙江”,34:”安徽”,35:”福建”,36:”江西”,37:”山东”,41:”河南”,42:”湖北”,43:”湖南”,44:”广东”,45:”广西”,46:”海南”,50:”重庆”,51:”四川”,52:”贵州”,53:”云南”,54:”西藏”,61:”陕西”,62:”甘肃”,63:”青海”,64:”宁夏”,65:”新疆”,71:”台湾”,81:”香港”,82:”澳门”,91:”国外”}

function cidInfo(sId){
var iSum=0
var info=””
if(!/^\d{17}(\d|x)$/i.test(sId))return false;
sId=sId.replace(/x$/i,”a”);
if(aCity[parseInt(sId.substr(0,2))]==null)return “Error:非法地区”;
sBirthday=sId.substr(6,4)+”-“+Number(sId.substr(10,2))+”-“+Number(sId.substr(12,2));
var d=new Date(sBirthday.replace(/-/g,”/”))
if(sBirthday!=(d.getFullYear()+”-“+ (d.getMonth()+1) + “-” + d.getDate()))return “Error:非法生日”;
for(var i = 17;i>=0;i –) iSum += (Math.pow(2,i) % 11) * parseInt(sId.charAt(17 – i),11)
if(iSum%11!=1)return “Error:非法证号”;
return aCity[parseInt(sId.substr(0,2))]+”,”+sBirthday+”,”+(sId.substr(16,1)%2 “男”:”女”)
}

document.write(cidInfo(“380524198002300016″),”<br/>”);
document.write(cidInfo(“340524198002300019″),”<br/>”)
document.write(cidInfo(“340524197711111111″),”<br/>”)
document.write(cidInfo(“34052419800101001x”),”<br/>”);
</script>

2.验证IP地址
<SCRIPT LANGUAGE=”JavaScript”>
function isip(s){
var check=function(v){try{return (v<=255 && v>=0)}catch(x){return false}};
var re=s.split(“.”)
return (re.length==4) (check(re[0]) && check(re[1]) && check(re[2]) && check(re[3])):false
}

var s=”202.197.78.129″;
alert(isip(s))
</SCRIPT>

3.加sp1后还能用的无边框窗口!!
<HTML XMLNS:IE>
<meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″>
<IE:Download ID=”include” STYLE=”behavior:url(#default#download)” />
<title>Chromeless Window</title>

<SCRIPT LANGUAGE=”JScript”>
/*— Special Thanks For andot —*/

/*
This following code are designed and writen by Windy_sk <seasonx@163.net>
You can use it freely, but u must held all the copyright items!
*/

/*— Thanks For andot Again —*/

var CW_width = 400;
var CW_height = 300;
var CW_top = 100;
var CW_left = 100;
var CW_url = “/”;
var New_CW = window.createPopup();
var CW_Body = New_CW.document.body;
var content = “”;
var CSStext = “margin:1px;color:black; border:2px outset;border-style:expression(onmouseout=onmouseup=function(){this.style.borderStyle=’outset’}, onmousedown=function(){if(event.button!=2)this.style.borderStyle=’inset’});background-color:buttonface;width:16px;height:14px;font-size:12px;line-height:11px;cursor:Default;”;

//Build Window
include.startDownload(CW_url, function(source){content=source});

function insert_content(){
var temp = “”;
CW_Body.style.overflow = “hidden”;
CW_Body.style.backgroundColor = “white”;
CW_Body.style.border = “solid black 1px”;
content = content.replace(/<a ([^>]*)>/g,”<a onclick=’parent.open(this.href);return false’ $1>”);
temp += “<table width=100% height=100% cellpadding=0 cellspacing=0 border=0>”;
temp += “<tr style=’;font-size:12px;background:#0099CC;height:20;cursor:default’ ondblclick=\”Max.innerText=Max.innerText==’1′ ‘2’:’1′;parent.if_max=!parent.if_max;parent.show_CW();\” onmouseup=’parent.drag_up(event)’ onmousemove=’parent.drag_move(event)’ onmousedown=’parent.drag_down(event)’ onselectstart=’return false’ oncontextmenu=’return false’>”;
temp += “<td style=’color:#ffffff;padding-left:5px’>Chromeless Window For IE6 SP1</td>”;
temp += “<td style=’color:#ffffff;padding-right:5px;’ align=right>”;
temp += “<span id=Help onclick=\”alert(‘Chromeless Window For IE6 SP1 – Ver 1.0\\n\\nCode By Windy_sk\\n\\nSpecial Thanks For andot’)\” style=\””+CSStext+”font-family:System;padding-right:2px;\”> </span>”;
temp += “<span id=Min onclick=’parent.New_CW.hide();parent.blur()’ style=\””+CSStext+”font-family:Webdings;\” title=’Minimum’>0</span>”;
temp += “<span id=Max onclick=\”this.innerText=this.innerText==’1′ ‘2’:’1′;parent.if_max=!parent.if_max;parent.show_CW();\” style=\””+CSStext+”font-family:Webdings;\” title=’Maximum’>1</span>”;
temp += “<span id=Close onclick=’parent.opener=null;parent.close()’ style=\””+CSStext+”font-family:System;padding-right:2px;\” title=’Close’>x</span>”;
temp += “</td></tr><tr><td colspan=2>”;
temp += “<div id=include style=’overflow:scroll;overflow-x:hidden;overflow-y:auto; HEIGHT: 100%; width:”+CW_width+”‘>”;
temp += content;
temp += “</div>”;
temp += “</td></tr></table>”;
CW_Body.innerHTML = temp;
}

setTimeout(“insert_content()”,1000);

var if_max = true;
function show_CW(){
window.moveTo(10000, 10000);
if(if_max){
New_CW.show(CW_top, CW_left, CW_width, CW_height);
if(typeof(New_CW.document.all.include)!=”undefined”){
New_CW.document.all.include.style.width = CW_width;
New_CW.document.all.Max.innerText = “1”;
}

}else{
New_CW.show(0, 0, screen.width, screen.height);
New_CW.document.all.include.style.width = screen.width;
}
}

window.onfocus = show_CW;
window.onresize = show_CW;

// Move Window
var drag_x,drag_y,draging=false

function drag_move(e){
if (draging){
New_CW.show(e.screenX-drag_x, e.screenY-drag_y, CW_width, CW_height);
return false;
}
}

function drag_down(e){
if(e.button==2)return;
if(New_CW.document.body.offsetWidth==screen.width && New_CW.document.body.offsetHeight==screen.height)return;
drag_x=e.clientX;
drag_y=e.clientY;
draging=true;
e.srcElement.setCapture();
}

function drag_up(e){
draging=false;
e.srcElement.releaseCapture();
if(New_CW.document.body.offsetWidth==screen.width && New_CW.document.body.offsetHeight==screen.height) return;
CW_top = e.screenX-drag_x;
CW_left = e.screenY-drag_y;
}

</SCRIPT>
</HTML>

电话号码的验证

要求:
  (1)电话号码由数字、”(“、”)”和”-“构成
  (2)电话号码为3到8位
  (3)如果电话号码中包含有区号,那么区号为三位或四位
  (4)区号用”(“、”)”或”-“和其他部分隔开
  (5)移动电话号码为11或12位,如果为12位,那么第一位为0
  (6)11位移动电话号码的第一位和第二位为”13″
  (7)12位移动电话号码的第二位和第三位为”13″
  根据这几条规则,可以与出以下正则表达式:
  (^[0-9]{3,4}\-[0-9]{3,8}$)|(^[0-9]{3,8}$)|(^\([0-9]{3,4}\)[0-9]{3,8}$)|(^0{0,1}13[0-9]{9}$)

<script language=”javascript”>
function PhoneCheck(s) {
var str=s;
var reg=/(^[0-9]{3,4}\-[0-9]{3,8}$)|(^[0-9]{3,8}$)|(^\([0-9]{3,4}\)[0-9]{3,8}$)|(^0{0,1}13[0-9]{9}$)/
alert(reg.test(str));
}
</script>
<input type=text name=”iphone”>
<input type=button onclick=”PhoneCheck(document.all.iphone.value)” value=”Check”>

具有在输入非数字字符不回显的效果,即对非数字字符的输入不作反应。
function numbersonly(field,event){
var key,keychar;
if(window.event){
key = window.event.keyCode;
}
else if (event){
key = event.which;
}
else{
return true
}
keychar = String.fromCharCode(key);
if((key == null)||(key == 0)||(key == 8)||(key == 9)||(key == 13)||(key == 27)){
return true;
}
else if((“0123456789.”).indexOf(keychar)>-1){
window.status = “”;
return true;
}
else {
window.status = “Field excepts numbers only”;
return false;
}
}

验证ip

str=document.RegExpDemo.txtIP.value;
if(/^(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})$/.test(str)==false)
{
window.alert(‘错误的IP地址格式’);
document.RegExpDemo.txtIP.select();
document.RegExpDemo.txtIP.focus();
return;
}
if(RegExp.$1<1 || RegExp.$1>254||RegExp.$2<0||RegExp.$2>254||RegExp.$3<0||RegExp.$3>254||RegExp.$4<1||RegExp.$4>254)
{
window.alert(‘错误的IP地址’);
document.RegExpDemo.txtIP.select();
document.RegExpDemo.txtIP.focus();
return;
}
//剔除 如 010.020.020.03 前面 的0
var str=str.replace(/0(\d)/g,”$1″);
str=str.replace(/0(\d)/g,”$1″);
window.alert(str);

//一下是取数据的类
//Obj参数指定数据的来源(限定Table),默认第一行为字段名称行
//GetTableData类提供MoveNext方法,参数是表的行向上或向下移动的位数,正数向下移动,负数向上.
//GetFieldData方法获得指定的列名的数据
//Sort_desc方法对指定的列按降序排列
//Sort_asc方法对指定的列按升序排列
//GetData方法返回字段值为特定值的数据数组,提供数据,可以在外部进行其他处理
//Delete方法删除当前记录,数组减少一行
//初始化,Obj:table的名字,Leftlen:左面多余数据长度,Rightlen:右面多余数据长度,
function GetTableData(Obj,LeftLen,RightLen){
var MyObj=document.all(Obj);
var iRow=MyObj.rows.length;
var iLen=MyObj.rows[0].cells.length;
var i,j;

TableData=new Array();
for (i=0;i< iRow;i++){
TableData[i]=new Array();
for (j=0;j<iLen;j++){
TableStr=MyObj.rows(i).cells(j).innerText;
TableStr=TableStr.substring(LeftLen, TableStr.length-RightLen).Trim();
TableStr=TableStr.replace(/ /gi,””).replace(/\r\n/ig,””);
TableData[i][j]=TableStr;
}
}

this.TableData=TableData;
this.cols=this.TableData[0].length;
this.rows=this.TableData.length;
this.rowindex=0;
}

function movenext(Step){
if (this.rowindex>=this.rows){
return
}

if (Step==”” || typeof(Step)==”undefined”) {
if (this.rowindex<this.rows-1)
this.rowindex++;
return;

}
else{
if (this.rowindex + Step<=this.rows-1 && this.rowindex + Step>=0 ){
this.rowindex=this.rowindex + Step;
}
else
{
if (this.rowindex + Step<0){
this.rowindex= 0;
return;
}
if (this.rowindex + Step>this.rows-1){
this.rowindex= this.rows-1;
return;
}
}
}
}

function getfielddata(Field){
var colindex=-1;
var i=0;
if (typeof(Field) == “number”){
colindex=Field;
}
else
{
for (i=0;i<this.cols && this.rowindex<this.rows ;i++){
if (this.TableData[0][i]==Field){
colindex=i;
break;
}
}
}
if (colindex!=-1) {
return this.TableData[this.rowindex][colindex];
}

}

function sort_desc(){//降序
var colindex=-1;
var highindex=-1;
desc_array=new Array();
var i,j;
for (n=0; n<arguments.length; n++){
Field=arguments[arguments.length-1-n];
for (i=0;i<this.cols;i++){
if (this.TableData[0][i]==Field){
colindex=i;
break;
}
}
if ( colindex==-1 )
return;
else
{
desc_array[0]=this.TableData[0];
for(i=1;i<this.rows;i++){
desc_array[i]=this.TableData[1];
highindex=1;
for(j=1;j<this.TableData.length;j++){
if (desc_array[i][colindex]<this.TableData[j][colindex]){
desc_array[i]=this.TableData[j];
highindex=j;
}

}
if (highindex!=-1)
this.TableData=this.TableData.slice(0,highindex).concat(this.TableData.slice(highindex+1,this.TableData.length));
}
}

this.TableData=desc_array;
}
return;
}

function sort_asc(){//升序
var colindex=-1;
var highindex=-1;
var i,j;
for (n=0; n<arguments.length; n++){
asc_array=new Array();
Field=arguments[arguments.length-1-n];
for (i=0;i<this.cols;i++){
if (this.TableData[0][i]==Field){
colindex=i;
break;
}
}
if ( colindex==-1 )
return;
else
{
asc_array[0]=this.TableData[0];
for(i=1;i<this.rows;i++){
asc_array[i]=this.TableData[1];
highindex=1;
for(j=1;j<this.TableData.length;j++){//找出最小的列值
if (asc_array[i][colindex]>this.TableData[j][colindex]){
asc_array[i]=this.TableData[j];
highindex=j;

}

}
if (highindex!=-1)
this.TableData=this.TableData.slice(0,highindex).concat(this.TableData.slice(highindex+1,this.TableData.length));

}
}

this.TableData=asc_array;
}
return;
}

function getData(Field,FieldValue){
var colindex=-1;
var i,j;

GetData=new Array();
if (typeof(Field)==”undefined” || typeof(FieldValue)==”undefined” ){
return this.TableData;
}

for(j=0;j<this.cols;j++){
if (this.TableData[0][j]==Field){
colindex=j;
}
}
if (colindex!=-1){

for(i=1;i<this.rows;i++){
if (this.TableData[i][colindex]==FieldValue){
GetData[i]=new Array();
GetData[i]=this.TableData[i];
}
}
}
return GetData;
}
function DeletE(){
this.TableData=this.TableData.slice(0,this.rowindex).concat(this.TableData.slice(this.rowindex+1,this.TableData.length));
this.rows=this.TableData.length;
return;
}
function updateField(Field,FieldValue){
var colindex=-1;
var i=0;
if (typeof(Field) == “number”){
colindex=Field;
}
else
{
for (i=0;i<this.cols && this.rowindex<this.rows ;i++){
if (this.TableData[0][i]==Field){
colindex=i;
break;
}
}
}
if (colindex!=-1) {
this.TableData[this.rowindex][colindex]=FieldValue;
}

}
function movefirst(){
this.rowindex=0;
}
function movelast(){
this.rowindex=this.rows-1;
}
function String.prototype.Trim() {return this.replace(/(^\s*)|(\s*$)/g,””);}
GetTableData.prototype.MoveNext = movenext;
GetTableData.prototype.GetFieldData = getfielddata;
GetTableData.prototype.Sort_asc = sort_asc;
GetTableData.prototype.Sort_desc = sort_desc;
GetTableData.prototype.GetData = getData;
GetTableData.prototype.Delete = DeletE;
GetTableData.prototype.UpdateField = updateField;
GetTableData.prototype.MoveFirst = movefirst;

具体的例子:http://202.119.73.208/NetEAn/com/test/jsprint.htm

在每个文本框的onblur事件中调用校验代码,并且每个文本框中onKeyDown事件中写一个enter转tab函数

//回车键换为tab
function enterToTab()
{
if(event.srcElement.type != ‘button’ && event.srcElement.type != ‘textarea’
&& event.keyCode == 13)
{
event.keyCode = 9;
}
}

应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下:

在b/s开发中经常用到的javaScript技术整理

一、验证类
1、数字验证内
  1.1 整数
  1.2 大于0的整数 (用于传来的ID的验证)
  1.3 负整数的验证
  1.4 整数不能大于iMax
  1.5 整数不能小于iMin
2、时间类
  2.1 短时间,形如 (13:04:06)
  2.2 短日期,形如 (2003-12-05)
  2.3 长时间,形如 (2003-12-05 13:04:06)
  2.4 只有年和月。形如(2003-05,或者2003-5)
  2.5 只有小时和分钟,形如(12:03)
3、表单类
  3.1 所有的表单的值都不能为空
  3.2 多行文本框的值不能为空。
  3.3 多行文本框的值不能超过sMaxStrleng
  3.4 多行文本框的值不能少于sMixStrleng
  3.5 判断单选框是否选择。
  3.6 判断复选框是否选择.
  3.7 复选框的全选,多选,全不选,反选
  3.8 文件上传过程中判断文件类型
4、字符类
  4.1 判断字符全部由a-Z或者是A-Z的字字母组成
  4.2 判断字符由字母和数字组成。
  4.3 判断字符由字母和数字,下划线,点号组成.且开头的只能是下划线和字母
  4.4 字符串替换函数.Replace();
5、浏览器类
  5.1 判断浏览器的类型
  5.2 判断ie的版本
  5.3 判断客户端的分辨率
 
6、结合类
  6.1 email的判断。
  6.2 手机号码的验证
  6.3 身份证的验证
 
二、功能类

1、时间与相关控件类
  1.1 日历
  1.2 时间控件
  1.3 万年历
  1.4 显示动态显示时钟效果(文本,如OA中时间)
  1.5 显示动态显示时钟效果 (图像,像手表)
2、表单类
  2.1 自动生成表单
  2.2 动态添加,修改,删除下拉框中的元素
  2.3 可以输入内容的下拉框
  2.4 多行文本框中只能输入iMax文字。如果多输入了,自动减少到iMax个文字(多用于短信发送)
 
3、打印类
  3.1 打印控件
4、事件类
  4.1 屏蔽右键
  4.2 屏蔽所有功能键
  4.3 –> 和<– F5 F11,F9,F1
  4.4 屏蔽组合键ctrl+N
5、网页设计类
  5.1 连续滚动的文字,图片(注意是连续的,两段文字和图片中没有空白出现)
  5.2 html编辑控件类
  5.3 颜色选取框控件
  5.4 下拉菜单
  5.5 两层或多层次的下拉菜单
  5.6 仿IE菜单的按钮。(效果如rongshuxa.com的导航栏目)
  5.7 状态栏,title栏的动态效果(例子很多,可以研究一下)
  5.8 双击后,网页自动滚屏
6、树型结构。
  6.1 asp+SQL版
  6.2 asp+xml+sql版
  6.3 java+sql或者java+sql+xml
7、无边框效果的制作
8、连动下拉框技术
9、文本排序

一、验证类
1、数字验证内
  1.1 整数
      /^(-|\+) \d+$/.test(str)
  1.2 大于0的整数 (用于传来的ID的验证)
      /^\d+$/.test(str)
  1.3 负整数的验证
      /^-\d+$/.test(str)
2、时间类
  2.1 短时间,形如 (13:04:06)
      function isTime(str)
      {
        var a = str.match(/^(\d{1,2})(:) (\d{1,2})\2(\d{1,2})$/);
        if (a == null) {alert(‘输入的参数不是时间格式’); return false;}
        if (a[1]>24 || a[3]>60 || a[4]>60)
        {
          alert(“时间格式不对”);
          return false
        }
        return true;
      }
  2.2 短日期,形如 (2003-12-05)
      function strDateTime(str)
      {
         var r = str.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/);
         if(r==null)return false;
         var d= new Date(r[1], r[3]-1, r[4]);
         return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]);
      }
  2.3 长时间,形如 (2003-12-05 13:04:06)
      function strDateTime(str)
      {
        var reg = /^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/;
        var r = str.match(reg);
        if(r==null)return false;
        var d= new Date(r[1], r[3]-1,r[4],r[5],r[6],r[7]);
        return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]&&d.getHours()==r[5]&&d.getMinutes()==r[6]&&d.getSeconds()==r[7]);
      }
  2.4 只有年和月。形如(2003-05,或者2003-5)
  2.5 只有小时和分钟,形如(12:03)
3、表单类
  3.1 所有的表单的值都不能为空
      <input onblur=”if(this.value.replace(/^\s+|\s+$/g,”)==”)alert(‘不能为空!’)”>
  3.2 多行文本框的值不能为空。
  3.3 多行文本框的值不能超过sMaxStrleng
  3.4 多行文本框的值不能少于sMixStrleng
  3.5 判断单选框是否选择。
  3.6 判断复选框是否选择.
  3.7 复选框的全选,多选,全不选,反选
  3.8 文件上传过程中判断文件类型
4、字符类
  4.1 判断字符全部由a-Z或者是A-Z的字字母组成
      <input onblur=”if(/[^a-zA-Z]/g.test(this.value))alert(‘有错’)”>
  4.2 判断字符由字母和数字组成。
      <input onblur=”if(/[^0-9a-zA-Z]/g.test(this.value))alert(‘有错’)”>
  4.3 判断字符由字母和数字,下划线,点号组成.且开头的只能是下划线和字母
      /^([a-zA-z_]{1})([\w]*)$/g.test(str)
  4.4 字符串替换函数.Replace();
5、浏览器类
  5.1 判断浏览器的类型
      window.navigator.appName
  5.2 判断ie的版本
      window.navigator.appVersion
  5.3 判断客户端的分辨率
      window.screen.height;  window.screen.width;
 
6、结合类
  6.1 email的判断。
      function ismail(mail)
      {
        return(new RegExp(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/).test(mail));
      }
  6.2 手机号码的验证
  6.3 身份证的验证
      function isIdCardNo(num)
      {
        if (isNaN(num)) {alert(“输入的不是数字!”); return false;}
        var len = num.length, re;
        if (len == 15)
          re = new RegExp(/^(\d{6})() (\d{2})(\d{2})(\d{2})(\d{3})$/);
        else if (len == 18)
          re = new RegExp(/^(\d{6})() (\d{4})(\d{2})(\d{2})(\d{3})(\d)$/);
        else {alert(“输入的数字位数不对!”); return false;}
        var a = num.match(re);
        if (a != null)
        {
          if (len==15)
          {
            var D = new Date(“19″+a[3]+”/”+a[4]+”/”+a[5]);
            var B = D.getYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5];
          }
          else
          {
            var D = new Date(a[3]+”/”+a[4]+”/”+a[5]);
            var B = D.getFullYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5];
          }
          if (!B) {alert(“输入的身份证号 “+ a[0] +” 里出生日期不对!”); return false;}
        }
        return true;
      }

3.7 复选框的全选,多选,全不选,反选
<form name=hrong>
<input type=checkbox name=All onclick=”checkAll(‘mm’)”>全选<br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/>
<input type=checkbox name=mm onclick=”checkItem(‘All’)”><br/><br/>

<input type=checkbox name=All2 onclick=”checkAll(‘mm2’)”>全选<br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>
<input type=checkbox name=mm2 onclick=”checkItem(‘All2’)”><br/>

</form>

<SCRIPT LANGUAGE=”java script”>
function checkAll(str)
{
  var a = document.getElementsByName(str);
  var n = a.length;
  for (var i=0; i<n; i++)
  a[i].checked = window.event.srcElement.checked;
}
function checkItem(str)
{
  var e = window.event.srcElement;
  var all = eval(“document.hrong.”+ str);
  if (e.checked)
  {
    var a = document.getElementsByName(e.name);
    all.checked = true;
    for (var i=0; i<a.length; i++)
    {
      if (!a[i].checked){ all.checked = false; break;}
    }
  }
  else all.checked = false;
}
</SCRIPT>

3.8 文件上传过程中判断文件类型
<input type=file onchange=”alert(this.value.match(/^(.*)(\.)(.{1,8})$/)[3])”>

画图:
<OBJECT
id=S
style=”LEFT: 0px; WIDTH: 392px; TOP: 0px; HEIGHT: 240px”
height=240
width=392
classid=”clsid:369303C2-D7AC-11D0-89D5-00A0C90833E6″>
</OBJECT>
<SCRIPT>
S.DrawingSurface.ArcDegrees(0,0,0,30,50,60);
S.DrawingSurface.ArcRadians(30,0,0,30,50,60);
S.DrawingSurface.Line(10,10,100,100);
</SCRIPT>

写注册表:
<SCRIPT>
var WshShell = WScript.CreateObject(“WScript.Shell”);
WshShell.RegWrite (“HKCU\\Software\\ACME\\FortuneTeller\\”, 1, “REG_BINARY”);
WshShell.RegWrite (“HKCU\\Software\\ACME\\FortuneTeller\\MindReader”, “Goocher!”, “REG_SZ”);
var bKey =    WshShell.RegRead (“HKCU\\Software\\ACME\\FortuneTeller\\”);
WScript.Echo (WshShell.RegRead (“HKCU\\Software\\ACME\\FortuneTeller\\MindReader”));
WshShell.RegDelete (“HKCU\\Software\\ACME\\FortuneTeller\\MindReader”);
WshShell.RegDelete (“HKCU\\Software\\ACME\\FortuneTeller\\”);
WshShell.RegDelete (“HKCU\\Software\\ACME\\”);
</SCRIPT>

TABLAE相关(客户端动态增加行列)
<HTML>
<SCRIPT LANGUAGE=”JScript”>
function numberCells() {
    var count=0;
    for (i=0; i < document.all.mytable.rows.length; i++) {
        for (j=0; j < document.all.mytable.rows(i).cells.length; j++) {
            document.all.mytable.rows(i).cells(j).innerText = count;
            count++;
        }
    }
}
</SCRIPT>
<BODY onload=”numberCells()”>
<TABLE id=mytable border=1>
<TR><TH>&nbsp;</TH><TH>&nbsp;</TH><TH>&nbsp;</TH><TH>&nbsp;</TH></TR>
<TR><TD>&nbsp;</TD><TD>&nbsp;</TD><TD>&nbsp;</TD><TD>&nbsp;</TD></TR>
<TR><TD>&nbsp;</TD><TD>&nbsp;</TD><TD>&nbsp;</TD><TD>&nbsp;</TD></TR>
</TABLE>
</BODY>
</HTML>

1.身份证严格验证:

<script>
var aCity={11:”北京”,12:”天津”,13:”河北”,14:”山西”,15:”内蒙古”,21:”辽宁”,22:”吉林”,23:”黑龙江”,31:”上海”,32:”江苏”,33:”浙江”,34:”安徽”,35:”福建”,36:”江西”,37:”山东”,41:”河南”,42:”湖北”,43:”湖南”,44:”广东”,45:”广西”,46:”海南”,50:”重庆”,51:”四川”,52:”贵州”,53:”云南”,54:”西藏”,61:”陕西”,62:”甘肃”,63:”青海”,64:”宁夏”,65:”新疆”,71:”台湾”,81:”香港”,82:”澳门”,91:”国外”}
 

function cidInfo(sId){
 var iSum=0
 var info=””
 if(!/^\d{17}(\d|x)$/i.test(sId))return false;
 sId=sId.replace(/x$/i,”a”);
 if(aCity[parseInt(sId.substr(0,2))]==null)return “Error:非法地区”;
 sBirthday=sId.substr(6,4)+”-“+Number(sId.substr(10,2))+”-“+Number(sId.substr(12,2));
 var d=new Date(sBirthday.replace(/-/g,”/”))
 if(sBirthday!=(d.getFullYear()+”-“+ (d.getMonth()+1) + “-” + d.getDate()))return “Error:非法生日”;
 for(var i = 17;i>=0;i –) iSum += (Math.pow(2,i) % 11) * parseInt(sId.charAt(17 – i),11)
 if(iSum%11!=1)return “Error:非法证号”;
 return aCity[parseInt(sId.substr(0,2))]+”,”+sBirthday+”,”+(sId.substr(16,1)%2 “男”:”女”)
}

document.write(cidInfo(“380524198002300016″),”<br/>”);
document.write(cidInfo(“340524198002300019″),”<br/>”)
document.write(cidInfo(“340524197711111111″),”<br/>”)
document.write(cidInfo(“34052419800101001x”),”<br/>”);
</script>

2.验证IP地址
<SCRIPT LANGUAGE=”java script”>
function isip(s){
 var check=function(v){try{return (v<=255 && v>=0)}catch(x){return false}};
 var re=s.split(“.”)
 return (re.length==4) (check(re[0]) && check(re[1]) && check(re[2]) && check(re[3])):false
}

var s=”202.197.78.129″;
alert(isip(s))
</SCRIPT>

 

3.加sp1后还能用的无边框窗口!!
<HTML XMLNS:IE>
<meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″>
<IE:Download ID=”include” STYLE=”behavior:url(#default#download)” />
<title>Chromeless Window</title>

<SCRIPT LANGUAGE=”JScript”>
/*— Special Thanks For andot —*/

/*
 This following code are designed and writen by Windy_sk <seasonx@163.net>
 You can use it freely, but u must held all the copyright items!
*/

/*— Thanks For andot Again —*/

var CW_width = 400;
var CW_height = 300;
var CW_top = 100;
var CW_left = 100;
var CW_url = “/”;
var New_CW = window.createPopup();
var CW_Body = New_CW.document.body;
var content = “”;
var CSStext = “margin:1px;color:black; border:2px outset;border-style:expression(onmouseout=onmouseup=function(){this.style.borderStyle=’outset’}, onmousedown=function(){if(event.button!=2)this.style.borderStyle=’inset’});background-color:buttonface;width:16px;height:14px;font-size:12px;line-height:11px;cursor:Default;”;

//Build Window
include.startDownload(CW_url, function(source){content=source});

function insert_content(){
 var temp = “”;
 CW_Body.style.overflow  = “hidden”;
 CW_Body.style.backgroundColor = “white”;
 CW_Body.style.border  =  “solid black 1px”;
 content = content.replace(/<a ([^>]*)>/g,”<a onclick=’parent.open(this.href);return false’ $1>”);
 temp += “<table width=100% height=100% cellpadding=0 cellspacing=0 border=0>”;
 temp += “<tr style=’;font-size:12px;background:#0099CC;height:20;cursor:default’ ondblclick=\”Max.innerText=Max.innerText==’1′ ‘2’:’1′;parent.if_max=!parent.if_max;parent.show_CW();\” onmouseup=’parent.drag_up(event)’ onmousemove=’parent.drag_move(event)’ onmousedown=’parent.drag_down(event)’ onselectstart=’return false’ oncontextmenu=’return false’>”;
 temp += “<td style=’color:#ffffff;padding-left:5px’>Chromeless Window For IE6 SP1</td>”;
 temp += “<td style=’color:#ffffff;padding-right:5px;’ align=right>”;
 temp += “<span id=Help  onclick=\”alert(‘Chromeless Window For IE6 SP1  –  Ver 1.0\\n\\nCode By Windy_sk\\n\\nSpecial Thanks For andot’)\” style=\””+CSStext+”font-family:System;padding-right:2px;\”> </span>”;
 temp += “<span id=Min   onclick=’parent.New_CW.hide();parent.blur()’ style=\””+CSStext+”font-family:Webdings;\” title=’Minimum’>0</span>”;
 temp += “<span id=Max   onclick=\”this.innerText=this.innerText==’1′ ‘2’:’1′;parent.if_max=!parent.if_max;parent.show_CW();\” style=\””+CSStext+”font-family:Webdings;\” title=’Maximum’>1</span>”;
 temp += “<span id=Close onclick=’parent.opener=null;parent.close()’ style=\””+CSStext+”font-family:System;padding-right:2px;\” title=’Close’>x</span>”;
 temp += “</td></tr><tr><td colspan=2>”;
 temp += “<div id=include style=’overflow:scroll;overflow-x:hidden;overflow-y:auto; HEIGHT: 100%; width:”+CW_width+”‘>”;
 temp += content;
 temp += “</div>”;
 temp += “</td></tr></table>”;
 CW_Body.innerHTML = temp;
}

setTimeout(“insert_content()”,1000);

var if_max = true;
function show_CW(){
 window.moveTo(10000, 10000);
 if(if_max){
  New_CW.show(CW_top, CW_left, CW_width, CW_height);
  if(typeof(New_CW.document.all.include)!=”undefined”){
   New_CW.document.all.include.style.width = CW_width;
   New_CW.document.all.Max.innerText = “1”;
  }
 
 }else{
  New_CW.show(0, 0, screen.width, screen.height);
  New_CW.document.all.include.style.width = screen.width;
 }
}

window.onfocus  = show_CW;
window.onresize = show_CW;

// Move Window
var drag_x,drag_y,draging=false

function drag_move(e){
 if (draging){
  New_CW.show(e.screenX-drag_x, e.screenY-drag_y, CW_width, CW_height);
  return false;
 }
}

function drag_down(e){
 if(e.button==2)return;
 if(New_CW.document.body.offsetWidth==screen.width && New_CW.document.body.offsetHeight==screen.height)return;
 drag_x=e.clientX;
 drag_y=e.clientY;
 draging=true;
 e.srcElement.setCapture();
}

function drag_up(e){
 draging=false;
 e.srcElement.releaseCapture();
 if(New_CW.document.body.offsetWidth==screen.width && New_CW.document.body.offsetHeight==screen.height) return;
 CW_top  = e.screenX-drag_x;
 CW_left = e.screenY-drag_y;
}

</SCRIPT>
</HTML>

电话号码的验证

要求:
  (1)电话号码由数字、”(“、”)”和”-“构成
  (2)电话号码为3到8位
  (3)如果电话号码中包含有区号,那么区号为三位或四位
  (4)区号用”(“、”)”或”-“和其他部分隔开
  (5)移动电话号码为11或12位,如果为12位,那么第一位为0
  (6)11位移动电话号码的第一位和第二位为”13″
  (7)12位移动电话号码的第二位和第三位为”13″
  根据这几条规则,可以与出以下正则表达式:
  (^[0-9]{3,4}\-[0-9]{3,8}$)|(^[0-9]{3,8}$)|(^\([0-9]{3,4}\)[0-9]{3,8}$)|(^0{0,1}13[0-9]{9}$)

<script language=”java script”>
function PhoneCheck(s) {
var str=s;
var reg=/(^[0-9]{3,4}\-[0-9]{3,8}$)|(^[0-9]{3,8}$)|(^\([0-9]{3,4}\)[0-9]{3,8}$)|(^0{0,1}13[0-9]{9}$)/
alert(reg.test(str));
}
</script>
<input type=text name=”iphone”>
<input type=button onclick=”PhoneCheck(document.all.iphone.value)” value=”Check”>

具有在输入非数字字符不回显的效果,即对非数字字符的输入不作反应。
function numbersonly(field,event){
 var key,keychar;
 if(window.event){
  key = window.event.keyCode;
 }
 else if (event){
  key = event.which;
 }
 else{
  return true
 }
 keychar = String.fromCharCode(key);
 if((key == null)||(key == 0)||(key == 8)||(key == 9)||(key == 13)||(key == 27)){
  return true;
 }
 else if((“0123456789.”).indexOf(keychar)>-1){
  window.status = “”;
  return true;
 }
 else {
  window.status = “Field excepts numbers only”;
  return false;
 }
}

验证ip

str=document.RegExpDemo.txtIP.value;
if(/^(\d{1,3})\.(\d{1,3})\.(\d{1,3})\.(\d{1,3})$/.test(str)==false)
{
 window.alert(‘错误的IP地址格式’);
 document.RegExpDemo.txtIP.select();
 document.RegExpDemo.txtIP.focus();
 return;
}
if(RegExp.$1<1 || RegExp.$1>254||RegExp.$2<0||RegExp.$2>254||RegExp.$3<0||RegExp.$3>254||RegExp.$4<1||RegExp.$4>254)
{
 window.alert(‘错误的IP地址’);
 document.RegExpDemo.txtIP.select();
 document.RegExpDemo.txtIP.focus();
 return;
}
//剔除 如  010.020.020.03 前面 的0
var str=str.replace(/0(\d)/g,”$1″);
str=str.replace(/0(\d)/g,”$1″);
window.alert(str);
 

彩票计算JAVA版(一)获取HTML页面的内容

彩票计算JAVA版(一)获取HTML页面的内容

主要用到了开源的两个包,pom.xml书写如下:

<dependency>

<groupId>org.htmlparser</groupId>

<artifactId>htmlparser</artifactId>

<version>1.6</version>

</dependency>

<dependency>

<groupId>cpdetector</groupId>

<artifactId>cpdetector</artifactId>

<version>1.0.5</version>

</dependency>

核心类HTMLParserUtil.java内容如下:

package com.sillycat.easyluck.common.html;

import java.io.BufferedReader;

import java.io.FileNotFoundException;

import java.io.IOException;

import java.io.InputStream;

import java.io.InputStreamReader;

import java.io.UnsupportedEncodingException;

import java.net.MalformedURLException;

import java.net.SocketException;

import java.net.SocketTimeoutException;

import java.net.URL;

import java.net.UnknownHostException;

import java.nio.charset.Charset;

import org.htmlparser.Parser;

import org.htmlparser.util.NodeList;

import org.htmlparser.util.ParserException;

import org.htmlparser.visitors.HtmlPage;

import cpdetector.io.ASCIIDetector;

import cpdetector.io.CodepageDetectorProxy;

import cpdetector.io.JChardetFacade;

import cpdetector.io.ParsingDetector;

import cpdetector.io.UnicodeDetector;

public class HtmlParserUtil {

/* StringBuffer的缓冲区大小 */

public static int TRANSFER_SIZE = 4096;

/* 当前平台的行分隔符 */

public static String lineSep = System.getProperty(“line.separator”);

/* 自动探测页面编码,避免中文乱码的出现 */

public static String autoDetectCharset(URL url) {

CodepageDetectorProxy detector = CodepageDetectorProxy.getInstance();

/**

* ParsingDetector可用于检查HTML、XML等文件或字符流的编码 构造方法中的参数用于指示是否显示探测过程的详细信息

* 为false则不显示

*/

detector.add(new ParsingDetector(false));

detector.add(JChardetFacade.getInstance());

detector.add(ASCIIDetector.getInstance());

detector.add(UnicodeDetector.getInstance());

Charset charset = null;

try {

charset = detector.detectCodepage(url);

} catch (MalformedURLException mue) {

mue.printStackTrace();

} catch (IOException ie) {

ie.printStackTrace();

}

if (charset == null)

charset = Charset.defaultCharset();

return charset.name();

}

/* 按照指定编码解析标准的html页面,为建立索引做准备 */

public static String[] parseHtml(String url, String charset) {

String result[] = null;

String content = null;

try {

URL source = new URL(url);

InputStream in = source.openStream();

BufferedReader reader = new BufferedReader(new InputStreamReader(

in, charset));

String line = new String();

StringBuffer temp = new StringBuffer(TRANSFER_SIZE);

while ((line = reader.readLine()) != null) {

temp.append(line);

temp.append(lineSep);

}

reader.close();

in.close();

content = temp.toString();

} catch (UnsupportedEncodingException uee) {

uee.printStackTrace();

} catch (MalformedURLException mue) {

System.err.println(“Invalid URL : ” + url);

} catch (UnknownHostException uhe) {

System.err.println(“UnknowHost : ” + url);

} catch (SocketException se) {

System.err.println(“Socket Error : ” + se.getMessage() + ” ” + url);

} catch (SocketTimeoutException ste) {

System.err.println(“Socket Connection Time Out : ” + url);

} catch (FileNotFoundException fnfe) {

System.err.println(“broken link ”

+ ((FileNotFoundException) fnfe.getCause()).getMessage()

+ ” ignored”);

} catch (IOException ie) {

ie.printStackTrace();

}

if (content != null) {

Parser myParser = Parser.createParser(content, charset);

HtmlPage visitor = new HtmlPage(myParser);

try {

myParser.visitAllNodesWith(visitor);

String body = null;

String title = “Untitled”;

if (visitor.getBody() != null) {

NodeList nodelist = visitor.getBody();

body = nodelist.asString().trim();

}

if (visitor.getTitle() != null) {

title = visitor.getTitle();

}

result = new String[] { body, title };

} catch (ParserException pe) {

pe.printStackTrace();

}

}

return result;

}

}

测试用例HtmlParserUtilTest.java

package com.sillycat.easyluck.common.html;

import java.net.MalformedURLException;

import java.net.URL;

import junit.framework.TestCase;

import com.sillycat.easybase.utils.StringUtil;

public class HtmlParserUtilTest extends TestCase {

private String url = “http://www.mengjiang.net/listnews.asp dncp=small&anid=2&nid=14&Page=1”;

protected void setUp() throws Exception {

super.setUp();

}

protected void tearDown() throws Exception {

super.tearDown();

}

public void testDumy() {

assertTrue(true);

}

public void testAutoDetectCharset() throws MalformedURLException {

String encode = HtmlParserUtil.autoDetectCharset(new URL(url));

assertTrue(StringUtil.isNotBlank(encode));

}

public void testParseHtml() throws MalformedURLException {

String[] contexts = HtmlParserUtil.parseHtml(url, HtmlParserUtil

.autoDetectCharset(new URL(url)));

assertNotNull(contexts);

assertTrue(contexts.length == 2);

assertTrue(StringUtil.isNotBlank(contexts[0]));

assertTrue(StringUtil.isNotBlank(contexts[1]));

System.out.println(contexts[0]);

}

}

MIDletCodesigningcertificates证书申请流程

作者:kenen 文章来源:http://www.j2medev.com/Article/ShowArticle.asp ArticleID=289

Sun Java 产品代码数字签名

申请产品代码数字签名认证证书

说明: 该“证书”是用来和Sun Java SDK的签署工具(或者用SUN WTK2.2—Ktoolbar工具“文件”->“工具集”->“安全” 选项里的 “签署MIDlet”和“证书管理”)一起给“支持单独URL下载”(单独一个URL 给用户下载)或者“嵌入IENetscape URL下载”(网页中的链接方式下载)的JAR文件、Java 小应用程序(applets, 移动信息设备应用程序(midlets) 和其他的 Java 应用程序。

<shapetype id=”_x0000_t75″ stroked=”f” filled=”f” path=”m@4@5l@4@11@9@11@9@5xe” o:preferrelative=”t” o:spt=”75″ coordsize=”21600,21600″><stroke joinstyle=”miter”></stroke><formulas><f eqn=”if lineDrawn pixelLineWidth 0″></f><f eqn=”sum @0 1 0″></f><f eqn=”sum 0 0 @1″></f><f eqn=”prod @2 1 2″></f><f eqn=”prod @3 21600 pixelWidth”></f><f eqn=”prod @3 21600 pixelHeight”></f><f eqn=”sum @0 0 1″></f><f eqn=”prod @6 1 2″></f><f eqn=”prod @7 21600 pixelWidth”></f><f eqn=”sum @8 21600 0″></f><f eqn=”prod @7 21600 pixelHeight”></f><f eqn=”sum @10 21600 0″></f></formulas><path o:extrusionok=”f” gradientshapeok=”t” o:connecttype=”rect”></path><lock v:ext=”edit” aspectratio=”t”></lock></shapetype>

我们的程序是属于—>移动信息设备应用程序(midlets),在该认证范围内。

证书单价: 400美元/

一个证书,包括一对密钥(公钥/私钥对)

私钥用于jar文件摘要的加密,公钥用于对应的解密。

用户设备认证过程:

我们把“jar文件摘要加密后的信息“存放在jad描述文件中,用户安装我们的程序时,用户设备(手机)自动识别该属性,并对下载的jar文件做摘要,同时对jad文件中所包含的认证证书进行合法性检测,若不合法就退出安装或提示授权失败,若合法则提取其中的公钥对“jar文件摘要加密后的信息“解密,并相互比较,相同则安装继续,否则就退出安装。

购买证书包括以下几步:


第一步:输入具体技术负责部门(人)的联系方式(信息)。

*First Name:lee

* Last Name: james

* Title: Certificate for ****

* Company: Cping.net

* Address1:

<street w:st=”on”>NO140 WenSan Road</street><city w:st=”on”>HangZhou</city>

City

* City: <city w:st=”on”><place w:st=”on”><span lang=”EN-US” style=”FONT-FAMILY: Arial; mso-bidi-font-size: 10.5pt; mso-font-kerning: 0pt”>HangZhou</span></place></city>

* State/Province: <place w:st=”on”><state w:st=”on”><span lang=”EN-US” style=”FONT-FAMILY: Arial; mso-bidi-font-size: 10.5pt; mso-font-kerning: 0pt”>ZheJiang</span></state></place>

* ZIP/Postal Code:310012

* Country:<place w:st=”on”><country-region w:st=”on”>China</country-region></place>

* Telephone:0571********

Fax:0571********

* E-mail:kenen@cping.net

第二步:输入相关的证书信息。

粘贴证书签名申请(Certificate Signing Request (CSR))文件内容,例如mbkey.csr

的内容如下:

—–BEGIN NEW CERTIFICATE REQUEST—–

MIIBqjCCARMCAQAwajELMAkGA1UEBhMCQ04xCzAJBgNVBAgTAlpKMREwDwYDVQQHEwhIYW5nWmhv

dTETMBEGA1UEChMKYmxv2ZNuLmNvbTETMBEGA1UECxMKRGVwIG9mIHRlYzERMA8GA1UEAxMIamFt

ZXNsZWUwgZ8BBQADgY0AMIGJAoGBAMdWU29wDQYJKoZIhvcNAQEGs<chmetcnv w:st=”on” unitname=”C” sourcevalue=”8″ hasspace=”False” negative=”False” numbertype=”1″ tcsc=”0″>8c</chmetcnv>5uaa6N4x3Q4Qp697VL<chmetcnv w:st=”on” unitname=”a” sourcevalue=”17″ hasspace=”False” negative=”False” numbertype=”1″ tcsc=”0″>17A</chmetcnv>

jKQon3447DIrDBN8xDNYBxZPKeQuGZswhuLnOGY4+Dc4r6MvcfyltjW2sjutjaBvsu+3ubzkVva0

3U9I9RKrY9UjxH1EjDq/UF7iVdI1OgZ/7ORd2YiMZEUN9TBpuzGiKS+ZupMrbbNdAgMBAAGgADAN

BgkqhkiG9w0BAQUFAAOBgQCvCxgKCWzGnWzzBPTi8D3dqNAD7ec4tsZZD+40JoBaXzQL1LtKAcTN

pi/NPK9QFXDGnV/QFs/BNK5yjCH6NCdWZ4GelIL6V/i8zMiSB1r7kZRKXVvNtMAyNnMqW1R9481z

x0zMlqnXqiwXnfmMFIBP4TrrZ7cgzLo8vpEjxhSgzQ==

—–END NEW CERTIFICATE REQUEST—–

第三步:检查证书信息并输入这个证书的使用密码。


第四步:输入公司的联系方式(信息)。


第五步:输入付款方式和相关信息。


第六步:确认并提交定单

申请者确认相应的提交信息。

第七步:打印确认书并查看VeriSign的签定过程。

若确认收到定单,并已交费,则VeriSign对申请者提交的信息正确性进行签定。大致515个工作日。视具体情况而定。一旦签定符合实际,则返回相应证书,申请成功结束。

申请完成,等待VeriSign,Inc签定结果。

参考:

https://securitycenter.verisign.com/celp/enroll/selectOptions bundle_id=JavaCS&originator=Java&application_locale=VRSN_US&checkPrice=false&promoCode=

http://eclipseme.org/docs/refSigning.html