随笔 - 31  文章 - 2  trackbacks - 0
javascript 事件查询综合
click() 对象 .click() 使对象被点击。
closed 对象 .closed 对象窗口是否已关闭 true/false
clearTimeout( 对象 ) 清除已设置的 setTimeout 对象
clearInterval( 对象 ) 清除已设置的 setInterval 对象
confirm(" 提示信息 ") 弹出确认框,确定返回 true 取消返回 false
cursor: 样式 更改鼠标样式 hand crosshair text wait help default auto e/s/w/n-resize
 
event.clientX 返回最后一次点击鼠标 X 坐标值;
event.clientY 返回最后一次点击鼠标 Y 坐标值;
event.offsetX 返回当前鼠标悬停 X 坐标值
event.offsetY 返回当前鼠标悬停 Y 坐标值
 
document.write(document.lastModified) 网页最后一次更新时间
document.ondblclick=x 当双击鼠标产生事件
document. 单击鼠标键产生事件
 
document.body.scrollTop; 返回和设置当前竖向滚动条的坐标值,须与函数配合 ,
document.body.scrollLeft; 返回和设置当前横向滚动务的坐标值,须与函数配合,
document.title document.title="message"; 当前窗口的标题栏文字
document.bgcolor document.bgcolor=" 颜色值 "; 改变窗口背景颜色
document.Fgcolor document.Fgcolor=" 颜色值 "; 改变正文颜色
document.linkcolor document.linkcolor=" 颜色值 "; 改变超联接颜色
document.alinkcolor document.alinkcolor=" 颜色值 "; 改变正点击联接的颜色
document.VlinkColor document.VlinkColor=" 颜色值 "; 改变已访问联接的颜色
document.forms.length 返回当前页 form 表单数
document.anchors.length 返回当前页锚的数量
document.links.length 返回当前页联接的数量
document. 单击鼠标触发事件
document.ondblclick=x 双击鼠标触发事件
defaultStatus window.status=defaultStatus; 将状态栏设置默认显示
 
function function xx(){...} 定义函数
isNumeric 判断是否是数字
innerHTML xx= 对象 .innerHTML 输入某对象标签中的 html 源代码
innerText divid.innerText=xx 将以 div 定位以 id 命名的对象值设为 XX
 
location.reload(); 使本页刷新, target 可等于一个刷新的网页
 
Math.random() 随机涵数 , 只能是 0 1 之间的数 , 如果要得到其它数 , 可以为 *10, 再取整
Math.floor(number) 将对象 number 转为整数,舍取所有小数
Math.min(1,2) 返回 1,2 哪个小
Math.max(1,2) 返回 1,2 哪个大
 
navigator.appName 返回当前浏览器名称
navigator.appVersion 返回当前浏览器版本号
navigator.appCodeName 返回当前浏览器代码名字
navigator.userAgent 返回当前浏览器用户代标志
 
onsubmit onsubmit="return(xx())" 使用函数返回值
opener opener.document. 对象 控制原打开窗体对象
 
prompt xx=window.prompt(" 提示信息 "," 预定值 "); 输入语句
parent parent. 框架名 . 对象 控制框架页面
 
return return false 返回值
random 随机参数( 0 1 之间)
reset() form.reset(); 使 form 表单内的数据重置
 
split("") string.split("") string 对象字符以逗号隔开
submit() form 对象 .submit() 使 form 对象提交数据
 
String 对象的 charAt(x) 对象 反回指定对象的第多少位的字母
lastIndexOf("string") 从右到左询找指定字符,没有返回 -1
indexOf("string") 从左到右询找指定字符,没有返回 -1
LowerCase() 将对象全部转为小写
UpperCase() 将对象全部转为大写
substring(0,5) string.substring(x,x) 返回对象中从 0 5 的字符
setTimeout("function",time) 设置一个超时对象
setInterval("function",time) 设置一个超时对象
 
toLocaleString() x.toLocaleString() x 时间对象中获取时间,以字符串型式存在
typeof( 变量名 ) 检查变量的类型,值有: String,Boolean,Object,Function,Underfined
 
window.event.button==1/2/3 鼠标键左键等于 1 右键等于 2 两个键一起按为 3
window.screen.availWidth 返回当前屏幕宽度 ( 空白空间 )
window.screen.availHeight 返回当前屏幕高度 ( 空白空间 )
window.screen.width 返回当前屏幕宽度 ( 分辨率值 )
window.screen.height 返回当前屏幕高度 ( 分辨率值 )
window.document.body.offsetHeight; 返回当前网页高度
window.document.body.offsetWidth; 返回当前网页宽度
window.resizeTo(0,0) 将窗口设置宽高
window.moveTo(0,0) 将窗口移到某位置
window.focus() 使当前窗口获得焦点
window.scroll(x,y) 窗口滚动条坐标, y 控制上下移动,须与函数配合
window.open() window.open(" 地址 "," 名称 "," 属性 ")
属性 :toolbar( 工具栏 ),location( 地址栏 ),directions,status( 状态栏 ),
menubar( 菜单栏 ),scrollbar( 滚动条 ),resizable( 改变大小 ), width( ),height( ),fullscreen( ),scrollbars( 全屏时无滚动条无参 ,channelmode( 宽屏 ),left( 打开窗口 x 坐标 ),top( 打开窗口 y 坐标 )
window.location = 'view-source:' + window.location.href 应用事件查看网页源代码 ;
 
 
a=new Date(); // 创建 a 为一个新的时期对象
y=a.getYear(); //y 的值为从对象 a 中获取年份值 两位数年份
y1=a.getFullYear(); // 获取全年份数 四位数年份
m=a.getMonth(); // 获取月份值
d=a.getDate(); // 获取日期值
d1=a.getDay(); // 获取当前星期值
h=a.getHours(); // 获取当前小时数
m1=a.getMinutes(); // 获取当前分钟数
s=a.getSeconds(); // 获取当前秒钟数
 
 
对象 .style.fontSize=" 文字大小 ";
单位: mm/cm/in 英寸 /pc /pt /px 象素 /em 文字高
1in =1.25cm
1pc=12pt
1pt =1.2px(800*600 分辩率下 )
 
文本字体属性:
fontSize 大小
family 字体
color 颜色
fontStyle 风格,取值为 normal 一般 ,italic 斜体 ,oblique 斜体且加粗
fontWeight 加粗 , 取值为 100 900 不等 ,900 最粗 ,light,normal,bold
letterSpacing 间距 , 更改文字间距离 , 取值为 ,1pt,10px,1cm
textDecoration: 文字修饰 ; 取值 ,none 不修饰 ,underline 下划线 ,overline 上划线
background: 文字背景颜色 ,
backgroundImage: 背景图片 , 取值为图片的插入路径
 
 
点击网页正文函数调用触发器:
 
1.onClick 当对象被点击
2.onLoad 当网页打开 , 只能书写在 body
3.onUnload 当网页关闭或离开时 , 只能书写在 body
4. 当鼠标悬于其上时
5. 当鼠标离开对象时
6. 当鼠标松开
7. 当鼠标按下键
8.onFocus 当对象获取焦点时
9.onSelect 当对象的文本被选中时
10.onChange 当对象的内容被改变
11.onBlur 当对象失去焦点
onsubmit=return(ss()) 表单调用时返回的值
 
直线 border-bottom:1x solid black
虚线 border-bottom:1x dotted black
点划线 border-bottom:2x dashed black
双线 border-bottom:5x double black
槽状 border-bottom:1x groove black
脊状 border-bottom:1x ridge black
 
 
1. 边缘高光 glow(color= 颜色 ,strength= 亮光大小 )<br/>
2. 水平翻转 fliph() 使对象水平翻转 180 <br/>
3. 垂直翻转 flipv() 使对象垂直翻转 180 <br/>
4. 对象模糊 blur(add=true/false direction= 方向 strength= 强度 )
add 指定是否按印象画派进行模糊 direction 模糊方向 strength 模糊强度
5. 对象透明 alpha(opaction=0-100,finishopacity=0-100,style=0/1/2/3)
opaction 对象整体不透明值 finishopacity 当对象利用了渐透明时该项指定结束透明位置的不透明值 style 指定透明方式 0 为整体透明, 1 为线型透明, 2 为圆型透明, 3 为矩形透明
6. 去除颜色 chroma(color= 颜色值 ) 使对象中颜色与指定颜色相同区域透明
7. 建立阴影 dropshadow(color= 阴影颜色 ,offx= 水平向左偏离像素 ,offy= 水平向下偏离像素 )
8. 去色 gray() 使对象呈灰度显示
9. 负片效果 invert() 使对象呈底片效果
10. 高光 light() 使对象呈黑色显示
11. 遮盖 mask(color= 颜色 ) 使整个对象以指定颜色进行蒙板一次
 
opacity 表透明度水平 .0~100,0 表全透明 ,100 表完全不透明
finishopacity 表想要设置的渐变透明效果 .0~100.
style 表透明区的形状 .0 表统一形状 .1 表线形 .2 表放射形 .3 表长方形 .
startx.starty 表渐变透明效果的开始时 X Y 坐标 .
finishx,finishy 渐变透明效果结束时 x,y 的坐标 .
add 有来确定是否在模糊效果中使有原有目标 . 值为 0,1.0 " ",1 " ".
direction 设置模糊的方向 .0 度表垂直向上 ,45 度为一个单位 . 默认值是向左 270 .left,right,down,up.
strength 只能用整数来确定 . 代表有多少个像素的宽度将受到模糊影响 . 默认是 5 .
color 要透明的颜色 .
offx,offy 分别是 x,y 方向阴影的偏移量 .
positive 指投影方式 .0 表透明像素生成阴影 .1 表只给出不透明像素生成阴影 ..
 
AddAmbient: 加入包围的光源 .
AddCone: 加入锥形光源 .
AddPoint 加入点光源
Changcolor: 改变光的颜色.
Changstrength: 改变光源的强度.
Clear: 清除所有的光源.
MoveLight: 移动光源.
 
freq 是波纹的频率,在指定在对象上一区需要产生多少个完事的波纹.
lightstrength 可对于波纹增强光影的效果.显著 0~100 正整数,正弦波开始位置是 0~360 度. 0 表从 0 度开始, 25 表从 90 度开始.
strength 表振幅大小.
 
 
hand style="cursor:hand"
crosshair style="cursor:crosshair"
text style="cursor:text"
wait style="cursor:wait"
default style="cursor:default"
help style="cursor:help"
e-resize style="cursor:e-resize"
ne-resize style="cursor:ne-resize"
n-resize style="cursor:n-resize"
nw-resize style="cursor:nw-resize"
w-resize style="cursor:w-resize"
s-resize style="cursor:s-resize"
sw-resize style="cursor:sw-resize "
se-resize style="cursor:se-resize"
auto style="cursor:auto"
 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> 数字输入控制 , 给数字加上千分符 </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
<style>
.inputRight {
 text-align: right;
 border: 1px #666666  dashed; 
 font-size: 9pt;
 color: #993366;
 height: 18px;
 ime-mode : disabled;
}
</style>
<SCRIPT LANGUAGE="JavaScript">
/*
这些功能建议通过 HTC 来实现
*/
////////////
// 数字输入控制
function FormatInput(dotlen)
{
var myEle=event.srcElement;
var myValue=String.fromCharCode(event.keyCode);
if (myEle.readOnly)
{
return;
}
switch(dotlen)
{
// 原正则表达式 ( 可以输入负数 ):/^[\-]?\d*\.?\d{0,0}$/
case 0:{event.returnValue = regInput(myEle, /^\d*\.?\d{0,0}$/,  myValue); break;}
case 1:{event.returnValue = regInput(myEle, /^\d*\.?\d{0,1}$/,  myValue); break;}
case 2:{event.returnValue = regInput(myEle, /^\d*\.?\d{0,2}$/,  myValue); break;}
case 3:{event.returnValue = regInput(myEle, /^\d*\.?\d{0,3}$/,  myValue); break;}
case 4:{event.returnValue = regInput(myEle, /^\d*\.?\d{0,4}$/,  myValue); break;}
case 5:{event.returnValue = regInput(myEle, /^\d*\.?\d{0,5}$/,  myValue); break;}
case 6:{event.returnValue = regInput(myEle, /^\d*\.?\d{0,6}$/,  myValue); break;}
case 7:{event.returnValue = regInput(myEle, /^\d*\.?\d{0,7}$/,  myValue); break;}
case 8:{event.returnValue = regInput(myEle, /^\d*\.?\d{0,8}$/,  myValue); break;}
default :{event.returnValue = regInput(myEle, /^\d*\.?\d{0,0}$/,  myValue); break;}
}
}
function regInput(obj, reg, inputStr)
{
var docSel = document.selection.createRange()
if (docSel.parentElement().tagName != "INPUT") return false
oSel = docSel.duplicate()
oSel.text = ""
var srcRange = obj.createTextRange()
 
oSel.setEndPoint("StartToStart", srcRange)
var str = oSel.text + inputStr + srcRange.text.substr(oSel.text.length)
return reg.test(str)
}
// 给数字加上千分符 by yuanzy
function splitNumber(eValue)
{
var intPart = "";
var decPart = "";
if (eValue.indexOf(",")>=0)
{
eValue=eValue.replace(/,/g,"");
}
if (eValue.indexOf(".")>=0)
{
intPart=eValue.split(".")[0];
decPart=eValue.split(".")[1];
}
else
{
intPart = eValue;
}
var num  =  intPart+""; 
    var  re=/(-?\d+)(\d{3})/ 
    while(re.test(num)){ 
num=num.replace(re,"$1,$2") 
    } 
if (eValue.indexOf(".")>=0)
{
eValue=num + "." + decPart;
}
else
{
eValue=num ;
}
return eValue;
}
 
function oFocus()
{
if (event.srcElement.readOnly) return;
event.srcElement.value=event.srcElement.value.replace(/,/g,"");
}
 
function oBlur()
{
if (event.srcElement.value=="-")
{
event.srcElement.value="";
}
event.srcElement.value = splitNumber(event.srcElement.value);
}
 
</SCRIPT>
</HEAD>
 
<BODY>
 
<input class="inputRight" type='text'  onfocus="oFocus();" onblur="oBlur();" onKeypress="FormatInput(2);" >
</BODY>
</HTML>
 
 
IE 功能汇总
<OBJECT id=WebBrowser height=0 width=0
      classid=CLSID:8856F961-340A-11D0-A96B-00C04FD705A2></OBJECT>
<INPUT onclick=document.all.WebBrowser.ExecWB(1,1) type=button value= 打开 name=Button1>
<INPUT onclick=document.all.WebBrowser.ExecWB(4,1) type=button value= 另存为 name=Button2>
<INPUT onclick=document.all.WebBrowser.ExecWB(10,1) type=button value= 属性 name=Button3>
<INPUT onclick=document.all.WebBrowser.ExecWB(6,1) type=button value= 打印 name=Button>
<INPUT onclick=document.all.WebBrowser.ExecWB(8,1) type=button value= 页面设置 name=Button4>
<INPUT onclick=window.location.reload() type=button value= 刷新 name=refresh>
<INPUT onclick="window.external.ImportExportFavorites(true,'');" type=button value= 导入收藏夹 name=Button5>
<INPUT onclick="window.external.ImportExportFavorites(false,'');" type=button value= 导出收藏夹 name=Button32>
<INPUT onclick="window.external.AddFavorite(location.href, document.title)" type=button value= 加入收藏夹 name=Button22>
 <INPUT onclick="window.external.ShowBrowserUI('OrganizeFavorites', null)" type=button value= 整理收藏夹 name=Submit2>
<INPUT onclick='window.location="view-source:" + window.location.href' type=button value= 查看源文件 name=Button7>
<INPUT onclick="window.external.ShowBrowserUI('LanguageDialog', null)" type=button value= 语言设置 name=Button6>
 <INPUT onclick="document.execCommand('Cut')" type=button value= 剪切 >
 <INPUT onclick="document.execCommand('Copy')" type=button value= 拷贝 >
 <INPUT onclick="document.execCommand('Paste')" type=button value= 粘贴 >
<INPUT onclick="document.execCommand('Undo')" type=button value= 撤消 >
 <INPUT onclick="document.execCommand('Delete')" type=button value= 删除 >
<INPUT onclick="document.execCommand('Bold')" type=button value= 黑体 >
 <INPUT onclick="document.execCommand('Italic')" type=button value= 斜体 >
 <INPUT onclick="document.execCommand('Underline')" type=button value= 下划线 >
 <INPUT onclick="document.execCommand('stop')" type=button value= 停止 >
 <INPUT onclick="document.execCommand('SaveAs')" type=button value= 保存 >
 <INPUT onclick="document.execCommand('Saveas',false,'c:\\test.htm')" type=button value= 另存为 >
<INPUT onclick="document.execCommand('FontName',false,fn)" type=button value= 字体 >
<INPUT onclick="document.execCommand('FontSize',false,fs)" type=button value= 字体大小 >
<INPUT onclick="document.execCommand('refresh',false,0)" type=button value= 刷新 >
<INPUT onclick=window.location.reload() type=button value= 刷新 >
 <INPUT onclick=history.go(1) type=button value= 前进 >
 <INPUT onclick=history.go(-1) type=button value= 后退 >
 <INPUT onclick=history.forward() type=button value= 前进 >
 <INPUT onclick=history.back() type=button value= 后退 >
 <INPUT onclick='window.external.ImportExportFavorites(true,"http://localhost");' type=button value= 导入收藏夹 >
<INPUT onclick='window.external.ImportExportFavorites(false,"http://localhost");' type=button value= 导出收藏夹 >
<INPUT onclick="window.external.ShowBrowserUI('OrganizeFavorites', null)" type=button value= 整理收藏夹 >
<INPUT onclick="window.location = 'view-source:'+ window.location.href" type=button value= 查看源文件 >
<INPUT onclick="window.external.ShowBrowserUI('LanguageDialog', null)" type=button value= 语言设置 >
<INPUT onclick="window.external.AddFavorite('http://www.cnblogs.com/hbzxf/', 阿好空间 )" type=button value= 加入收藏夹 >
<INPUT onclick="window.external.addChannel('http://www.cnblogs.com/hbzxf/')" type=button value= 加入到频道 >
<INPUT onclick="this.style.behavior='url(#default#homepage)';this.setHomePage('http://www.cnblogs.com/hbzxf/')" type=button value= 设成主页 >
 
窗口打开自动最大化代码
<!-- 窗口打开后最大化 -->
<OBJECT id="max" type="application/x-oleobject" classid="clsid:adb880a6-d8ff-11cf-9377-00aa003b7a11"><PARAM name="Command" value="Maximize"></OBJECT>
<script>
if(window.screenLeft!=0)
max.Click();
</script>
<!-- 窗口打开后最大化结束 -->
 
利用脚本封装,方便实现网站悬浮广告
 
下面是 JS 脚本 (floatdiv.js)
/*======================================================================
  浮动块支持脚本
  DESIGN BY :  彭国辉
  DATE:        2004-02-26
  SITE:        http://kacarton.yeah.net/
  BLOG:        http://blog.csdn.net/nhconch
  EMAIL:       kacarton@sohu.com
 
  文章为作者原创,转载前请先与本人联系,转载请注明文章出处、保留作者信息,谢谢支持!
======================================================================*/
 
var alLeft = 0, alCenter = 1, alRight  = 2;   // 水平对齐方式
var alTop  = 0, alMiddle = 1, alBottom = 2;   // 垂直对齐方式
 
var f = new Array();
var cnt = 0;
 
function floatDiv(objId, align, vAlign, x, y, smooth)
{
    /* 浮动块对象
      数据结构:
        objId 对象 ID
        align 水平对齐方式,枚举型
        vAlign :垂直对齐方式,枚举型内容
        x, y   xy 坐标,整型
        smooth :平滑移动,布尔型
    */
    this.objId  = objId;
    this.align  = align;
    this.vAlign = vAlign;
    this.x = x;
    this.y = y;
    this.smooth = smooth;
}
 
function addDiv(objId, align, vAlign, x, y, smooth)
{   // 添加浮动块
    f[cnt++] = new floatDiv(objId, align, vAlign, x, y, smooth);
}
 
function floatMove()
{   // 重新定位各块位置
    var objX, objY;
    if (document.all)
    {
        var d = document.body;
//status = "scrollLeft:"+f[0].objId.style.pixelTop+"| offsetWidth:"+d.offsetWidth;
        for (var i=0; i<f.length; i++)
        {
            switch (f[i].align)
            {
                case alLeft  : objX = d.scrollLeft + f[i].x; break;
                case alCenter: objX = d.scrollLeft + Math.ceil((d.offsetWidth - f[i].objId.offsetWidth)/2) + f[i].x; break;
                case alRight : objX = d.scrollLeft + d.offsetWidth - f[i].x - f[i].objId.offsetWidth - 20; break; // 减滚动条 20
            }
            switch (f[i].vAlign)
            {
                case alTop   : objY = d.scrollTop + f[i].y; break;
                case alMiddle: objY = d.scrollTop + Math.ceil((d.offsetHeight - f[i].objId.offsetHeight)/2) + f[i].y; break;
                case alBottom: objY = d.scrollTop + d.offsetHeight - f[i].y - f[i].objId.offsetHeight; break;
            }
            if (f[i].smooth)
smoothMove(f[i].objId, objX, objY);
            else
            {
                f[i].objId.style.pixelLeft = objX;
                f[i].objId.style.pixelTop  = objY;
            }
        }
    }
   
    if (document.layers)
    {
        for (var i=0; i<f.length; i++)
        {
            var objId = f[i].objId;
            switch (f[i].align)
            {
                case alLeft  : objX = pageXOffset + f[i].x; break;
                case alCenter: objX = pageXOffset + Math.ceil((window.innerWidth-objId.width)/2) + f[i].x; break;
                case alRight : objX = pageXOffset + window.innerWidth - f[i].x - document.objId.width; break;
            }
            switch (f[i].vAlign)
            {
                case alTop   : objY = pageYOffset + f[i].y; break;
                case alMiddle: objY = pageYOffset + Math.ceil(window.innerHeight/2) + f[i].y; break;
                case alBottom: objY = pageYOffset + window.innerHeight - f[i].y - document.objId.height; break;
            }
            if (t[i].smooth) smoothMove(f[i].objId, objX, objY);
            else
            {
                document.objId.left = objX;
                document.objId.top  = objY;
            }
        }
    }
   
    setTimeout("floatMove();",50);
}
 
function smoothMove(obj, x, y)
{
    var percent;
    if (document.all)
    {
        percent = .1 * (x - obj.style.pixelLeft);
        if (percent > 0) percent = Math.ceil(percent); else percent = Math.floor(percent);
        obj.style.pixelLeft += percent;
       
        percent = .1 * (y - obj.style.pixelTop);
        if (percent > 0) percent = Math.ceil(percent); else percent = Math.floor(percent);
        obj.style.pixelTop += percent;
    }
    if (document.layers)
    {
        percent = .1 * (x - document.objId.left);
        if (percent > 0) percent = Math.ceil(percent); else percent = Math.floor(percent);
        document.objId.left += percent;
       
        percent = .1 * (y - document.objId.top);
        if (percent > 0) percent = Math.ceil(percent); else percent = Math.floor(percent);
        document.objId.top += percent;
    }
}
 
 
setTimeout("floatMove();",50);
 
 
调用例子:
 
<script language="javascript" src="lib/floatdiv.js"></script>
<script language="javascript">
if (navigator.appName == "Netscape")
{
    document.write("<layer id=ad_hr top=300 width=100 height=120><a href=http://www.fpc.org.cn/hr/040522.htm target=_blank><img src='ad/hr40522.gif' width=120 height=180 border=0></a></layer>");
}
else
{
    document.write("<div id=ad_hr style='position: absolute;width:120;top:300;left:5;visibility: visible;z-index: 1'><a href=http://www.fpc.org.cn/hr/040522.htm target=_blank><img src='ad/hr40522.gif' width=120 height=180 border=0></a></div>");
}
addDiv(ad_hr, alRight, alTop, 0, 30, true);
</script>
 
 
[ 原创 ] 自己定义的简单方法验证表单数据
方法很简单,先是定义好要验证的数组比如 :
check_array[0]= new Array(title, 留言主题不能为空 !);
然后判断,错误的就提示定义的内容,代码如下 :
 
<script language="javascript">
 // 表单验证程序;
 
  // 定义获取表单元素;
  function $()
  {
    var elements = new Array();
 
    for (var i = 0; i < arguments.length; i++) {
   var element = arguments[i];
   if (type of element == 'string')
     element = document.getElementById(element);
 
   if (arguments.length == 1)
     return element;
 
   elements.push(element);
    }
 
    return elements;
  }
 
 
 function checkform()
 {
  // 定义要验证的表单数组;
  var check_array=new Array();
  check_array[0]= new Array("title"," 留言主题不能为空 !");
  check_array[1]= new Array("name"," 姓名不能为空 !");
  check_array[2]= new Array("email"," 电子邮件不能为空 !");
  check_array[3]= new Array("phone"," 电话不能为空 !");
  check_array[4]= new Array("note"," 留言内容不能为空 !");
  
  // 验证定义表单是否为空 ;
  for(var i=0;i<check_array.length;i++)
  {
   if($(check_array[i][0]).value=="")
   {
    alert(check_array[i][1]);
    $(check_array[i][0]).focus();
    return false;
   }
  }
 
 }
</script>
 
几个表单验证的
function checkMail(obj,error)
{
    if (obj == null)
return "NULL";
    if (obj.value == "")
return "EMPTY";
    var filter  = /^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/;
    if (filter.test(obj.value))
return true;
    else
alert(error);
return false;
}
 
function verifyDottedIP(cntrl,errmsg1,errmsg2,flag)
{
    ip_str = cntrl.value;
 
 
if (ip_str == "") {
 if (flag == 1){
 
alert(errmsg1);
cntrl.select();
    return false;
}
    return true;
}else{
varval = 0;
vari = index = 0;
 
while (index < ip_str.lastIndexOf(".")){
k = index;
index = ip_str.indexOf(".", index);
val = toNumber(ip_str, k, index);
 
if (val < 0 || val > 255)
break;
i++;
index++;
}
 
if (i == 3){
if (index == ip_str.length){
i = 2;
} else {
val = toNumber(ip_str,index, ip_str.length);
if (val < 0 || val > 255) i = 2;
}
}
 
if (i != 3) {
alert(errmsg2);
cntrl.select();
return false;
}
}
return true;
}
 
function verifyport(cntrl,errmsg1,errmsg2,flag)
    {
    varval = 0;
 
    port_str = cntrl.value;
if (port_str == "") {
 if (flag == 1){
 
alert(errmsg1);
cntrl.select();
    return false;
}}
    val = toNumber(port_str, 0, port_str.length);
 
    if (val < 0 || val > 65535)
    {
 
       
 
alert(errmsg2);
cntrl.select();
    return false;
    }
    else
    {
    return true;
    }
    }
 
 
function checkname(field,err_blank,err_space,err_invalid)
{
if (field.value.indexOf(" ") >=0)
   {
alert(err_space);
field.focus();
field.select();
return false;
}
 
left_trim(field);
right_trim(field);
 
 
 
 
if (field.value =="" | field.value == null)
{
 
alert(err_blank);
field.focus();
field.select();
return false;
}
 
 
if (checkOtherChar(field.value, err_invalid)==false)
{
field.focus();
field.select();
return false;
}
if (isChinese(field.value)==true)
{
field.focus();
field.select();
return false;
}
 
return true;
}
 
function isChinese(inputStr){
      iLength = inputStr.length
      for (i = 0; i < iLength; i++)
        if (inputStr.charCodeAt(i) > 255){
            alert("Input error!");
            return true ;
           }
     return false ;
}
 
 
function left_trim(field)
{
 var tmp_string = field.value;
 while (''+tmp_string.charAt(0) == ' ')
 tmp_string = tmp_string.substring(1,tmp_string.length);
 
 field.value = tmp_string;
 
}
 
function right_trim(field)
{
 var tmp_string = field.value;
 
 while (''+tmp_string.charAt(tmp_string.length-1) == ' ')
 tmp_string = tmp_string.substring(0,tmp_string.length-1);
 
 field.value = tmp_string;
}
 
function  checkOtherChar(str,errmsg) {
       for(var loop_index=0; loop_index<str.length; loop_index++)
        {
         if(str.charAt(loop_index) == '~'
           ||str.charAt(loop_index) == '!'
           ||str.charAt(loop_index) == '@'
           ||str.charAt(loop_index) == '#'
           ||str.charAt(loop_index) == '$'
           ||str.charAt(loop_index) == '%'
           ||str.charAt(loop_index) == '^'
           ||str.charAt(loop_index) == '&'
           ||str.charAt(loop_index) == '*'
           ||str.charAt(loop_index) == '('
           ||str.charAt(loop_index) == ')'
           ||str.charAt(loop_index) == '+'
           ||str.charAt(loop_index) == '{'
           ||str.charAt(loop_index) == '}'
           ||str.charAt(loop_index) == '|'
           ||str.charAt(loop_index) == ':'
           ||str.charAt(loop_index) == '"'
           ||str.charAt(loop_index) == '<'
           ||str.charAt(loop_index) == '>'
           ||str.charAt(loop_index) == '?'
           ||str.charAt(loop_index) == '`'
           ||str.charAt(loop_index) == '='
           ||str.charAt(loop_index) == '['
           ||str.charAt(loop_index) == ']'
           ||str.charAt(loop_index) == '\\'
           ||str.charAt(loop_index) == ';'
           ||str.charAt(loop_index) == '\''
           ||str.charAt(loop_index) == ','
           ||str.charAt(loop_index) == '.'
           ||str.charAt(loop_index) == '/')
          {
           
            alert(errmsg);
            return false;
      }
         }
      return true;
   }
 
function check_pwd_eq(element1,element2,errmsg)
{
if (element1.value == element2.value)
{
return true;
}
else
{
alert(errmsg);
element1.select();
return false;
}
}
 
function check_pwd(field,errmsg1)
{
 
  if (field.value == "") {
      alert(errmsg1);
      field.focus();
      return false;
}
 
  
 
 
  return true;
}
 
function verifynum(cntrl,errmsg3,flag,errmsg1,errmsg2,from,to)
    {
    varval = 0;
    num_str = cntrl.value;
   if (num_str.indexOf(" ") >=0)
   {
alert(errmsg3);
cntrl.focus();
cntrl.select();
return false;
}
 
if (flag == 1) {
if (num_str == "") {
alert(errmsg1);
    return false;
}}
    val = toNumber(num_str, 0, num_str.length);
 
 
 
    if ((val < from || val > to) && (num_str != ""))
    {
alert(errmsg2);
    return false;
    }
    else
    {
    return true;
    }
    }
 
判断浏览器类型
<SCRIPT language=JavaScript>
if(navigator.appVersion.indexOf("MSIE 6.") != -1 ){
window.location = "111.htm" ;
}
 
</SCRIPT>
 
按钮背景图片替换
<input type=button style="background-image:url(a.gif)" value=test onmouseover="this.style.backgroundImage='url(b.gif)'" onmouseout='this.style.backgroundImage='url(a.gif)'' ID="Button1" NAME="Button1"/>
 
document.getElementById(id) 的最简化调用
/*--------------------------------------------------------------------------*/
 
/**
 * 这个函数就 Ruby 了。我觉得它的作用主要有两个
 * 1.  大概是 document.getElementById(id) 的最简化调用。
 * 比如: $(aaa) 将返回 aaa 对象
 * 2.  得到对象数组
 * 比如 : $(aaa,bbb) 返回一个包括 id aaa bbb 两个
 input 控件对象的数组。
 */
function $() {
  var elements = new Array();
 
  for (var i = 0; i < arguments.length; i++) {
    var element = arguments[i];
    if (typeof element == 'string')
      element = document.getElementById(element);
 
    if (arguments.length == 1)
      return element;
 
    elements.push(element);
  }
 
  return elements;
}
 
<script language="Javascript">
// 屏蔽鼠标右键、 Ctrl+N Shift+F10 F5 刷新、退格键
// 屏蔽 F1 帮助
function window.onhelp()
{
return false
}
function KeyDown()
{
//alert(event.keyCode);
// 屏蔽 Alt+ 方向键 屏蔽 Alt+ 方向键
if ((window.event.altKey)&&((window.event.keyCode==37)||(window.event.keyCode==39)))
{
//alert(" 不准你使用 ALT+ 方向键前进或后退网页! ");
event.returnValue=false;
}
// 屏蔽退格删除键 , 屏蔽 F5 刷新键 ,Ctrl + R
if ((event.keyCode==116)||(event.ctrlKey && event.keyCode==82))
{
event.keyCode=0;
event.returnValue=false;
}
 
// 屏蔽 Ctrl+n
if ((event.ctrlKey)&&(event.keyCode==78))
{
event.returnValue=false;
}
 
// 屏蔽 shift+F10
if ((event.shiftKey)&&(event.keyCode==121))
{
event.returnValue=false;
}
 
// 屏蔽 shift 加鼠标左键新开一网页
if (window.event.srcElement.tagName == "A" && window.event.shiftKey)
{
window.event.returnValue = false;
}
 
// 屏蔽 Alt+F4
if ((window.event.altKey)&&(window.event.keyCode==115))
{
window.showModelessDialog("about:blank","","dialogWidth:1px;dialogheight:1px");
return false;
}
 
// 屏蔽 Ctrl+A
if((event.ctrlKey)&&(event.keyCode==65))
{
return false;
}
return false;
}
document.onkeydown=KeyDown;
</script>
 
根据身份证号码取得生日与性别,并判断 18 位身份证的正确与错误 :
function showBirthday(val){
var birthdayValue;
if(15==val.length){//15 位身份证号码
birthdayValue = val.charAt(6)+val.charAt(7);
if(parseInt(birthdayValue)<10){
birthdayValue = '20'+birthdayValue;
}else{
birthdayValue = '19'+birthdayValue;
}
birthdayValue=birthdayValue+'-'+val.charAt(8)+val.charAt(9)+'-'+val.charAt(10)+val.charAt(11);
if(parseInt(val.charAt(14)/2)*2!=val.charAt(14))
document.all.sex.value=' ';
else
document.all.sex.value=' ';
document.all.birthday.value=birthdayValue;
}
if(18==val.length){//18 位身份证号码
birthdayValue=val.charAt(6)+val.charAt(7)+val.charAt(8)+val.charAt(9)+'-'+val.charAt(10)+val.charAt(11)+'-'+val.charAt(12)+val.charAt(13);
if(parseInt(val.charAt(16)/2)*2!=val.charAt(16))
document.all.sex.value=' ';
else
document.all.sex.value=' ';
if(val.charAt(17)!=IDCard(val)){
document.all.idCard.style.backgroundColor='#ffc8c8';
}else{
document.all.idCard.style.backgroundColor='white';
}
document.all.birthday.value=birthdayValue;
}
}
 
// 18 位身份证号最后一位校验
function IDCard(Num)
{
if (Num.length!=18)
return false;
var x=0;
var y='';
 
for(i=18;i>=2;i--)
x = x + (square(2,(i-1))%11)*parseInt(Num.charAt(19-i-1));
x%=11;
y=12-x;
if (x==0) y='1';
if (x==1) y='0';
if (x==2) y='X';
return y;
}
// 求得 x y 次方
function square(x,y)
{
var i=1;
for (j=1;j<=y;j++)
i*=x;
return i;
}
 
 
身份证 <input type="text" name="idCard">
性别 <input type="text" name="sex">
生日 <input type="text" name="birthday">
 
获取页面中控件的 ID:( 查错时可能有用 )
 
function clk()
{
document.all('TextBox1').value=event.srcElement.id;
}
 
document.onclick=clk;
 
 
  B.27 string 对象
  它不是另一个对象的属性 , 而是一个内置对象 , 即一串字符字符串输入脚本中时必须位于引号内。
  属性
   length 字符串中的字符个数
  方法
   anchor() 用来把字符串转换到 HTML 锚点标记内 (<A NAME=>)
   big() 把字符串中的文本变成大字体 (<BIG>)
   blink() 把字符串中的文本变成闪烁字体 (<BLINK>)
   bold() 把字符串中的文本变成黑字体 (<B>)
   charAt() 寻找字符串中指定位置的一个字符
   fixed() 把字符串中的文本变成固定间距字体 (<TT>)
   fontcolor() 改变字符串中文本的颜色 (<FONT COLOR=>)
   fontsize() 把字符串中的文本变成指定大小 (<FONTSIZE=>)
   indexOf() 用来搜索字符串中的某个特殊字符 , 并返回该字符的索引位置
   italics() 把字符串中的文本变成斜字体 (<I>)
   lastlndexOf() indexof 相似 , 但是向后搜索最后一个出现的字符
   link() 用来把字符串转换到 HTML 链接标记中 (<A HREF=>)
   small() 把字符串中的文本变成小字体 (<SMALL>)
   strike() 把字符串中的文本变成划掉字体 (<STRIKE>)
   sub() 把字符串中的文本变成下标 (subscript) 字体 ((SUB>)
   substring() 返回字符串里指定位置间的一部分字符串
   sup() 把字符串中的文本变成上标 (superscript) 字体 (<SUP>)
   toLowerCase() 把字符串中的文本变成小写
   toUpperCase() 把字符串中的文本变成大写
 
   B.28 submit 对象
  它是 form 对象的一个属性 , 窗体中的一个提交按钮 (<INPUT TYPE= SUBMIT >)
  属性
   name 对象的名字 (NAME= 特性 )
   value VALUE= 特性
  方法
   click 模拟鼠标单击按钮
  事件处理程序
   Onclick 点击
 
   B.29 text 对象
  它是 form 对象的一个属性 , 宙体中的一个文本域 (<INPUT TYPE= TEXT >)
  属性
   defaultValue text 对象的缺省值 (VALUE= 特性 )
   name 该对象的名字 (NAME= 特性 )
   Value 该域具有的当前值 , 最初与 VALUE= 特性 (defaultValue) 相同但是 , 如果脚本修改了该域中的值 , 则该值将改变
  方法
   blur 把焦点从文本框移开
   focus 把焦点移到文本框
   select 选择输入区域
  事件处理程序
   Onblur 失去焦点事件
   Onchange 更改
   Onfocus 聚焦事件
   Onselect 选取事件
 
   B.30 textarea 对象
  它是 form 对象的一个属性 , 宙体中的一个文本区域 (<TEXTAREA>)
  属性
   defaultValue textarea 对象的缺省值 (VALUE= 特性 )
   name 该对象的名字 (NAME= 特性 )
   value 该域具有的当前值 , 最初与 VALUE= 特性 (defaultValue) 相同 , 但是 , 如果脚本修改了该域中的值 , 则该值将改变了。
  方法
   blur 把焦点从文本区移开
   focus 把焦点移到文本区
   select 选择输入区域事件处理程序
  事件处理程序
   Onblur 失去焦点事件
   Onchange 更改
   Onfocus 聚焦事件
   Onselect 选取事件
 
   B.31 window 对象
  它是一个顶层对象 , 而不是另一个对象的属性即浏览器的窗口。
  属性
   defaultStatus 缺省的状态条消息
   document 当前显示的文档 ( 该属性本身也是一个对象 )
   frame 窗口里的一个框架 ((FRAME>)( 该属性本身也是一个对象 )
   frames array 列举窗口的框架对象的数组 , 按照这些对象在文档中出现的顺序列出 ( 该属性本身也是一个对象 )
   history 窗口的历史列表 ( 该属性本身也是一个对象 )
   length 窗口内的框架数
   location 窗口所显示文档的完整 ( 绝对 )URL( 该属性本身也是一个对象 ) 不要把它与如 document.location 混淆 , 后者是当前显示文档的 URL 。用户可以改变 window.location( 用另一个文档取代当前文档 ), 但却不能改变 document.location( 因为这是当前显示文档的位置 )
   name 窗口打开时 , 赋予该窗口的名字
   opener 代表使用 window.open 打开当前窗口的脚本所在的窗口 ( 这是 Netscape Navigator 3.0beta 3 所引入的一个新属性 )
   parent 包含当前框架的窗口的同义词。 frame window 对象的一个属性
   self 当前窗口或框架的同义词
   status 状态条中的消息
   top 包含当前框架的最顶层浏览器窗口的同义词
   window 当前窗口或框架的同义词 , self 相同
  方法
   alert() 打开一个 Alert 消息框
   clearTimeout() 用来终止 setTimeout 方法的工作
   close() 关闭窗口
   confirm() 打开一个 Confirm 消息框 , 用户可以选择 OK Cancel, 如果用户单击 OK, 该方法返回 true, 单击 Cancel 返回 false
   blur() 把焦点从指定窗口移开 ( 这是 Netscape Navigator 3.0 beta 3 引入的新方法 )
   focus() 把指定的窗口带到前台 ( 另一个新方法 )
   open() 打开一个新窗口
   prompt() 打开一个 Prompt 对话框 , 用户可向该框键入文本 , 并把键入的文本返回到脚本
   setTimeout() 等待一段指定的毫秒数时间 , 然后运行指令事件处理程序
  事件处理程序
   Onload() 页面载入时触发
   Onunload() 页面关闭时触发
 
 
   B.16 images 数组
  它是 document 对象的一个属性 , 文档中所有图像的列表。
  属性
   length 文档内的图像个数
 
   B.17 link
  它是 document 对象的一个属性 , 文档内的一个 <A HREF=> 标记。
  属性
   hash 以散列号 (#) 开始的一个字符串 , 用于指定 URL 内的一个锚点
   host 包括冒号和端口号的 URL 的主机名部分
   hostname host 属性相同 , 除了不包括冒号和端口号外
   href 完整的 URL
   pathname URL 的目录路径部分
   port URL : 端口部分
   protocol URL 类型 (http: ftp: gopher: 等等 )
   search 以一个问号开始的 URL 中的一部分 , 用于指定搜索信息
   target 当用户单击一链接 (TARGET 特性 ) , 用于显示被引用文档内容的窗口
  事件处理程序
   Onclick 点击
   Onmouseover 鼠标移到对象上
 
   B.18 links 数组
  它是 document 对象的一个属性 , 文档内所有链接的一个列表。
  属性
   length 文档内的链接数
 
   B.19 location 对象
  它为 document 对象的一个属性 , 该文档的完整 URL ,请不要把它与 window.location 属性相混淆 , 后者可用来加载一个新文档 , 并且 window.location 属性本身并不是一个对象,同时 ,window.location 可以用脚本修改 , document.location 则不能。
  属性
   hash 以散列号 (#) 开始的一个字符串 , 用于指定 URL 内的一个锚点
   host 包括冒号和端口号的 URL 的主机名部分
   hostname host 属性相同 , 除了不包括冒号和端口号之外
   href 完整的 URL
   pathname URL 的目录路径部分
   port URL : 端口部分
   protocol URL 的类型 (http: ftp: gopher: 等等 )
   search 以问号 (?) 开始的 URL 中的一部分 , 用于指定搜索信息
   target 用户单击链接 (TARGET 特性 ) , 用于显示被引用文档的内容的窗口
 
   B.20 math 对象
  该对象不是其它对象的一个属性 , 而是一个内置对象 , 包含了许多数学常量和函数。
  属性
   E 欧拉常量 , 自然对数的底 ( 约等于 2.718)
   LN2 2 的自然对数 ( 约等于 0.693)
   LN10 10 的自然对数 ( 约等于 2.302)
   LOG2E 2 为底的 e 的对数 ( 约等于 1.442)
   LOG10E 10 为底的 e 的对数 ( 约等于 o.434)
   PI ∏的值 ( 约等于 3.14159)
   SQRT1_2 0.5 的平方根 ( l 除以 2 的平方根 , 约等于 o.707)
   SQRT2 2 的平方根 ( 约等于 1.414)
  方法
   abs() 返回某数的绝对值 ( 即该数与 o 的距离 , 例如 ,2 与一 2 的绝对值都是 2)
   acos() 返回某数的反余弦值 ( 以弧度为单位 )
   asin() 返回某数的反正弦值 ( 以弧度为单位 )
   atan() 返回某数的反正切值 ( 以弧度为单位 )
   ceil() 返回与某数相等 , 或大于该数的最小整数 (ceil(-22.22) 返回 -22;ceil22,22) 返回 23;ceil(22) 返回 22)
   cos() 返回某数 ( 以弧度为单位 ) 的余弦值
   exp() 返回 en
   floor() ceil 相反 (floor( 22.22) 返回一 23;floor(22.22) 返回 22; floor(22) 返回 22)
   10g () 返回某数的自然对数 ( e 为底 )
   max() 返回两数间的较大值
   min() 返回两数问的较小值
   pow() 返回 m n 次方 ( 其中 ,m 为底 ,n 为指数 )
   random() 返回 0 1 之间的一个伪随机数 ( 该方法仅在 Netscape
   Navigator UNIX 版本中有效 )
   round() 返回某数四舍五入之后的整数
   sin() 返回某数 ( 以弧度为单位 ) 的正弦值
   sqrt() 返回某数的平方根
   tan() 返回某数的正切值
 
   B.2l navigator 对象
  该对象不是其它对象的属性 , 而是一个内置对象它包含了有关加载文档的浏览器的信息。
  属性
   appCodeName 浏览器的代码名 ( 例如 ,Mozilla)
   appName 浏览器的名字
   appVersion 浏览器的版本号
   userAgent 由客户机送到服务器的用户与代理头标文本
  方法
   javaEnabled JavaScript 中当前并没有该方法 , 但是不久之后将会添加上它将查看浏览器是否为兼容 JavaScript 的浏览器 , 如果是 , 继续查看 JavaScript 是否处于支持状态。
 
   B.22 options 数组
  该数组是 select 对象的一个属性 , 即选择框中的所有选项 (<OPTION>) 的一个列表。
  属性
   defaultSelected 选项列表中的缺省选项
   index 选项列表中某选项的索引位置
   length 选项列表中的选项数 (<OPTIONS>)
   name 选项列表的名字 (NAME 特性 )
   selected 表示选项列表中某选项 <OPTION> 是否被选中的一个布尔类型值
   selectedIndex 选项列表中已选中的 <OPTION> 的索引 ( 位置 )
   text 选项列表中 <OPTION> 标记后的文本
   value 选项列表中的 VALUE= 特性
 
   B.23 Password 对象
  它是 document 对象的一个属性 , 一个 <INPUT TYPE= PASSWORD > 标记。
  属性
   defaultValue password 对象的缺省值 (VAlUE= 特性 )
   name 对象的名字 (NAME= 特性 )
   value 该域具有的当前值最初与 VALUE= 特性 (defauttValue) 相同 , 但是 , 如果脚本修改了该域中的值 , 则该值将改变
  方法
   focus 把焦点从该域移开
   blur 把焦点移到该域
   select 选择输入区域
 
   B.24 radio 对象
  它是 form 对象的一个属性 , 窗体内的一组单选按钮 ( 选项按钮 )(<INPUT TYPE= RADIO >)
  属性
   checked 复选框或选项按钮 ( 单选按钮 ) 的状态
   defaultChecked 复选框或选项按钮 ( 单选按钮 ) 的缺省状态
   length 一组单选按钮中的按钮数
   name 对象的名字 (NAME= 特性 )
   value VALUE= 特性
  方法
   click 模拟鼠标单击按钮
  事件处理程序
   onclick 点击
 
   B.25 reset 对象
  它是 form 对象的一个属性 , 复位按钮 (<INPUT TYPE= RESET >)
  属性
   name 对象的名字 (NAME= 特性 )
   value VALUE= 特性
  方法
   click 模拟鼠标单击按钮
  事件处理程序
   onclick 点击
 
   B.26 select 对象
  它是 form 对象的一个属性 , 选择框 (<SELECT>)
  属性
   length 选项列表中的选项数 (<OPTIONS>)
   name 选项列表的名字 (NAME 特性 )
   options 列表中的选项数
   selectedlndex 选项列表中已选中的 <OPTION> 的索引 ( 位置 )
   text 选项列表中 (OPTION) 标记之后的文本
   value 选项列表中的 VALUE= 特性
  方法
   blur 把焦点从选项列表中移走
   focus 把焦点移到选项列表中
  事件处理程序
   Onblur 失去焦点时事件
   onchange 更改
   Onfocus 聚焦事件
本文列举了各种 JavaScript 对象与数组 , 同时包括对上述每一对象或数组所完成工作的简短描述 , 以及与其相关的属性方法 , 以及事件处理程序 , 还注明了该对象或数组的父对象用户同样可能需要参考 Online Companion 中的超级文本 Object Hierarchy 页面 (http://www.netscapepress.com/support/javascript/10-9.htm), 以便了解这些对象之间是如何相互关联的。
  顺便提一下 , 记住 , 这里把所有作为另一对象的子对象的对象看作该对象的属性请参见第十章中与此相关的注解。
 
   B.1 anchor 对象
  使用 <A NAME=> 标记创建的 HTML 描点能被一个链接作为目标如果锚点包括 HREF= 特性 , 则它也是一个链接对象。
   anchor 对象是 document 对象的一个属性 , 它本身没有属性方法或者事件处理程序。
 
   B.2 anchors 数组
   anchors 数组是 document 对象的一个属性 , 是文档内所有 anchor 对象的一个列表如果 anchor 也是一个 link( 链接 ), 则它会同时出现在 anchors links 数组中。
  属性
   length 文档内的锚点个数
 
   B.3 array 对象
   array 对象是 Netscape Navlgator 3.0 beta 3 中引入的一个新的对象 , 因而 , 它不能在 Netscape 2.0 中使用它是一个内置对象 , 而不是其它对象的属性。
  属性
    length 数组中的值个数
 
   B.4 button 对象
  它是 form 对象的一个属性 , 使用 <INPUT TYPE="BUTTON"> 标记来创建。
  属性
   name HTML 标记中的 NAME= 特性
   value HTML 标记中的 VALUE= 特性
  方法
   click 模拟鼠标单击一按钮
  事件处理程序
   Onclick
 
   B.5 checkbox 对象
  它是 form 对象的一个属性 , 使用 <INPUT TYPE="CHECKBOX"> 标记来创建。
  属性
   checked 复选框的选择状态
   defaultChecked 标记的 CHECKED= 特性
   name 标记的 NAME= 特性
   value 标记的 VALUE= 特性
  方法
   click 模拟鼠标单击按钮
  事件处理程序
   onclick
 
   B.6 Date 对象
  它是一个内置对象——而不是其它对象的属性 , 允许用户执行各种使用日期和时间的过程。
   方法
   getDate() 查看 Date 对象并返回日期
   getDay() 返回星期几
   getHours() 返回小时数
   getMinutes() 返回分钟数
   getMonth() 返回月份值
   getSeconds() 返回秒数
   getTime() 返回完整的时间
   getTimezoneoffset() 返回时区偏差值 ( 格林威治平均时间与运行脚本的计算机所处时区设置之间相差的小时数 )
   getYear() 返回年份
   parse() 返回在 Date 字符串中自从 1970 1 1 00:00:00 以来的毫秒数 (Date 对象按照毫秒数的形式存储从那时起的日期和时间 ) 但是注意 , 该方法当前不能正确运行
   setDate() 改变 Date 对象的日期
   setHours() 改变小时数
   setMinutes() 改变分钟数
   setMonth() 改变月份
   setSeconds() 改变秒数
   setTime() 改变完整的时间
   setYear() 改变年份
   toGMTString() Date 对象的日期 ( 一个数值 ) 转变成一个 GMT 时间字符串 , 返回类似下面的值 :Weds,15 June l997 14:02:02 GMT( 精确的格式依赖于计算机上所运行的操作系统而变 )
   toLocaleString() Date 对象的日期 ( 一个数值 ) 转变成一个字符串 , 使用所在计算机上配置使用的特定日期格式
   UTC() 使用 Date UTC( 年、月、日、时、分、秒 ), 以自从 1970 1 1 00:00:00( 其中时、分、秒是可选的 ) 以来的毫秒数的形式返回日期
 
   B.7 document 对象
  该对象是 window frames 对象的一个属性 , 是显示于窗口或框架内的一个文档。
  属性
   alinkColor 活动链接的颜色 (ALINK)
   anchor 一个 HTMI 锚点 , 使用 <A NAME=> 标记创建 ( 该属性本身也是一个对象 )
   anchors array 列出文档锚点对象的数组 (<A NAME=>)( 该属性本身也是一个对象 )
   bgColor 文档的背景颜色 (BGCOLOR)
   cookie 存储于 cookie.txt 文件内的一段信息 , 它是该文档对象的一个属性
   fgColor 文档的文本颜色 (<BODY> 标记里的 TEXT 特性 )
   form 文档中的一个窗体 (<FORM>)( 该属性本身也是一个对象 )
   forms anay 按照其出现在文档中的顺序列出窗体对象的一个数组 ( 该属性本身也是一个对象 )
   lastModified 文档最后的修改日期
   linkColor 文档的链接的颜色 , <BODY> 标记中的 LINK 特性 ( 链接到用户没有观察到的文档 )
   link 文档中的一个 <A HREF=> 标记 ( 该属性本身也是一个对象 )
   links array 文档中 link 对象的一个数组 , 按照它们出现在文档中的顺序排列 ( 该属性本身也是一个对象 )
   location 当前显示文档的 URL 。用户不能改变 document.location( 因为这是当前显示文档的位置 ) 。但是 , 可以改变 window.location ( 用其它文档取代当前文档 )window.location 本身也是一个对象 , document.location 不是对象
   referrer 包含链接的文档的 URL, 用户单击该链接可到达当前文档
   title 文档的标题 ((TITLE>)
   vlinkColor 指向用户已观察过的文档的链接文本颜色 , <BODY> 标记的 VLINK 特性
  方法
   clear 清除指定文档的内容
   close 关闭文档流
   open 打开文档流
   write 把文本写入文档
   writeln 把文本写入文档 , 并以换行符结尾
 
   B.8 elements 数组
  它是 form 对象的一个属性 , 列举了窗体内各元素的一个数组。
  属性
   1ength 窗体内的元素个数
   B.9 form 对象
  它是 document 对象的一个属性 , 文档内的一个窗体。
  属性
   action 包含了为一个窗体提交的目标 URL 的字符串
   button 窗体内的一个按钮 , 使用 <INPUT TYPE= BUTTON > 标记来创建 ( 该属性本身也是一个对象 )
   checkbox 复选框 , 使用 <INPUT TYPE= CHECKBOX > 标记来创建 ( 该属性本身也是一个对象 )
   elements array 一个数组 , 按照其出现于窗体内的顺序列举各窗体元素 ( 该属性本身也是一个对象 )
   encoding 窗体的 MIME 编码
    hidden 窗体里的一个隐藏元素 (<INPUT TYPE= HIDDEN >) 。窗体对象的一个属性 ( 该属性本身也是一个对象 )
   length 窗体里的元素的个数
   method 输入窗体的数据传送到服务器上的方式 , (FORM) 标记中的 METHOD 特性
   radio 设置在窗体里的单选按钮 (<INPUT TYPE= RADIO >)( 该属性本身也是一个对象 )
   reset 窗体里的复位按钮 ((1NPUT TYPE= RESET >)( 该属性自身也是一个对象 )
   select 窗体里的选择框 (<SELECT>)( 该属性本身也是一个对象 )
   submit 窗体里的提交按钮 (<INPUT TYPE= SUBMIT >)( 该属性本身也是一个对象 )
   target 提交窗体后 , 显示回应信息的窗口的名字
   text 窗体里的文本元素 (<INPUT TYPE= TEXT >)( 该属性本身也是一个对象 )
   textarta 窗体里的文本区元素 (<TEXTAREA>)( 该属性本身也是一个对象 )
  方法
   submit 提交窗体 ( 与使用 Submit 按钮的作用相同 ) 事件处理程序
   onsubmit
 
   B.10 forms 数组
  该数组是 document 对象的一个属性 , 即列举了文档内的各窗体的一个数组。
  属性
   length 文档内窗体的个数
 
   B.11 frame 对象
  它是 window 对象的一个属性 , 窗口内的一个框架。除了个别例外 ,frame 对象与 window 对象的作用相同。
  属性
   frames array 列举该框架内的各个子框架的一个数组 ( 该属性本身也是—个对象 )
   length 该框架内的框架数
   name 框架的名字 (<FRAME> 标记里的 NAME 特性 )
   parent 包含本框架的父窗口的同义词
   self 当前框架的同义词
   window 当前框架的同义词
  方法
   clearTimeout() 用来终止 setTimeout 方法的工作
   setTimeout() 等待指定的毫秒数 , 然后运行指令
 
   B.12 frames 数组
  它既是 window 对象 , 也是 frame 对象的属性 , 列举了 window 或者 frame 对象内的各框架。
  属性
   length 窗口或框架对象内的框架数
 
   B.13 hidden 对象
  糊为 form 对象的一个属性 , 窗体内的一个隐藏元素 (<INPUT TYPE= HIDDEN >)
  属性
   name 标记内的名字 (NAME 特性 )
   value 标记内的 VALUE= 特性
 
   B.14 history 对象
  它为 window 对象的一个属性 , 该窗口的历史列表。
  属性
   length 历史列表中的项目数
  方法
   back 加载历史列表中的上一个文档
   forward 加载历史列表中的下一个文档
   go 加载历史列表中的一个指定文档 , 通过文档在列表中的位置来指定
 
   B.15 image 对象
  它是 document 对象的一个属性 , 是使用 (1MG) 标记内嵌入文档里的一幅图像这是 Netscape Navigator 3.0 beta 3 引入的新对象。
  属性
   border <IMG> 标记的 BORDER 特性
   complete 表示浏览器是否完整地加载了图像的一个布尔值
   height HEIGHT 特性
   hspace HSPACE 特性
   lowsrc LOWSRC 特性
   src SRC 特性
   vsPace VSPACE 特性
   width WIDTH 特性
  事件处理程序
   Onload 图象载入
   Onerror 载入错误
   Onabort 取消
 
javascript 事件列表解说
 
事件 浏览器支持 解说
一般事件
 
onclick IE3 N2  鼠标点击时触发此事件
ondblclick IE4 N4  鼠标双击时触发此事件
IE4 N4  按下鼠标时触发此事件
IE4 N4  鼠标按下后松开鼠标时触发此事件
IE3 N2  当鼠标移动到某对象范围的上方时触发此事件
IE4 N4  鼠标移动时触发此事件
IE4 N3 当鼠标离开某对象范围时触发此事件
onkeypress IE4 N4  当键盘上的某个键被按下并且释放时触发此事件 .
onkeydown IE4 N4  当键盘上某个按键被按下时触发此事件
onkeyup IE4 N4  当键盘上某个按键被按放开时触发此事件
 
页面相关事件
onabort IE4 N3  图片在下载时被用户中断
onbeforeunload IE4 N  当前页面的内容将要被改变时触发此事件
onerror IE4 N3  出现错误时触发此事件
onload IE3 N2  页面内容完成时触发此事件
onmove IE N4  浏览器的窗口被移动时触发此事件
onresize IE4 N4  当浏览器的窗口大小被改变时触发此事件
onscroll IE4 N  浏览器的滚动条位置发生变化时触发此事件
onstop IE5 N  浏览器的停止按钮被按下时触发此事件或者正在下载的文件被中断
onunload IE3 N2  当前页面将被改变时触发此事件
 
表单相关事件
onblur IE3 N2  当前元素失去焦点时触发此事件
onchange IE3 N2  当前元素失去焦点并且元素的内容发生改变而触发此事件
onfocus IE3 N2 当某个元素获得焦点时触发此事件
onreset IE4 N3  当表单中 RESET 的属性被激发时触发此事件
onsubmit IE3 N2  一个表单被递交时触发此事件
 
滚动字幕事件
 
onbounce IE4 N Marquee 内的内容移动至 Marquee 显示范围之外时触发此事件
onfinish IE4 N Marquee 元素完成需要显示的内容后触发此事件
onstart IE4 N Marquee 元素开始显示内容时触发此事件
 
编辑事件
 
onbeforecopy IE5 N 当页面当前的被选择内容将要复制到浏览者系统的剪贴板前触发此事件
onbeforecut IE5 N 当页面中的一部分或者全部的内容将被移离当前页面 [ 剪贴 ] 并移动到浏览者的系统
剪贴板时触发此事件
 
onbeforeeditfocus IE5 N 当前元素将要进入编辑状态
onbeforepaste IE5 N 内容将要从浏览者的系统剪贴板传送 [ 粘贴 ] 到页面中时触发此事件
onbeforeupdate IE5 N 当浏览者粘贴系统剪贴板中的内容时通知目标对象
oncontextmenu IE5 N 当浏览者按下鼠标右键出现菜单时或者通过键盘的按键触发页面菜单时触发的事件
oncopy IE5 N 当页面当前的被选择内容被复制后触发此事件
oncut IE5 N  当页面当前的被选择内容被剪切时触发此事件
ondrag IE5 N  当某个对象被拖动时触发此事件 [ 活动事件 ]
ondragdrop IE N4 一个外部对象被鼠标拖进当前窗口或者帧
ondragend IE5 N 当鼠标拖动结束时触发此事件,即鼠标的按钮被释放了
ondragenter IE5 N 当对象被鼠标拖动的对象进入其容器范围内时触发此事件
ondragleave IE5 N  当对象被鼠标拖动的对象离开其容器范围内时触发此事件
ondragover IE5 N 当某被拖动的对象在另一对象容器范围内拖动时触发此事件
ondragstart IE4 N 当某对象将被拖动时触发此事件
ondrop IE5 N 在一个拖动过程中,释放鼠标键时触发此事件
onlosecapture IE5 N 当元素失去鼠标移动所形成的选择焦点时触发此事件
onpaste IE5 N 当内容被粘贴时触发此事件
onselect  IE4 N 当文本内容被选择时的事件
onselectstart IE4 N 当文本内容选择将开始发生时触发的事件
 
数据绑定
onafterupdate IE4 N 当数据完成由数据源到对象的传送时触发此事件
oncellchange IE5 N 当数据来源发生变化时
ondataavailable IE4 N 当数据接收完成时触发事件
ondatasetchanged IE4 N 数据在数据源发生变化时触发的事件
ondatasetcomplete IE4 N 当来子数据源的全部有效数据读取完毕时触发此事件
onerrorupdate IE4 N 当使用 onBeforeUpdate 事件触发取消了数据传送时,代替 onAfterUpdate 事件
onrowenter IE5 N 当前数据源的数据发生变化并且有新的有效数据时触发的事件
onrowexit IE5 N 当前数据源的数据将要发生变化时触发的事件
onrowsdelete IE5 N 当前数据记录将被删除时触发此事件
onrowsinserted IE5 N 当前数据源将要插入新数据记录时触发此事件
 
外部事件
onafterprint IE5 N 当文档被打印后触发此事件
onbeforeprint IE5 N 当文档即将打印时触发此事件
onfilterchange IE4 N 当某个对象的滤镜效果发生变化时触发的事件
onhelp IE4 N 当浏览者按下 F1 或者浏览器的帮助选择时触发此事件
onpropertychange IE5 N 当对象的属性之一发生变化时触发此事件
onreadystatechange IE4 N 当对象的初始化属性值发生变化时触发此事件
 
38. 页面进入和退出的特效
进入页面 <meta http-equiv="Page-Enter" content="revealTrans(duration=x, transition=y)">
推出页面 <meta http-equiv="Page-Exit" content="revealTrans(duration=x, transition=y)"> 
这个是页面被载入和调出时的一些特效。 duration 表示特效的持续时间,以秒为单位。 transition 表示使
 
用哪种特效,取值为 1-23:
   0 矩形缩小
   1 矩形扩大
   2 圆形缩小
   3 圆形扩大
   4 下到上刷新
   5 上到下刷新
   6 左到右刷新
   7 右到左刷新
   8 竖百叶窗
   9 横百叶窗
   10 错位横百叶窗
   11 错位竖百叶窗
   12 点扩散
   13 左右到中间刷新
   14 中间到左右刷新
   15 中间到上下
   16 上下到中间
   17 右下到左上
   18 右上到左下
   19 左上到右下
   20 左下到右上
   21 横条
   22 竖条
   23 以上 22 种随机选择一种
 
39. 在规定时间内跳转
<META http-equiv=V="REFRESH" content="5;URL=http://www.51js.com">
 
40. 网页是否被检索
<meta name="ROBOTS" content=" 属性值 ">
  其中属性值有以下一些 :
  属性值为 "all": 文件将被检索,且页上链接可被查询;
  属性值为 "none": 文件不被检索,而且不查询页上的链接;
  属性值为 "index": 文件将被检索;
  属性值为 "follow": 查询页上的链接;
  属性值为 "noindex": 文件不检索,但可被查询链接;
  属性值为 "nofollow": 文件不被检索,但可查询页上的链接。
 
网页常用小技巧
1. oncontextmenu="window.event.returnValue=false" 将彻底屏蔽鼠标右键
<table border oncontextmenu=return(false)><td>no</table> 可用于 Table
 
2. <body onselectstart="return false"> 取消选取、防止复制
 
3. onpaste="return false" 不准粘贴
 
4. oncopy="return false;" oncut="return false;" 防止复制
 
5. <link rel="Shortcut Icon" href="favicon.ico"> IE 地址栏前换成自己的图标
 
6. <link rel="Bookmark" href="favicon.ico"> 可以在收藏夹中显示出你的图标
 
7. <input style="ime-mode:disabled"> 关闭输入法
 
8. 永远都会带着框架
<script language="JavaScript"><!--
if (window == top)top.location.href="frames.htm"; //frames.htm 为框架网页
// --></script>
 
9. 防止被人 frame
<SCRIPT LANGUAGE=JAVASCRIPT><!--
if (top.location != self.location)top.location=self.location;
// --></SCRIPT>
 
10. 网页将不能被另存为
<noscript><iframe src=*.html></iframe></noscript>
 
11. <input type=button value= 查看网页源代码
onclick="window.location = "view-source:"+ "http://www.51js.com/"">
 
 
12. 删除时确认
<a href="javascript:if(confirm(" 确实要删除吗 ?"))location="boos.asp?&areyou= 删除 &page=1""> 删除 </a>
 
13. 取得控件的绝对位置
//Javascript
<script language="Javascript">
function getIE(e){
var t=e.offsetTop;
var l=e.offsetLeft;
while(e=e.offsetParent){
t+=e.offsetTop;
l+=e.offsetLeft;
}
alert("top="+t+"/nleft="+l);
}
</script>
 
//VBScript
<script language="VBScript"><!--
function getIE()
dim t,l,a,b
set a=document.all.img1
t=document.all.img1.offsetTop
l=document.all.img1.offsetLeft
while a.tagName<>"BODY"
set a = a.offsetParent
t=t+a.offsetTop
l=l+a.offsetLeft
wend
msgbox "top="&t&chr(13)&"left="&l,64," 得到控件的位置 "
end function
--></script>
 
14. 光标是停在文本框文字的最后
<script language="javascript">
function cc()
{
var e = event.srcElement;
var r =e.createTextRange();
r.moveStart("character",e.value.length);
r.collapse(true);
r.select();
}
</script>
<input type=text name=text1 value="123" onfocus="cc()">
 
15. 判断上一页的来源
javascript:
document.referrer
 
16. 最小化、最大化、关闭窗口
<object id=hh1 classid="clsid:ADB880A6-D8FF-11CF-9377-00AA003B7A11">
<param name="Command" value="Minimize"></object>
<object id=hh2 classid="clsid:ADB880A6-D8FF-11CF-9377-00AA003B7A11">
<param name="Command" value="Maximize"></object>
<OBJECT id=hh3 classid="clsid:adb880a6-d8ff-11cf-9377-00aa003b7a11">
<PARAM NAME="Command" VALUE="Close"></OBJECT>
 
<input type=button value= 最小化 onclick=hh1.Click()>
<input type=button value= 最大化 onclick=hh2.Click()>
<input type=button value= 关闭 onclick=hh3.Click()>
本例适用于 IE
 
17. 屏蔽功能键 Shift,Alt,Ctrl
<script>
function look(){
if(event.shiftKey)
alert(" 禁止按 Shift !"); // 可以换成 ALT   CTRL
}
document.onkeydown=look;
</script>
 
18. 网页不会被缓存
<META HTTP-EQUIV="pragma" CONTENT="no-cache">
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate">
<META HTTP-EQUIV="expires" CONTENT="Wed, 26 Feb 1997 08:21:57 GMT">
或者 <META HTTP-EQUIV="expires" CONTENT="0">
 
19. 怎样让表单没有凹凸感?
<input type=text style="border:1 solid #000000">
<input type=text style="border-left:none; border-right:none; border-top:none; border-bottom:
 
1 solid #000000"></textarea>
 
20.<div><span>&<layer> 的区别?
<div>(division) 用来定义大段的页面元素,会产生转行
<span> 用来定义同一行内的元素,跟 <div> 的唯一区别是不产生转行
<layer> ns 的标记, ie 不支持,相当于 <div>
 
 
21. 让弹出窗口总是在最上面 :
<body onblur="this.focus();">
 
22. 不要滚动条 ?
让竖条没有 :
<body style="overflow:scroll;overflow-y:hidden">
</body>
让横条没有 :
<body style="overflow:scroll;overflow-x:hidden">
</body>
两个都去掉?更简单了
<body scroll="no">
</body>
 
23. 怎样去掉图片链接点击后,图片周围的虚线?
<a href="#" onFocus="this.blur()"><img src="logo.jpg" border=0></a>
 
24. 电子邮件处理提交表单
<form name="form1" method="post" action="mailto:****@***.com" enctype="text/plain">
<input type=submit>
</form>
 
25. 在打开的子窗口刷新父窗口的代码里如何写?
window.opener.location.reload()
 
26. 如何设定打开页面的大小
<body onload="top.resizeTo(300,200);">
打开页面的位置 <body onload="top.moveBy(300,200);">
 
27. 在页面中如何加入不是满铺的背景图片 , 拉动页面时背景图不动
<STYLE>
body
{background-image:url(logo.gif); background-repeat:no-repeat;
 
background-position:center;background-attachment: fixed}
</STYLE>
 
28. 检查一段字符串是否全由数字组成
<script language="Javascript"><!--
function checkNum(str){return str.match(//D/)==null}
alert(checkNum("1232142141"))
alert(checkNum("123214214a1"))
// --></script>
 
29. 获得一个窗口的大小
document.body.clientWidth; document.body.clientHeight
 
30. 怎么判断是否是字符
if (/[^/x00-/xff]/g.test(s)) alert(" 含有汉字 ");
else alert(" 全是字符 ");
 
31.TEXTAREA 自适应文字行数的多少
<textarea rows=1 name=s1 cols=27 onpropertychange="this.style.posHeight=this.scrollHeight">
</textarea>
 
32. 日期减去天数等于第二个日期
<script language=Javascript>
function cc(dd,dadd)
{
// 可以加上错误处理
var a = new Date(dd)
a = a.valueOf()
a = a - dadd * 24 * 60 * 60 * 1000
a = new Date(a)
alert(a.getFullYear() + " " + (a.getMonth() + 1) + " " + a.getDate() + " ")
}
cc("12/23/2002",2)
</script>
 
33. 选择了哪一个 Radio
<HTML><script language="vbscript">
function checkme()
for each ob in radio1
if ob.checked then window.alert ob.value
next
end function
</script><BODY>
<INPUT name="radio1" type="radio" value="style" checked>Style
<INPUT name="radio1" type="radio" value="barcode">Barcode
<INPUT type="button" value="check" onclick="checkme()">
</BODY></HTML>
 
34. 脚本永不出错
<SCRIPT LANGUAGE="JavaScript">
<!-- Hide
function killErrors() {
return true;
}
window.onerror = killErrors;
// -->
</SCRIPT>
 
35.ENTER 键可以让光标移到下一个输入框
<input onkeydown="if(event.keyCode==13)event.keyCode=9">
 
36. 检测某个网站的链接速度:
把如下代码加入 <body> 区域中 :
<script language=Javascript>
tim=1
setInterval("tim++",100)
b=1
 
var autourl=new Array()
autourl[1]="www.njcatv.net"
autourl[2]="javacool.3322.net"
autourl[3]="www.sina.com.cn"
autourl[4]="www.nuaa.edu.cn"
autourl[5]="www.cctv.com"
 
function butt(){
document.write("<form name=autof>")
for(var i=1;i<autourl.length;i++)
document.write("<input type=text name=txt"+i+" size=10 value= 测试中…… > = <input type=text
 
name=url"+i+" size=40> = <input type=button value=GO
 
onclick=window.open(this.form.url"+i+".value)><br/>")
document.write("<input type=submit value= 刷新 ></form>")
}
butt()
function auto(url){
document.forms[0]["url"+b].value=url
if(tim>200)
{document.forms[0]["txt"+b].value=" 链接超时 "}
else
{document.forms[0]["txt"+b].value=" 时间 "+tim/10+" "}
b++
}
function run(){for(var i=1;i<autourl.length;i++)document.write("<img
src=http://"+autourl+"/"+Math.random()+" width=1 height=1
onerror=auto("http://"+autourl+"")>")}
run()</script>
 
37. 各种样式的光标
auto :标准光标
default :标准箭头
hand :手形光标
wait :等待光标
text I 形光标
vertical-text :水平 I 形光标
no-drop :不可拖动光标
not-allowed :无效光标
help ? 帮助光标
all-scroll :三角方向标
move :移动标
crosshair :十字标
e-resize
n-resize
nw-resize
w-resize
s-resize
se-resize
sw-resize
 
external.m2_blocked() external.m2_blocked() 方法使用详解
 
 javascript 有许多内建的方法来产生对话框,如: window.alert(),
window.confirm(),window.prompt(). 等。 然而 IE 提供更多的方法支持对话框。如:
 
   external.m2_blocked() (IE 4+ 支持 )
   external.m2_blocked() (IE 5+ 支持 )
 
 
 window.external.m2_blocked() 方法用来创建一个显示 HTML 内容的模态对话框,
由于是对话框,因此它并没有一般用 window.open() 打开的窗口的所有属性。
 window.external.m2_blocked() 方法用来创建一个显示 HTML 内容的非模态对话框。
 
  当我们用 external.m2_blocked() 打开窗口时,不必用 window.close() 去关闭它,
当以非模态方式 [IE5] 打开时, 打开对话框的窗口仍可以进行其他的操作,即对话框
不总是最上面的焦点,当打开它的窗口URL改变时,它自动关闭。而模态 [ IE4 ]
方式的对话框始终有焦点(焦点不可移走,直到它关闭)。模态对话框和打开它的窗
口相联系,因此我们打开另外的窗口时,他们的链接关系依然保存,并且隐藏在活动
窗口的下面。
 
使用方法如下:
 vReturnValue=window.external.m2_blocked(sURL [,vArguments] [,sFeatures])
 vReturnValue=window.external.m2_blocked(sURL [,vArguments] [,sFeatures])
参数说明:
 sURL
  必选参数,类型:字符串。用来指定对话框要显示的文档的 URL
 vArguments
  可选参数,类型:变体。用来向对话框传递参数。传递的参数类型不限,包括数组等。
对话框通过 window.dialogArguments 来取得传递进来的参数。
 sFeatures
  可选参数,类型:字符串。用来描述对话框的外观等信息,可以使用以下的一个或几个,
用分号“ ; ”隔开。
  dialogHeight 对话框高度,不小于100 px ,IE4中 dialogHeight dialogWidth
  默认的单位是 em ,而IE5中是 px ,为方便其见,在定义 modal 方式的对话框时,用 px
做单位。
     dialogWidth: 对话框宽度。
     dialogLeft: 距离桌面左的距离。
     dialogTop: 离桌面上的距离。
     center: {yes | no | 1 | 0 } :窗口是否居中,默认 yes ,但仍可以指定高度和宽度。
     help: {yes | no | 1 | 0 } :是否显示帮助按钮,默认 yes
     resizable: {yes | no | 1 | 0 } [ IE5+ ] :是否可被改变大小。默认 no
     status: {yes | no | 1 | 0 } [IE5+] :是否显示状态栏。默认为 yes[ Modeless]
no[Modal]
  scroll:{ yes | no | 1 | 0 | on | off } :指明对话框是否显示滚动条。默认为 yes
 
  还有几个属性是用在 HTA 中的,在一般的网页中一般不使用。
  dialogHide:{ yes | no | 1 | 0 | on | off } :在打印或者打印预览时对话框是否隐藏。
默认为 no
  edge:{ sunken | raised } :指明对话框的边框样式。默认为 raised
  unadorned:{ yes | no | 1 | 0 | on | off } :默认为 no
 
  传入参数:
  要想对话框传递参数,是通过 vArguments 来进行传递的。类型不限制,对于字符串类型,
最大为 4096 个字符。也可以传递对象,例如:
 
 test1.htm
 ====================
 <script>
  var mxh1 = new Array("mxh","net_lover"," 孟子 E ")
  var mxh2 = window.open("about:blank","window_mxh")
  // 向对话框传递数组
  window.external.m2_blocked("test2.htm",mxh1)
  // 向对话框传递 window 对象
  window.external.m2_blocked("test3.htm",mxh2)
 </script>
 
 test2.htm
 ====================
 <script>
  var a = window.dialogArguments
  alert(" 您传递的参数为: " + a)
 </script>
 
 test3.htm
 ====================
 <script>
  var a = window.dialogArguments
  alert(" 您传递的参数为 window 对象,名称: " + a.name)
 </script>
 
  可以通过 window.returnValue 向打开对话框的窗口返回信息,当然也可以是对象。
例如:
 
 test4.htm
 ===================
 <script>
  var a = window.external.m2_blocked("test5.htm")
  for(i=0;i<a.length;i++) alert(a[i])
 </script>
 
 test5.htm
 ===================
 <script>
 function sendTo()
 {
  var a=new Array("a","b")
  window.returnValue = a
  window.close()
 }
 </script>
 <body>
 <form>
  <input value=" 返回 " type=button
 </form>
 
  常见问题:
 1 ,如何在模态对话框中进行提交而不新开窗口?
  如果你 浏览器是 IE5.5+, 可以在对话框中使用带 name 属性的 iframe ,提交时可以
制定 target 为该 iframe name 。对于 IE4+ ,你可以用高度为 0 frame 来作:例子,
 
 test6.htm
 ===================
 <script>
  window.external.m2_blocked("test7.htm")
 </script>
 
 test7.htm
 ===================
 if(window.location.search) alert(window.location.search)
 <frameset rows="0,*">
  <frame src="about:blank">
  <frame src="test8.htm">
 </frameset>
 
 test8.htm
 ===================
 <form target="_self" method="get">
 <input name=txt value="test">
 <input type=submit>
 </form>
 <script>
 if(window.location.search) alert(window.location.search)
 </script>
 2, 可以通过 http://servername/virtualdirname/test.htm?name=mxh 方式直接向
对话框传递参数吗?
  答案是不能。但在 frame 里是可以的。
file:// 屏蔽 F5 刷新键
 
 
function document.onkeydown()
{
    var k = window.event.keyCode;
    if (k == 116)                   file:// 屏蔽 F5 刷新键
    {
        window.event.keyCode    = 0;
        window.event.returnValue= false;
    }
}
 
 
<script language="javascript">
 file:// 屏蔽鼠标右键、 Ctrl+N Shift+F10 F5 刷新、退格键
 file:// 屏蔽 F1 帮助
function window.onhelp()
{
   return false
}
function KeyDown()
{
  file://alert(event.keyCode);
   file:// 屏蔽 Alt+ 方向键 屏蔽 Alt+ 方向键
  if ((window.event.altKey)&&((window.event.keyCode==37)||
(window.event.keyCode==39)))
  {  
     file://alert(" 不准你使用 ALT+ 方向键前进或后退网页! ");
     event.returnValue=false;
  }
  file:// 屏蔽退格删除键 , 屏蔽 F5 刷新键 ,Ctrl + R
  if ((event.keyCode==116)||(event.ctrlKey && event.keyCode==82))
  { 
     event.keyCode=0;
     event.returnValue=false;
  } 
  
  file:// 屏蔽 Ctrl+n
  if ((event.ctrlKey)&&(event.keyCode==78))
  {  
     event.returnValue=false;
  }
  
  file:// 屏蔽 shift+F10
  if ((event.shiftKey)&&(event.keyCode==121))
  { 
     event.returnValue=false;
  }
  
  file:// 屏蔽 shift 加鼠标左键新开一网页
  if (window.event.srcElement.tagName == "A" && window.event.shiftKey) 
  {
    window.event.returnValue = false;
  }
      
   file:// 屏蔽 Alt+F4
  if ((window.event.altKey)&&(window.event.keyCode==115))
  {
      window.external.m2_blocked("about:blank","","dialogWidth:1px;dialogheight:1px");
      return false;
  }
  
  file:// 屏蔽 Ctrl+A
  if((event.ctrlKey)&&(event.keyCode==65))
  {
   return false;
  }
    
}
</script>
</body>
</HTML> 
 
一些搜集的 WEB 技术小窍门
如何在 HTML 文件中包含某个 HTML 文件?
方法一:
html 页面 include 其它页面
<IE:Download ID="oDownload" STYLE="behavior:url(#default#download)" />
<body onload="oDownload.startDownload('tt.htm',onDownloadDone)">
<span id=showImport></span>
<script language=javascript><!--
function onDownloadDone(downDate)
{
  document.all.showImport.innerHTML=downDate; // 这种方法被讨论出来是最好的
}
//--></script>
方法二:
<object data="vister/count.asp" type="text/x-scriptlet" width="158" height="50" align="top" marginWidth=0 marginHeight
 
=0>
</object>
----------------------------------------------------------------------------------------------------------------------------
 
-------------------------------------------
TextBox 里加入图片?
<TEXTAREA rows=8 cols=20 id=textarea1 >
大家好!
这里是一个图片
</TEXTAREA>
 
<SCRIPT LANGUAGE=javascript>
<!--
var img = document.createElement("IMG");
img.src="http://community.csdn.net/images/csdn.gif";
window.textarea1.appendChild(img);
//-->
</SCRIPT>
 
 
全屏技术:
真正的全屏页面解决之道!(全代码)  
真正全屏解决之道:  
1.htm 
<html> 
<head> 
<title> 无标题文档 </title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
</head> 
 
<body onload="window.open('fullscreen.htm','','fullscreen=1,scroll=no');"> 
</body> 
</html> 
 
 
fullscreen.htm 
<html> 
<head> 
<title> 无标题文档 </title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<script language="javascript1.2">  
<!--  
function opensmallwin(myurl){  
var w2=300;// 想弹出窗口的宽度   
var h2=100;// 想弹出窗口的高度   
var w3=window.screen.width/2-w2/2;  
var h3=window.screen.height/2-h2/2;  
window.open(myurl,'small','toolbar=no,location=no,directories=no,status=no,menubar=no,
scrollbars=no,resizable=0,width='+ w2 +',height='+ h2 +',left='+ w3 +',top='+ h3 +'');  
}  
file://-->  
 
<!-- 
function modelesswin(url,mwidth,mheight){ 
  if (document.all&&window.print) 
    eval('window.external.m2_blocked(url,"","help:0;resizable:0;status:0;center:1;
scroll:0;dialogWidth:'+mwidth+'px;dialogHeight:'+mheight+'px")')  
  else 
    eval('window.open(url,"","width='+mwidth+'px,height='+mheight+'px,resizable=1,
scrollbars=1")') 
  } 
file://--> 
 
</script>  
</head> 
 
<body  scroll="no"> 
<div align="right"><a href="javascript:" onclick="window.close()"> 关闭
</a> </div> 
<p></P> 
<div align="right"><a href="javascript:" onclick="opensmallwin('login.htm')"> 登录
</a> </div> 
 
<p></P> 
<div align="center"><a href="javascript:"
onclick="modelesswin('login.htm',300,160)"> 用模态登录窗口 </a> </div> 
</body> 
</html> 
 
 
login.htm 
<html> 
<head> 
<title> 用户登录 </title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
 
<style type="text/css"> 
<!-- 
body { 
   background-color: #EAEAEA; 
   font-family: Arial, Helvetica, sans-serif; 
   font-size: 12px; 
   line-height: 24px; 
   color: #336699; 
} 
input.boxline { 
   width: 100px; 
   font-family: "Times New Roman", "Times", "serif"; 
   font-size: 9pt; 
   border: 1px solid #669999; 
   height: 18px; 
 
} 
 
input.whiteline {   
   font-size: 12px; border: 1px #999999 solid 
} 
--> 
</style></head> 
<body leftmargin="0" topmargin="0" marginwidth="0" marginheight="0"> 
<table width="100%" height="100%" border="0" cellpadding="0"
 cellspacing="14" bgcolor="#CCCCCC"> 
  <tr valign="top"> 
    <td width="10%" nowrap  align="right"><b> 用户名: </b></td> 
    <td width="90%"><input name="textfield1" type="text" size="25"
 class="whiteline"></td> 
  </tr> 
  <tr valign="top"> 
    <td nowrap align="right"><b> 密 码: </b></td> 
    <td><input name="textfield12" type="password" size="25"
class="whiteline"></td> 
  </tr> 
  <tr valign="top"> 
    <td> </td> 
    <td><input type="submit" name="Submit" value=" 登  录 "
class="boxline"></td> 
  </tr> 
</table> 
</body> 
</html> 
 
 
自动关掉原窗口:  
 
 
<html> 
<head> 
<title> 无标题文档 </title> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<style type="text/css"> 
<!-- 
body { 
   margin-left: 0px; 
   margin-top: 0px; 
   margin-right: 0px; 
   margin-bottom: 0px; 
} 
--> 
</style> 
</head> 
 
<body onload="window.open('fullscreen.htm','','fullscreen=1,scroll=no');
window.opener=null;window.close()"> 
<input type=button value= 关闭 onclick="window.opener=null;window.close()">  
<!-- IE5.5+ 不会有弹出提示 -->  
 
<OBJECT id=WebBrowser classid=CLSID:8856F961-340A-11D0-A96B-00C04FD705A2
height=0 width=0></OBJECT>  
<input type=button value= 关闭窗口 onclick=document.all.WebBrowser.ExecWB(45,1)>  
</body> 
</html> 
 
关键是在 onload 事件中加入:  
window.opener=null;window.close() 
 
 
预读图片:
<SCRIPT LANGUAGE="javascript">
 
<!-- This script and many more are available free online at -->
<!-- The javascript Source!! <a href=http://javascript.internet.com
target=_blank>http://javascript.internet.com -->
 
<!-- Begin
 
image1 = new Image();
image1.src="image1.gif";
 
image2 = new Image();
image2.src="image2.gif";
 
// End -->
</script>
 
 
 
关于两个网页刷新交互的问题  
JS 处理方法:  
 
a.htm 
 
<a href="b.htm" target=blank> 发表留言 </a> 
<script> 
alert("wwwwwwwwwwwwwwwwwwwwwwwwww"); 
</script> 
 
b.htm 
 
<script language="javascript"> 
file://window.opener.location.reload(); 刷新父窗口  
file://window.opener.location="2.htm"// 重定向父窗口到 2.htm  
function closewindow() 
{ 
window.opener.location.reload(); 
self.close(); 
window.opener.document.write("sssssssssssssssssss"); 
} 
</script> 
<a href="b.htm" target=blank onclick="closewindow();"> 关闭 </a> 
 
 
 
后台处理方法:  
 
private btnForSubmit(Object sender,EventArgs e) 
{ 
 ............. 
 Response.Write("<script>window.opener.document.execCommand('refresh');
window.opener='';window.close();</script>"); 
file://string str="<script>window.opener.document.execCommand('refresh');
window.opener='';window.close();</script>"; 
file://this.RegisterStartupScript("mycode",str);
 
BS 开发中常用的 javascript 技术
 
 
4 、事件类
  4.1 屏蔽右键
      body 标签里加上 oncontextmenu=self.event.returnValue=false  
  4.2 屏蔽所有功能键
 
  4.3 --> <-- F5 F11,F9,F1
 
  4.4 屏蔽组合键 ctrl+N
 
<script language=javascript>
function KeyDown(){   
  if ((window.event.altKey)&&
      ((window.event.keyCode==37)||   file:// 屏蔽 Alt+ 方向键
       (window.event.keyCode==39))){  file:// 屏蔽 Alt+ 方向键
     alert(" 不准你使用 ALT+ 方向键前进或后退网页! ");
     event.returnValue=false;
     }
  if ((event.keyCode==8)||            file:// 屏蔽退格删除键
      (event.keyCode==116)){          file:// 屏蔽 F5 刷新键
     event.keyCode=0;
     event.returnValue=false;
     }
  if ((event.ctrlKey)&&(event.keyCode==78)){   file:// 屏蔽 Ctrl+n
     event.returnValue=false;
     }
  if ((event.shiftKey)&&(event.keyCode==121)){ file:// 屏蔽 shift+F10
     event.returnValue=false;
     }
  if (event.keyCode==122){ file:// 屏蔽 F11
     event.returnValue=false;
     }
  }
只要知道 keyCode 即可屏蔽所有功能键
 
 
一、验证类
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
<input type=checkbox name=mm
<input type=checkbox name=mm
<input type=checkbox name=mm
<input type=checkbox name=mm
 
 
<input type=checkbox name=All2 onclick="checkAll('mm2')"> 全选 <br/>
<input type=checkbox name=mm2
<input type=checkbox name=mm2
<input type=checkbox name=mm2
<input type=checkbox name=mm2
<input type=checkbox name=mm2
 
</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])">
 
 
 
不断地清空剪贴板 :
<body onload="setInterval('clipboardData.setData(\'Text\',\'\')',100)">
 
 
<script language="javascript" type="text/javascript">
file:// 先复制一样东西,或者文本或者图片
if(clipboardData.getData("Text")||clipboardData.getData("HTML")||
clipboardData.getData("URL"))
{
alert(" 有效行为 ");
}
</script>
// 保护页面不被打印、复制,禁止 Mouse 各键
<SCRIPT LANGUAGE="JavaScript">wside=(window.sidebar)?true:false;
var w456=false;
function nrcie(){return false;};
function nrcns(e) { if(e.which==2||e.which==3) return false;
 }if(document.layers) { document.captureEvents(Event.MOUSEDOWN);
 document.onmousedown=nrcns;
 }document.oncontextmenu=nrcie;
document.onselectstart=new Function("return false");
function nsel(){if((document.layers)||wside){var qwe= document.getSelection();
if(qwe!="") {window.find(" ")};
setTimeout("nsel()",20);
}}nsel();
function ccd(){clipboardData.clearData();
};
function cce(){ccd();
setTimeout("cce()",30);
};
cce();
</SCRIPT>
 
<style media='print'>body {display:none}</style>
 
 
页面上关于定位和长度的几个属性 ( 原创 )
首先是页面定位,用 CSS
 
position ,这个下面有两个属性 absolute( 绝对定位 ) relative( 相对定位 ) ,绝对定位是指相对浏览器的位置地位,而相对定位和其他元素的位置有关系,位置不固定。
 
以下可以看一个例子,看了之后就明白了
 
abc<br/>
 
<div style="position:relative;left:1;top:100;color:green">absolute positioning with the current element<br/><span style="position:absolute;left:0;top:0;">aaaaaaaaa</span></div>
 
<div style="color:red">absolute positioning with the body<br/><span style="position:absolute;left:0;top:0">bbbbbbbbbbb</span></div>
 
<div style="color:blue">relative positioning with the body<span style="position:relative;left:-12;top:0">ccccccccccc</span></div>
 
而有些 CSS 属性有时候需用 position:absolute 之后才有效,比如裁切的那个 CSS
 
接下来是一些元素的位置问题
 
就拿宽度来说
 
scrollwidth,clientwidth,offsetwidth
 
这些属性都可以用在 <body>,<div> 等元素
 
第一个是包括滚动条所有在内的长度,第二个和第三个差不多,第三个是包括工具栏,菜单栏,状态栏,滚动条宽度等在内的宽度,而第二个是去掉一些 cellpadding 等一些的额外的宽度。高度同这个,元素分别为
 
scrollheight,clientheight,offsetheight
 
接下来是鼠标的位置
 
可以用 event.clientX + document.body.scrollLeft 得到横的绝对位置
 
这里面 event.clientX 是相对屏幕的位置,而 document.body.scrollLeft 是网页被横向滚动条卷进去的宽度。
 
这里可以看一个例子,代码如下 把这个方法写在 <body> onmousemove 中,一目了然了。
 
<SCRIPT>
<!--
function statusreport() {
 
  var tempx = event.clientX + document.body.scrollLeft;
  var tempy = event.clientY + document.body.scrollTop;
 
  window.status=' 在整个页面中的 X, Y 坐标 : ('+tempx+', '+tempy+') ; 在当前窗口中的 X, Y 坐标 : ( '+event.clientX+', '+event.clientY +')';
}
//-->
 
</SCRIPT>
 
 
 
大梅的思路,我把他用到了判断数据提交的时候有没有重复记录上了
<form name=form1>
<input name=a123>
<input name=b123>
<input name=c123>
<input name=d123>
<input name=e123>
<input name=f123 type=button onclick=check()>
</form>
<SCRIPT LANGUAGE="JavaScript">
<!--
Array.prototype.unique = function()
{
  var a = {}; for(var i=0; i<this.length; i++)
  {
    if(typeof a[this[i]] == "undefined")
      a[this[i]] = 1;
  }
  this.length = 0;
  for(var i in a)
    this[this.length] = i;
  return this;
}
function check()
{
var ArrText = [document.form1.a123.value,document.form1.b123.value,document.form1.c123.value,document.form1.d123.value,document.form1.e123.value];
OldArr=ArrText.length;
NewArr=ArrText.unique().length;
if(OldArr==NewArr)
{
alert(" 无重复记录 ");
}
else
{
alert(" 有重复记录 ");
}
}
//-->
</SCRIPT>
 
Date.prototype.Format = function(format)
{
  var o = {
    "M+" : this.getMonth()+1, //month
    "d+" : this.getDate(),    //day
    "h+" : this.getHours(),   //hour
    "m+" : this.getMinutes(), //minute
    "s+" : this.getSeconds(), //second
    "q+" : Math.floor((this.getMonth()+3)/3),  //quarter
    "S" : this.getMilliseconds() //millisecond
  }
  if(/(y+)/.test(format)) format=format.replace(RegExp.$1,
    (this.getFullYear()+"").substr(4 - RegExp.$1.length));
  for(var k in o)if(new RegExp("("+ k +")").test(format))
    format = format.replace(RegExp.$1,
      RegExp.$1.length==1 ? o[k] :
        ("00"+ o[k]).substr((""+ o[k]).length));
  return format;
};
 
示例:
alert(new Date().Format("yyyy MM dd "));
alert(new Date().Format("MM/dd/yyyy"));
alert(new Date().Format("yyyyMMdd"));
alert(new Date().Format("yyyy-MM-dd hh:mm:ss"));
 
空间已经过期
代码无法更新
示例仅提供思路:
 
 
常用前台 JS 函数
 
自动加上验证事件及日期按钮 (htc 方式 )
 
自动加上验证事件及日期按钮 (js 方式 )
 
Ctrl + 鼠标 选中 (20050214)
 
固定 Div(20050214)
 
可以盖住 select div(20041216)
 
可输入下拉框 (20041126)( 相似高亮显示,不相似移除 )
 
可输入下拉框 (20041126)( 相似高亮显示,不相似不移除 )
 
改变 table 的列宽 (20041103)
 
可用鼠标移动和改变大小的 table(20041029)
 
用鼠标移动 TR(20050107)
 
固定 Table 首行 (20041123)
 
固定 Table 首行首列 (20041123)
 
Main Content Div
 
从服务器端取值并回填到页面
 
动态明细示例
 
多功能 multiple-update
 
一个简单的 IFRAME 框架
 
调用客户端发邮件程序
 
读取客户端文件
 
一级选择左右移动及排库
 
二级选择左右移动
 
提交到特定大小的窗口
 
忠实显示 Text 内容 ( 不同于 Pre 标签 )
 
自动关闭 Alert 对话框
 
年月日选择
 
 
提交到特定大小的窗口
 
忠实显示 Text 内容 ( 不同于 Pre 标签 )
 
自动关闭 Alert 对话框
 
年月日选择
 
 
JS cookie 操作
function setCookie(name,value)
{
  var Days = 30; // cookie 将被保存 30
  var exp  = new Date();    //new Date("December 31, 9998");
  exp.setTime(exp.getTime() + Days*24*60*60*1000);
  document.cookie = name + "="+ escape(value) +";expires="+ exp.toGMTString();
}
function getCookie(name)
{
  var arr = document.cookie.match(new RegExp("(^| )"+name+"=([^;]*)(;|$)"));
  if(arr != null) return unescape(arr[2]); return null;
}
function delCookie(name)
{
  var exp = new Date();
  exp.setTime(exp.getTime() - 1);
  var cval=getCookie(name);
  if(cval!=null) document.cookie=name +"="+cval+";expires="+exp.toGMTString();
}
 
 
<script type="text/javascript">
var _st = window.setTimeout;
 
/* 重载 window.setTimeout 函数 , 引用的函数可以带参数 */
window.setTimeout = function(fRef, mDelay) {
 if(typeof fRef == 'function'){
  var argu = Array.prototype.slice.call(arguments,2);
alert(typeof(argu));
  var f = (function(){ fRef.apply(null, argu); });
  return _st(f, mDelay);
 }
 return _st(fRef,mDelay);
}
 
function test(x){
 alert(x);
}
window.setTimeout(test,3000,'fason');
</script>
 
 
<script language=javascript>
<!--
/*@cc_on @*/
/*@if (@_win32 && @_jscript_version>=5)
function window.confirm(str)
{
    str=str.replace(/\'/g, "'&chr(39)&'").replace(/\r\n|\n|\r/g, "'&VBCrLf&'");
    execScript("n = msgbox('"+ str +"', 257, ' 自定的的 confirm')", "vbscript");
    return(n==1);
}
@end @*/
alert(confirm('sure?'));
// -->
</script>
 
 
// 两端去空格函数
function trim(str) {
return str.replace(/(^\s*)|(\s*$)/g,"");
}
 
 
<script>
// Number 增加 length 方法
Number.prototype.length = function()
{
return String(this).length;
}
 
alert((11).length())
</script>
 
Ms XmlDom 异步装载 Xml 文件
放在这里,算作是资源备份吧。
 
<script>
var xmldoc;
function Load(){
  xmldoc = new ActiveXObject("Msxml2.DOMDocument");
  xmldoc.onreadystatechange = CheckState;
  xmldoc.resolveExternals = false;
  xmldoc.load(URL.value);
}
function CheckState(){
  var state = xmldoc.readyState;
  RESULTS.innerHTML += " 加载状态 = " + state + "<BR>"
  if (state == 4){
    var err = xmldoc.parseError;
    if (err.errorCode != 0)
      RESULTS.innerHTML += err.reason +  "<BR>"
    else
    {
     RESULTS.innerHTML += " 加载成功。 " +  "<BR>"
     alert(xmldoc.xml)
     }
  }
}
</script>
URL: <input type=text size=60 id=URL value="http://dotnet.aspx.cc/Rss.aspx">
<input type=button value=" 正在 XML" onclick="Load()">
<div id=RESULTS style="color:red; font-weight:bold;"></div></script>
 
 
// 带中文字符串长度 , 一个中文字长度为 2
String.prototype.lenB = function(){return this.replace(/[^\x00-\xff]/g,"**").length;}
 document.all.tes1.value.lenB();
 
 
 
预判断一下链接 URL 是否可用
 
<script language="javascript">
function getURL(url)
{
    var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
    xmlhttp.open("GET",url,false);
    xmlhttp.send();
    if (xmlhttp.readyState==4)
      alert((xmlhttp.Status==200)?" 存在 ":" 不存在 ");
}
//user like this:
getURL("http://localhost/1.asp")
</script>
 
 
// 将数字转换成三位逗号分隔的样式
function formatNum(s)
{
  if(!/^(\+|-)?\d+(\.\d+)?$/.test(num)){alert("wrong!"); return num;}
  var re = new RegExp().compile("(\\d)(\\d{3})(,|\\.|$)");
  num += ""; while(re.test(num))
    num = num.replace(re, "$1,$2$3")
  return num;
}
alert(formatNum(-12345678.123));
alert(formatNum("12345678.123"));
alert(formatNum("10000000000000000000000000000000000000000"));
 
 
 
格式化日期 :yyyy-m-d to yyyy-mm-dd
 
<SCRIPT LANGUAGE="JavaScript">
<!--
var str = "2005-3-2"; //2005-03-02
var str = "2005-3-22"; //2005-03-02
str = str.replace(/(\D)(\d)(?=\D|$)/g, "$10$2");
alert(str);
//-->
</SCRIPT>
 
 
表格中的行删除功能 , checkbox 选择的
<script language="JavaScript">
<!--
var curRow=null;
function selectRow(tr1){
if(curRow)
curRow.bgColor="#FFFFFF";
tr1.bgColor="e7e7e7";
curRow=tr1;
}
function delTr(){
var chks=document.getElementsByName("chkDelete");
var tb=document.getElementById("tbContent");
for(var i=chks.length-1;i>=0;i--){
if(chks[i].checked){
tb.deleteRow(i);
}
}
}
//-->
</script>
<div align="center" style="overflow:auto; width:400; height:300px " id="divVector">
<table id="tbContent" border=1 width="300">
<script language="JavaScript">
<!--
for(var i=0;i<25;i++)
document.write('<tr height=20 algin="center"
 
width="20%"><input type="checkbox" name="chkDelete"></td><td width="80%"
 
align="center">'+i+'</td></tr>');
//-->
</script>
</table>
</div>
<input type="button" value=" 删除选中的行 " onclick="delTr()">
 
 
yyyy-mm-dd 格式日期完整校验加提示
<script language="JavaScript">
<!--
function CheckDate(strDate){
var reg=/^(\d{4})([-])(\d{2})([-])(\d{2})/;
if(!reg.test(strDate)){
alert(" 日期格式不正确 !\n 正确格式为 :2004-01-01");
return false;
}
var ss=strDate.split("-");
var year=ss[0];
var month=ss[1];
var date=ss[2];
if(!checkYear(year)){return false;}
if(!checkMonth(month)){return false;}
if(!checkDate(year,month,date)){return false;}
return true;
}
function checkYear(year){
if(isNaN(parseInt(year))){alert(" 年份输入有误 , 请重新输入 !"); return false;}
else if(parseInt(year)<1950 || parseInt(year) >2050){ alert(" 年份应该在 1950-2050 之间
 
!"); return false}
else return true;
}
function checkMonth(month){
if(isNaN(parseInt(month))){alert(" 月份输入有误 , 请重新输入 !"); return false;}
else if(parseInt(month)<1 || parseInt(month) >12){ alert(" 月份应该在 1-12 之间 !");
 
return false}
else return true;
}
function checkDate(year,month,date){
var daysOfMonth=CalDays(parseInt(year),parseInt(month));
if(isNaN(parseInt(date))){alert(" 日期输入有误 , 请重新输入 !"); return false;}
else if(parseInt(date)<0||parseInt(date)>daysOfMonth){ alert(" 日期应该在 1
 
-"+daysOfMonth+" 之间 !"); return false;}
else return true;
}
function CalDays(year,month){
var date= new Date(year,month,0);
return date.getDate();
}
function isLeapYear(year){
if((year %4==0 && year %100!=0) || (year %400==0)) return true;
else return false;
}
alert(CheckDate("2007-02-29"));
//-->
</script>
 
 
<script language="JavaScript">
<!--
/* 函数名称 : dateAfterDays
 * 函数功能 : 返回与某日期相距 N (N 24 小时 ) 的日期
 * 函数参数 : num number 类型 可以为正负整数或者浮点数
 * 函数返回 : 新的日期
 * 调用方法 : dateObject.dateAfterDays(num);
 */
Date.prototype.dateAfterDays=function(num){
if(typeof(num)!="number") throw new Error("Date(num) 参数为数值类型 .",-1);
var date = this.valueOf();
date += num*24*3600*1000;
return new Date(date);
}
var dd= new Date();
alert(dd.dateAfterDays(1.5));
//-->
</script>
 
 
类似 CSDN 感兴趣社区配置页面中的 checkbox 选择的功能
<script language="JavaScript">
<!--
function chkClk(obj){
var chks=document.getElementsByName(obj.name);
if(obj.flag=="main"){
for(var i=1;i<chks.length;i++)
chks[i].checked=obj.checked;
}
else{
for(var i=1;i<chks.length;i++)
if(chks[i].checked==false){
chks[0].checked=false;
break;
}
else{
if(i==chks.length-1) chks[0].checked=true;
}
}
}
//-->
</script>
 
<input type="checkbox" name="type1" flag="main">typetext
<li><input type="checkbox" name="type1">typetext</li>
<li><input type="checkbox" name="type1">typetext</li>
<br/><br/>
<input type="checkbox" name="type2" flag="main">typetext
<li><input type="checkbox" name="type2">typetext</li>
<li><input type="checkbox" name="type2">typetext</li>
posted on 2008-03-13 19:53 缘来如此 阅读(881) 评论(0)  编辑  收藏 所属分类: javaScript

只有注册用户登录后才能发表评论。


网站导航: