javascript 应用小技巧方法汇总


Posted in Javascript onJuly 05, 2015

javascript 在前端应用体验小技巧继续积累。

事件源对象 event.srcElement.tagName 
event.srcElement.type
捕获释放 event.srcElement.setCapture(); 
event.srcElement.releaseCapture(); 
事件按键 event.keyCode event.shiftKey 
event.altKey event.ctrlKey
事件返回值 event.returnValue
鼠标位置 event.x event.y
窗体活动元素 document.activeElement
绑定事件 
document.captureEvents(Event.KEYDOWN);
访问窗体元素 document.all("txt").focus(); 
document.all("txt").select();
窗体命令 document.execCommand
窗体COOKIE document.cookie
菜单事件 document.oncontextmenu
创建元素 document.createElement("SPAN"); 
根据鼠标获得元素: 
document.elementFromPoint(event.x,event.y).tagName=="TD 
document.elementFromPoint(event.x,event.y).appendChild(ms) 
窗体图片 document.images[索引]
窗体事件绑定 
document.onmousedown=scrollwindow;
元素 document.窗体.elements[索引]
对象绑定事件 
document.all.xxx.detachEvent('onclick',a);
插件数目 navigator.plugins
取变量类型 typeof($js_libpath) == "undefined"
下拉框 下拉框.options[索引] 
下拉框.options.length
查找对象 document.getElementsByName("r1"); 
document.getElementById(id);
定时 
timer=setInterval('scrollwindow()',delay); 
clearInterval(timer);
UNCODE编码 escape() ,unescape
父对象 obj.parentElement(dhtml) 
obj.parentNode(dom)
交换表的行 TableID.moveRow(2,1)
替换CSS document.all.csss.href = "a.css";
并排显示 display:inline
隐藏焦点 hidefocus=true
根据宽度换行 
style="word-break:break-all"
自动刷新 <meta HTTP-EQUIV="refresh" CONTENT="8;URL=http://c98.yeah.net">
简单邮件 <a href="mailto:aaa@bbb.com?subject=ccc&body=xxxyyy"> 
快速转到位置 
obj.scrollIntoView(true)
锚 <a name="first"> <a href="#first">anchors</a>
网页传递参数 location.search();
可编辑 obj.contenteditable=true
执行菜单命令 obj.execCommand
双字节字符 /[^\x00-\xff]/ 汉字 
/[\u4e00-\u9fa5]/
让英文字符串超出表格宽度自动换行word-wrap: break-word; word-break: break-all;
透明背景 <IFRAME src="1.htm" width=300 height=180 allowtransparency></iframe>
获得style内容 obj.style.cssText
HTML标签 
document.documentElement.innerHTML
第一个style标签 document.styleSheets[0]
style标签里的第一个样式 
document.styleSheets[0].rules[0]
防止点击空链接时,页面往往重置到页首端。 <a href="javascript:function()">word</a>
上一网页源 asp: request.servervariables("HTTP_REFERER") 
javascript: document.referrer
释放内存 CollectGarbage();
禁止右键document.oncontextmenu = function() { return false;}
禁止保存 <noscript><iframe src="*.htm"></iframe></noscript>
禁止选取<body oncontextmenu="return false" ondragstart="return false" onselectstart ="return false" onselect="document.selection.empty()" oncopy="document.selection.empty()" onbeforecopy="return false"onmouseup="document.selection.empty()>
禁止粘贴 <input type=text onpaste="return false">
地址栏图标 <link rel="Shortcut Icon" href="favicon.ico"> favicon.ico 名字最好不变16*16的16色,放虚拟目录根目录下
收藏栏图标 <link rel="Bookmark" href="favicon.ico">
查看源码 <input type=button value=查看网页源代码 onclick="window.location = 'view-source:'+ 'http://www.csdn.net/'">
关闭输入法 <input style="ime-mode:disabled">
自动全选<input type=text name=text1 value="123" onfocus="this.select()">
ENTER键可以让光标移到下一个输入框 <input onkeydown="if(event.keyCode==13)event.keyCode=9">
文本框的默认值 <input type=text value="123" onfocus="alert(this.defaultValue)">
title换行 obj.title = "123
sdfs "
获得时间所代表的微秒 var n1 = new Date("2004-10-10".replace(/-/g, "\/")).getTime()
窗口是否关闭 win.closed
checkbox扁平 <input type=checkbox style="position: absolute; clip:rect(5px 15px 15px 5px)"><br>
获取选中内容 
document.selection.createRange().duplicate().text
自动完成功能 <input type=text autocomplete=on>打开该功能 
<input type=text autocomplete=off>关闭该功能  
窗口最大化 <body onload="window.resizeTo(window.screen.width - 4,window.screen.height-50);window.moveTo(-4,-4)">
无关闭按钮IE window.open("aa.htm", "meizz", "fullscreen=7");
统一编码/解码 
alert(decodeURIComponent(encodeURIComponent("http://你好.com?as= hehe"))) encodeURIComponent对":"、"/"、";" 和 "?"也编码
表格行指示 <tr onmouseover="this.bgColor='#f0f0f0'" onmouseout="this.bgColor='#ffffff'">

//各种尺寸

s += "\r\n网页可见区域宽:"+ document.body.clientWidth;  
s += "\r\n网页可见区域高:"+ document.body.clientHeight;  
s += "\r\n网页可见区域高:"+ document.body.offsetWeight +" (包括边线的宽)";  s += "\r\n网页可见区域高:"+ document.body.offsetHeight +" (包括边线的宽)";  s += "\r\n网页正文全文宽:"+ document.body.scrollWidth;  
s += "\r\n网页正文全文高:"+ document.body.scrollHeight;  
s += "\r\n网页被卷去的高:"+ document.body.scrollTop;  
s += "\r\n网页被卷去的左:"+ document.body.scrollLeft;  
s += "\r\n网页正文部分上:"+ window.screenTop;  
s += "\r\n网页正文部分左:"+ window.screenLeft;  
s += "\r\n屏幕分辨率的高:"+ window.screen.height;  
s += "\r\n屏幕分辨率的宽:"+ window.screen.width;  
s += "\r\n屏幕可用工作区高度:"+ window.screen.availHeight;  
s += "\r\n屏幕可用工作区宽度:"+ window.screen.availWidth;

//过滤数字

<input type=text onkeypress="return event.keyCode>=48&&event.keyCode<=57||(this.value.indexOf('.')<0?event.keyCode==46:false)" onpaste="return !clipboardData.getData('text').match(/\D/)" ondragenter="return false">

//特殊用途

<input type=button value=导入收藏夹 onclick="window.external.ImportExportFavorites(true,'http://localhost');"> <input type=button value=导出收藏夹 onclick="window.external.ImportExportFavorites(false,'http://localhost');"> <input type=button value=整理收藏夹 onclick="window.external.ShowBrowserUI('OrganizeFavorites', null)"> 

<input type=button value=语言设置   onclick="window.external.ShowBrowserUI('LanguageDialog', null)"> 

<input type=button value=加入收藏夹 onclick="window.external.AddFavorite('http://www.google.com/', 'google')"> <input type=button value=加入到频道 onclick="window.external.addChannel('http://www.google.com/')"> <input type=button value=加入到频道 onclick="window.external.showBrowserUI('PrivacySettings',null)">

//不缓存

<META HTTP-EQUIV="pragma" CONTENT="no-cache"> <META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate"> 

<META HTTP-EQUIV="expires" CONTENT="0">

//正则匹配

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

匹配双字节字符(包括汉字在内):[^\x00-\xff] 匹配空行的正则表达式:\n[\s| ]*\r 

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

匹配首尾空格的正则表达式:(^\s*)|(\s*$)(像vbscript那样的trim函数) 

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

匹配网址URL的正则表达式:http://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)? 以下是例子: 利用正则表达式限制网页表单里的文本框输入内容: 用正则表达式限制只能输入中文:onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))" 

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

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

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

//消除图像工具栏

<IMG SRC="mypicture.jpg" HEIGHT="100px" WIDTH="100px" GALLERYIMG="false">  or <head> 

<meta http-equiv="imagetoolbar" content="no"> </head>

//无提示关闭

function Close() { var ua=navigator.userAgent var ie=navigator.appName=="Microsoft Internet Explorer"?true:false if(ie) {       var IEversion=parseFloat(ua.substring(ua.indexOf("MSIE ")+5,ua.indexOf(";",ua.indexOf("MSIE "))))   if(IEversion< 5.5)   {    var str  = '<object id=noTipClose classid="clsid:ADB880A6-D8FF-11CF-9377-00AA003B7A11">' 

       str += '<param name="Command" value="Close"></object>'; 

       document.body.insertAdjacentHTML("beforeEnd", str); 

       document.all.noTipClose.Click();   }       else   { 

       window.opener =null; 

       window.close();       }    } else { 

  window.close()    } }

//取得控件得绝对位置(1)

<script language="javascript">  function getoffset(e) {  var t=e.offsetTop;  var l=e.offsetLeft;  while(e=e.offsetParent) {  

  t+=e.offsetTop;    l+=e.offsetLeft;  }  var rec = new Array(1); 

rec[0]  = t; rec[1] = l; return rec }  </script>

//获得控件的绝对位置(2)
oRect = obj.getBoundingClientRect(); 
oRect.left oRect.

//最小化,最大化,关闭

<object id=min classid="clsid:ADB880A6-D8FF-11CF-9377-00AA003B7A11"> 
<param name="Command" value="Minimize"></object> 
<object id=max classid="clsid:ADB880A6-D8FF-11CF-9377-00AA003B7A11"> 
<param name="Command" value="Maximize"></object> 
<OBJECT id=close classid="clsid:adb880a6-d8ff-11cf-9377-00aa003b7a11"> 
<PARAM NAME="Command" value="Close"></OBJECT> 
<input type=button value=最小化 onclick=min.Click()> 
<input type=button value=最大化 onclick=max.Click()> 
<input type=button value=关闭 onclick=close.Click()>

//光标停在文字最后

<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()">

//页面进入和退出的特效

进入页面<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

//网页是否被检索

<meta name="ROBOTS" content="属性值">

其中属性值有以下一些:

属性值为"all": 文件将被检索,且页上链接可被查询;

属性值为"none": 文件不被检索,而且不查询页上的链接;

属性值为"index": 文件将被检索;

属性值为"follow": 查询页上的链接;

属性值为"noindex": 文件不检索,但可被查询链接;

属性值为"nofollow":

//打印分页

<p  style="page-break-after:always">page1</p>  
<p  style="page-break-after:always">page2</p> 

//设置打印

<object id="factory" style="display:none" viewastext  classid="clsid:1663ed61-23eb-11d2-b92f-008048fdd814" 
 codebase="http://www.meadroid.com/scriptx/ScriptX.cab#Version=5,60,0,360" ></object> 
<input type=button value=页面设置 onclick="factory.printing.PageSetup()"> 
<input type=button value=打印预览 onclick="factory.printing.Preview()">  
<script language=javascript> function window.onload() {  // -- advanced features  factory.printing.SetMarginMeasure(2) // measure margins in inches  factory.printing.SetPageRange(false, 1, 3) // need pages from 1 to 3  factory.printing.printer = "HP DeskJet 870C" 
  factory.printing.copies = 2  factory.printing.collate = true 
  factory.printing.paperSize = "A4" 
  factory.printing.paperSource = "Manual feed"  // -- basic features  factory.printing.header = "居左显示&b居中显示&b居右显示页码,第&p页/共&P页" 
  factory.printing.footer = "(自定义页脚)" 
  factory.printing.portrait = false 
  factory.printing.leftMargin = 0.75 
  factory.printing.topMargin = 1.5 
  factory.printing.rightMargin = 0.75 
  factory.printing.bottomMargin = 1.5 } function Print(frame) { 
 factory.printing.Print(true, frame) // print with prompt } </script> 
<input type=button value="打印本页" onclick="factory.printing.Print(false)"> 
<input type=button value="页面设置" onclick="factory.printing.PageSetup()"> 
<input type=button value="打印预览" onclick="factory.printing.Preview()"><br> 
<a href="http://www.meadroid.com/scriptx/docs/printdoc.htm?static" target=_blank>具体使用手册,更多信息,点这里</a>

//自带的打印预览

WebBrowser.ExecWB(1,1) 打开 
Web.ExecWB(2,1) 关闭现在所有的IE窗口,并打开一个新窗口 Web.ExecWB(4,1) 保存网页 
Web.ExecWB(6,1) 打印 Web.ExecWB(7,1) 打印预览 Web.ExecWB(8,1) 打印页面设置 
Web.ExecWB(10,1) 查看页面属性 Web.ExecWB(15,1) 好像是撤销,有待确认 
Web.ExecWB(17,1) 全选 Web.ExecWB(22,1) 刷新 Web.ExecWB(45,1) 关闭窗体无提示 
<style media=print> 
.Noprint{display:none;}<!--用本样式在打印时隐藏非打印项目--> 
.PageNext{page-break-after: always;}<!--控制分页--> </style> 
<object id="WebBrowser" width=0 height=0 classid="CLSID:8856F961-340A-11D0-A96B-00C04FD705A2">   
</object>    <center class="Noprint" > 
<input type=button value=打印 onclick=document.all.WebBrowser.ExecWB(6,1)> 
<input type=button value=直接打印 onclick=document.all.WebBrowser.ExecWB(6,6)> 
<input type=button value=页面设置 onclick=document.all.WebBrowser.ExecWB(8,1)> 
</p> 
<p> <input type=button value=打印预览 onclick=document.all.WebBrowser.ExecWB(7,1)> 
</center>

//去掉打印时的页眉页脚

<script language="JavaScript">  var HKEY_Root,HKEY_Path,HKEY_Key; 
HKEY_Root="HKEY_CURRENT_USER"; 
HKEY_Path="\\Software\\Microsoft\\Internet Explorer\\PageSetup\\"; 
//设置网页打印的页眉页脚为空 function PageSetup_Null() { try { 
     var Wsh=new ActiveXObject("WScript.Shell");  HKEY_Key="header"; 
 Wsh.RegWrite(HKEY_Root+HKEY_Path+HKEY_Key,"");  HKEY_Key="footer"; 
 Wsh.RegWrite(HKEY_Root+HKEY_Path+HKEY_Key,""); } catch(e){} } //设置网页打印的页眉页脚为默认值 function PageSetup_Default() {  try 
{  var Wsh=new ActiveXObject("WScript.Shell");  HKEY_Key="header"; 
 Wsh.RegWrite(HKEY_Root+HKEY_Path+HKEY_Key,"&w&b页码,&p/&P"); 
 HKEY_Key="footer"; 
 Wsh.RegWrite(HKEY_Root+HKEY_Path+HKEY_Key,"&u&b&d"); } catch(e){} } </script> 
<input type="button" value="清空页码" onclick=PageSetup_Null()> 
<input type="button" value="恢复页码" onclick=PageSetup_Default()>

//浏览器验证

function checkBrowser() {   this.ver=navigator.appVersion   this.dom=document.getElementById?1:0   this.ie6=(this.ver.indexOf("MSIE 6")>-1 && this.dom)?1:0;   this.ie5=(this.ver.indexOf("MSIE 5")>-1 && this.dom)?1:0;   this.ie4=(document.all && !this.dom)?1:0;   this.ns5=(this.dom && parseInt(this.ver) >= 5) ?1:0;   this.ns4=(document.layers && !this.dom)?1:0;   this.mac=(this.ver.indexOf('Mac') > -1) ?1:0; 
  this.ope=(navigator.userAgent.indexOf('Opera')>-1); 
  this.ie=(this.ie6 || this.ie5 || this.ie4)   this.ns=(this.ns4 || this.ns5)   this.bw=(this.ie6 || this.ie5 || this.ie4 || this.ns5 || this.ns4 || this.mac || this.ope)   this.nbw=(!this.bw)   return this; 
}

//计算内容宽和高

<SCRIPT language="javascript">  function test(obj)  {     var range = obj.createTextRange();  
    alert("内容区宽度: " + range.boundingWidth   
                         + "px\r\n内容区高度: " + range.boundingHeight + "px");         }  
</SCRIPT>  <BODY>  <Textarea id="txt" height="150">sdf</textarea><INPUT type="button" value="计算内容宽度" onClick="test(txt)">  </BODY>

//无模式的提示框

function modelessAlert(Msg) { 
  window.showModelessDialog("javascript:alert(\""+escape(Msg)+"\");window.close();","","status:no;resizable:no;help:no;dialogHeight:height:30px;dialogHeight:40px;"); 
}

//屏蔽按键

<html> 
<head>  <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
 <noscript><meta http-equiv="refresh" content="0;url=about:noscript"></noscript> 
 <title>屏蔽鼠标右键、Ctrl+N、Shift+F10、Alt+F4、F11、F5刷新、退格键</title> 
</head> <body> <script language="Javascript"><!--  //屏蔽鼠标右键、Ctrl+N、Shift+F10、F11、F5刷新、退格键  //Author: meizz(梅花雨) 2002-6-18 function document.oncontextmenu(){event.returnValue=false;}//屏蔽鼠标右键 function window.onhelp(){return false} //屏蔽F1帮助 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.keyCode==116)||         //屏蔽 F5 刷新键    (event.ctrlKey && event.keyCode==82)){ //Ctrl + R   event.keyCode=0; 
   event.returnValue=false;   } 
 if (event.keyCode==122){event.keyCode=0;event.returnValue=false;} //屏蔽F11  if (event.ctrlKey && event.keyCode==78) event.returnValue=false;  //屏蔽 Ctrl+n  if (event.shiftKey && event.keyCode==121)event.returnValue=false; //屏蔽 shift+F10  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;  } } </script> 
屏蔽鼠标右键、Ctrl+N、Shift+F10、Alt+F4、F11、F5刷新、退格键 </body>

</html>
//屏蔽打印 <style> @media print{ * {display:none} } </style>

//移动的图层,拖动

1.<span style='position:absolute;width:200;height:200;background:red' onmousedown=MouseDown(this) onmousemove=MouseMove() onmouseup=MouseUp()>meizz</span> 
<script language=javascript> var Obj; function MouseDown(obj) {  Obj=obj; 
 Obj.setCapture();  Obj.l=event.x-Obj.style.pixelLeft; 
 Obj.t=event.y-Obj.style.pixelTop; } function MouseMove() {  if(Obj!=null) 
 {   Obj.style.left = event.x-Obj.l; 
  Obj.style.top = event.y-Obj.t;  } } function MouseUp() {  if(Obj!=null) 
 {   Obj.releaseCapture();   Obj=null;  } } </script> 2. 
<div id="myDiv" src="logo.gif" ondrag="doDrag();" onmouseover="this.style.cursor='hand'" style="position:absolute;left=100;top=100;" onmousedown="doMouseDown();"> <a href="#" onclick="return false"><h1>wlecome</h1></a> 
</div> <script language="JavaScript" type="text/javascript"> var orgMouseX; var orgMouseY; var orgObjX; var orgObjY; function doDrag() { var myObject=document.all.myDiv; 
var x=event.clientX; var y=event.clientY; 
myObject.style.left=x-(orgMouseX-orgObjX); 
myObject.style.top=y-(orgMouseY-orgObjY);  } function doMouseDown() { 
orgMouseX=event.clientX; orgMouseY=event.clientY; 
orgObjX=parseInt(document.all.myDiv.style.left); 
orgObjY=parseInt(document.all.myDiv.style.top); } 
</script>

//文档状态改变

<iframe src="a.html" id="f" name="f" scrolling="no" frameborder=0 marginwidth=0 marginheight=0></iframe> 
<script> var doc=window.frames["f"].document; function s(){ if (doc.readyState=="complete"){ 
 document.all.f.style.height=doc.body.scrollHeight 
 document.all.f.style.width=doc.body.scrollWidth } } 
doc.onreadystatechange=s </script>

//刷新后不变的文本框

<HTML> 
<HEAD> <META NAME="save" CONTENT="history"> <STYLE> 
  .sHistory {behavior:url(#default#savehistory);} </STYLE> 
</HEAD> <BODY> 
<INPUT class="sHistory" type=text id=oPersistInput> </BODY> 
</HTML>

//访问剪贴板

(1)拖拽访问

event.dataTransfer.setData("URL", oImage.src); 
sImageURL = event.dataTransfer.getData("URL") (2)普通访问 
window.clipboardData.setData("Text",oSource.innerText); 
window.clipboardData.getData("Text");

//操作COOKIE

function SetCookie(sName, sValue) { 
document.cookie = sName + "=" + escape(sValue) + "; "; } function GetCookie(sName) { var aCookie = document.cookie.split("; "); for (var i=0; i < aCookie.length; i++) {  
 var aCrumb = aCookie[i].split("=");  if (sName == aCrumb[0])  return unescape(aCrumb[1]); }  } 
function DelCookie(sName) { 
document.cookie = sName + "=" + escape(sValue) + "; expires=Fri, 31 Dec 1999 23:59:59 GMT;"; }

//setTimeout增加参数

<script> 

var _st = window.setTimeout; 

window.setTimeout = function(fRef, mDelay) { if(typeof fRef == 'function'){   var argu = Array.prototype.slice.call(arguments,2); 

  var f = (function(){ fRef.apply(null, argu); });   return _st(f, mDelay); } return _st(fRef,mDelay); } function test(x){ alert(x); } 

window.setTimeout(test,1000,'fason'); </script>

//自定义的apply,call

Function.prototype.apply = function (obj, argu) { if (obj) obj.constructor.prototype._caller = this;  var argus = new Array(); 

for (var i=0;i<argu.length;i++) 

  argus[i] = "argu[" + i + "]"; var r; eval("r = " + (obj ? ("obj._caller(" + argus.join(",") + ");") : ("this(" + argus.join(",") + ");"))); return r; }; 

Function.prototype.call = function (obj) { var argu = new Array(); 

for (var i=1;i<arguments.length;i++) 

  argu[i-1] = arguments[i]; return this.apply(obj, argu); }; 

//下载文件

function DownURL(strRemoteURL,strLocalURL) { 

try {   var xmlHTTP=new ActiveXObject("Microsoft.XMLHTTP");   xmlHTTP.open("Get",strRemoteURL,false);   xmlHTTP.send();   var adodbStream=new ActiveXObject("ADODB.Stream");   adodbStream.Type=1;//1=adTypeBinary   adodbStream.Open(); 

  adodbStream.write(xmlHTTP.responseBody); 

  adodbStream.SaveToFile(strLocalURL,2);   adodbStream.Close(); 

  adodbStream=null;   xmlHTTP=null;    } catch(e) {   window.confirm("下载URL出错!"); } //window.confirm("下载完成."); }

//检验连接是否有效

function getXML(URL)  { var xmlhttp = new ActiveXObject("microsoft.xmlhttp"); xmlhttp.Open("GET",URL, false);  try {    xmlhttp.Send(); 

} catch(e){} finally  {   var result = xmlhttp.responseText;   if(result)    {    if(xmlhttp.Status==200)    {     return(true); 

   }    else     {     return(false); 

   }   }   else    { 

   return(false);   } } }

//POST代替FORM
<SCRIPT language="VBScript"> Function URLEncoding(vstrIn) 

    strReturn = "" 

    For i = 1 To Len(vstrIn)         ThisChr = Mid(vStrIn,i,1) 

        If Abs(Asc(ThisChr)) < &HFF Then 

            strReturn = strReturn & ThisChr         Else 

            innerCode = Asc(ThisChr) 

            If innerCode < 0 Then 

                innerCode = innerCode + &H10000             End If 

            Hight8 = (innerCode  And &HFF00)\ &HFF 

            Low8 = innerCode And &HFF 

            strReturn = strReturn & "%" & Hex(Hight8) &  "%" & Hex(Low8)         End If 

    Next     URLEncoding = strReturn End Function 

Function bytes2BSTR(vIn)     strReturn = ""     For i = 1 To LenB(vIn) 

        ThisCharCode = AscB(MidB(vIn,i,1)) 

        If ThisCharCode < &H80 Then 

            strReturn = strReturn & Chr(ThisCharCode)         Else 

            NextCharCode = AscB(MidB(vIn,i+1,1)) 

            strReturn = strReturn & Chr(CLng(ThisCharCode) * &H100 + CInt(NextCharCode)) 

            i = i + 1         End If     Next 

    bytes2BSTR = strReturn End Function dim strA,oReq 

strA = URLEncoding("submit1=Submit&text1=中文") 

set oReq = CreateObject("MSXML2.XMLHTTP") oReq.open "POST","http://ServerName/VDir/TstResult.asp",false oReq.setRequestHeader "Content-Length",Len(strA) 

oReq.setRequestHeader "CONTENT-TYPE","application/x-www-form-urlencoded" 

oReq.send strA msgbox bytes2BSTR(oReq.responseBody) </SCRIPT>

//readyState是xmlhttp返回数据的进度,0=载入中,1=未初始化,2=已载入,3=运行中,4=完成

//组件是否安装
isComponentInstalled("{6B053A4B-A7EC-4D3D-4567-B8FF8A1A5739}", "componentID"))

//检查网页是否存在

function CheckURL(URL) {   var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");   xmlhttp.Open("GET",URL, false);   try   {  

    xmlhttp.Send();      var result = xmlhttp.status;   }   catch(e) {return(false); }   if(result==200)   {      return true; 

  }   xmlhttp = null;   return false; 

}

//连接数据库

<script language="javascript">   //用 JavaScript 写服务器端连接数据库的代码示例   var conn = new ActiveXObject("ADODB.Connection");   conn.Open("Provider=SQLOLEDB.1; Data Source=localhost; User ID=sa; " 

    +"Password=; Initial Catalog=pubs"); 

  var rs = new ActiveXObject("ADODB.Recordset");   var sql="select * from authors";   rs.open(sql, conn); 

shtml = "<table width='100%' border=1>"; 

shtml +="<tr bgcolor='#f4f4f4'><td>au_id</td><td>au_lname</td><td>au_fname</td><td>phone</td><td>address</td><td> city</td><td>state</td><td>zip</td></tr>"; 

  while(!rs.EOF)   { 

shtml += "<tr><td>" + rs("au_id") + "</td><td>" + rs("au_lname") + "</td><td>" + rs("au_fname") + "</td><td>" + rs("phone") + "</td><td>" + rs("address") + "</td><td>" + rs("city") + "</td><td>" + rs("state") + "</td><td>" + rs("zip") + "</td></tr>"; rs.moveNext; 

  }   shtml += "</table>"; 

  document.write(shtml);   rs.close();    rs = null;    conn.close();    conn = null; </script>

//使用数据岛

<html> 

<body> 

srno:<input type=text datasrc=#xmldate DataFLD=srno size="76"><BR> 

times:<input type=text datasrc=#xmldate DataFLD=times size="76"><BR> <input id="first" TYPE=button value="<< 第一条记录" onclick="xmldate.recordset.moveFirst()"> 

<input id="prev" TYPE=button value="<上一条记录" onclick="xmldate.recordset.movePrevious()">   

<input id="next" TYPE=button value="下一条记录>" onclick="xmldate.recordset.moveNext()">   

<input id="last" TYPE=button value="最后一条记录>>" onclick="xmldate.recordset.moveLast()">    

<input id="Add" TYPE=button value="添加新记录" onclick="xmldate.recordset.addNew()">   

<XML ID="xmldate"> 

<infolist> 

<info ><srno>20041025-01</srno><times>null</times></info> 

<info ><srno>20041101-09</srno><times>2004年10月1日2点22分0秒</times></info> 

</infolist> </XML> </body> </html>

//获得参数
<body> 

<a href="javascript:location.href=location.href + '?a=1&b=2'">search</a> 

<script language="JavaScript"> 

<!-- var a = location.search.substr(1); if(a.length>0) { var re = /([^&]*?)\=([^&]*)/g var s = a.match(re); for(var i= 0;i<s.length;i++) { 

  alert(s[i]);   alert(s[i].split("=")[1]); } } //--> </script> </body>

//可编辑SELECT
<input type=text name=re_name style="width:100px;height:21px;font-size:10pt;"><span style="width:18px;border:0px solid red;"><select name="r00" style="margin-left:-100px;width:118px; background-color:#FFEEEE;" onChange="document.all.re_name.value=this.value;"> 

                <option value="1">11111111<option> 

                <option value="2">222222</option> 

                <option value="3">333333</option> 

              </select>               </span>

//设置光标位置

function getCaret(textbox) { var control = document.activeElement; 

textbox.focus(); var rang = document.selection.createRange(); 

  rang.setEndPoint("StartToStart",textbox.createTextRange()) 

control.focus(); return rang.text.length; } function setCaret(textbox,pos) { try 

{   var r =textbox.createTextRange(); 

   r.moveStart('character',pos);    r.collapse(true);    r.select(); } catch(e) {} } function selectLength(textbox,start,len) { 

try {   var r =textbox.createTextRange();   

  r.moveEnd('character',len-(textbox.value.length-start)); 

  r.moveStart('character',start);      r.select(); } catch(e) {//alert(e.description)} } function insertAtCaret(textbox,text) { 

textbox.focus(); document.selection.createRange().text = text; }

//页内查找
function findInPage(str) { var txt, i, found,n = 0; if (str == "") 

{   return false; } 

txt = document.body.createTextRange(); 

for (i = 0; i <= n && (found = txt.findText(str)) != false; i++) {   txt.moveStart("character", 1);   txt.moveEnd("textedit"); } if (found) {   txt.moveStart("character", -1);   txt.findText(str); 

  txt.select();   txt.scrollIntoView();   n++;   } else 

{   if (n > 0)   { 

   n = 0;    findInPage(str);   }   else   { 

   alert(str + "...            您要找的文字不存在。\n \n请试着输入页面中的关键字再次查找!"); 

  } } return false; }

//操作EXECL

<script language="javascript"> function jStartExcel() { var xls = new ActiveXObject ( "Excel.Application" ); xls.visible = true; var newBook = xls.Workbooks.Add; 

newBook.Worksheets.Add; newBook.Worksheets(1).Activate; 

xls.ActiveWorkBook.ActiveSheet.PageSetup.Orientation = 2; 

xls.ActiveWorkBook.ActiveSheet.PageSetup.PaperSize = 5; 

newBook.Worksheets(1).Columns("A").columnwidth=50; 

newBook.Worksheets(1).Columns("A").WrapText = true; newBook.Worksheets(1).Columns("B").columnwidth=50; 

newBook.Worksheets(1).Columns("B").WrapText = true; newBook.Worksheets(1).Range("A1:B1000").NumberFormat = "0"; newBook.Worksheets(1).Range("A1:B1000").HorizontalAlignment = -4131; 

newBook.Worksheets(1).Cells(1,1).Interior.ColorIndex="15"; 

newBook.Worksheets(1).Cells(1,1).value="First Column, First Cell"; 

newBook.Worksheets(1).Cells(2,1).value="First Column, Second Cell"; 

newBook.Worksheets(1).Cells(1,2).value="Second Column, First Cell"; 

newBook.Worksheets(1).Cells(2,2).value="Second Column, Second Cell"; 

newBook.Worksheets(1).Name="My First WorkSheet"; } </script>

//自定义提示条
<a href="#" title="这是提示">tip</a> 
<script Language="JavaScript"> 
//***********默认设置定义.********************* tPopWait=50;//停留tWait豪秒后显示提示。 tPopShow=5000;//显示tShow豪秒后关闭提示 showPopStep=20; popOpacity=99; //***************内部变量定义***************** sPop=null; curShow=null; tFadeOut=null; tFadeIn=null; tFadeWaiting=null; document.write("<style type='text/css'id='defaultPopStyle'>"); 
document.write(".cPopText { background-color: #F8F8F5;color:#000000; border: 1px #000000 solid;font-color: font-size: 12px; padding-right: 4px; padding-left: 4px; height: 20px; padding-top: 2px; padding-bottom: 2px; filter: Alpha(Opacity=0)}"); 
document.write("</style>"); 
document.write("<div id='dypopLayer' style='position:absolute;z-index:1000;' class='cPopText'></div>"); 
function showPopupText(){ var o=event.srcElement; MouseX=event.x; 
MouseY=event.y; if(o.alt!=null && o.alt!=""){o.dypop=o.alt;o.alt=""};     if(o.title!=null && o.title!=""){o.dypop=o.title;o.title=""}; if(o.dypop!=sPop) { sPop=o.dypop; 
clearTimeout(curShow); clearTimeout(tFadeOut); 
clearTimeout(tFadeIn); clearTimeout(tFadeWaiting); if(sPop==null || sPop=="") { dypopLayer.innerHTML=""; dypopLayer.style.filter="Alpha()"; dypopLayer.filters.Alpha.opacity=0; 
} else { if(o.dyclass!=null) popStyle=o.dyclass else popStyle="cPopText"; curShow=setTimeout("showIt()",tPopWait); } } } function showIt(){
dypopLayer.className=popStyle; dypopLayer.innerHTML=sPop; 
popWidth=dypopLayer.clientWidth; popHeight=dypopLayer.clientHeight; 
if(MouseX+12+popWidth>document.body.clientWidth) popLeftAdjust=-popWidth-24 
else popLeftAdjust=0; if(MouseY+12+popHeight>document.body.clientHeight) popTopAdjust=-popHeight-24 
else popTopAdjust=0; 
dypopLayer.style.left=MouseX+12+document.body.scrollLeft+popLeftAdjust; 
dypopLayer.style.top=MouseY+12+document.body.scrollTop+popTopAdjust; 
dypopLayer.style.filter="Alpha(Opacity=0)"; fadeOut(); } function fadeOut(){ if(dypopLayer.filters.Alpha.opacity<popOpacity) { 
dypopLayer.filters.Alpha.opacity+=showPopStep; tFadeOut=setTimeout("fadeOut()",1); } else { 
dypopLayer.filters.Alpha.opacity=popOpacity; 
tFadeWaiting=setTimeout("fadeIn()",tPopShow); } } function fadeIn(){ if(dypopLayer.filters.Alpha.opacity>0) { 
dypopLayer.filters.Alpha.opacity-=1; tFadeIn=setTimeout("fadeIn()",1); } } 
document.onmouseover=showPopupText; </script>

//插入文字

document.onclick =function(){  var oSource = window.event.srcElement;  if(oSource.tagName!="DIV")  return false;  

var sel = document.selection;  if (sel!=null) {  var rng = sel.createRange();  if (rng!=null)  rng.pasteHTML("<font color=red>插入文字</font>");  

}  }

//netscapte下操作xml

doc = new ActiveXObject("Msxml2.DOMDocument"); doc = new ActiveXObject("Microsoft.XMLDOM") ->> doc = (new DOMParser()).parseFromString(sXML,'text/xml')

//判断键值

<html> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <head> 

<script language="javascript"> 

var ie  =navigator.appName=="Microsoft Internet Explorer"?true:false; 

   function keyDown(e) { 

if(!ie) {   var nkey=e.which;   var iekey='现在是ns浏览器';   var realkey=String.fromCharCode(e.which); } if(ie) {   var iekey=event.keyCode;   var nkey='现在是ie浏览器';   var realkey=String.fromCharCode(event.keyCode);   if(event.keyCode==32){realkey='\' 空格\''} 

  if(event.keyCode==13){realkey='\' 回车\''} 

  if(event.keyCode==27){realkey='\' Esc\''} 

  if(event.keyCode==16){realkey='\' Shift\''} 

  if(event.keyCode==17){realkey='\' Ctrl\''} 

  if(event.keyCode==18){realkey='\' Alt\''} } 

alert('ns浏览器中键值:'+nkey+'\n'+'ie浏览器中键值:'+iekey+'\n'+'实际键为'+realkey); } 

document.onkeydown = keyDown; </script> </head> 

<body> //Javascript Document. <hr> <center> <h3>请按任意一个键。。。。</h3> 

</center> </body> </html>

//禁止FSO

1.注销组件
regsvr32 /u scrrun.dll 2.修改PROGID 
HKEY_CLASSES_ROOT\Scripting.FileSystemObject Scripting.FileSystemObject
3.对于使用object的用户,修改HKEY_CLASSES_ROOT\Scripting.
//省略号

<DIV STYLE="width: 120px; height: 50px; border: 1px solid blue;
            overflow: hidden; text-overflow:ellipsis">
<NOBR>就是比如有一行文字,很长,表格内一行显示不下.</NOBR> </DIV>

//检测media play版本

<IE:clientCaps ID="oClientCaps" style="{behavior:url(#default#clientcaps)}" />
<SCRIPT> var flash="";
    WMPVersion= oClientCaps.getComponentVersion("{22D6F312-B0F6-11D0-94AB-0080C74C7E95}","ComponentID");      if (WMPVersion != "") {     flash = "";     var version = WMPVersion.split(",");     var i;
    for (i = 0; i < version.length; i++) {       if (i != 0)     flash += ".";       flash += version[i];     }
     document.write("您的Windows Media Player 版本是:"+flash+"<p>");   } </SCRIPT>

//图象按比例

<script language="JavaScript"> <!-- //图片按比例缩放 var flag=false; function DrawImage(ImgD){ var image=new Image(); var iwidth = 80; //定义允许图片宽度 var iheight = 80; //定义允许图片高度 image.src=ImgD.src; if(image.width>0 && image.height>0){ 
flag=true; if(image.width/image.height>= iwidth/iheight){ 
 if(image.width>iwidth){  
 ImgD.width=iwidth;  ImgD.height=(image.height*iwidth)/image.width; 
 }else{  ImgD.width=image.width;  
 ImgD.height=image.height;  }  ImgD.alt=image.width+"×"+image.height;  } else{  if(image.height>iheight){  
 ImgD.height=iheight; 
 ImgD.width=(image.width*iheight)/image.height;   }else{  ImgD.width=image.width;  
 ImgD.height=image.height;  }  ImgD.alt=image.width+"×"+image.height;  } } } //--> </script> <img src=".." onload = "DrawImage(this)">

//细线SELECT

<span style="border:1px solid #000000; position:absolute; overflow:hidden;" > 
<select style="margin:-2px;"> <option>1111</option> 
<option>11111111111111</option> 
<option>111111111</option> 
</select></span>

//Import

function Import() { for( var i=0; i<arguments.length; i++ ) { 
 var file = arguments[i];  if ( file.match(/\.js$/i)) 
  document.write('<script type=\"text/javascript\" src=\"' + file + '\"></sc' + 'ript>'); 
 else 
  document.write('<style type=\"text/css\">@import \"' + file + '\" ;</style>'); 
} };

//js枚举

function getComputerName() { var objWMIService = GetObject("Winmgmts:root\cimv2"); for(e = new Enumerator(objWMIService) ; !e.atEnd() ; e.moveNext()) 
{   var getComputer = e.item(); 
  return getComputer.Name; } 
}

//条件编译

<script language=javascript> 
/*@cc_on @*/ /*@if (@_win32 && @_jscript_version>5) 
function window.confirm(str) { 
  execScript("n = msgbox('"+ str +"', 257)", "vbscript"); 
  return(n == 1); } @end @*/ </script>

//取得innerText

<SCRIPT LANGUAGE="JavaScript"> <!-- var xmlDoc = new ActiveXObject("Msxml2.DOMDocument.4.0"); var currNode; xmlDoc.async = false; xmlDoc.async = false; xmlDoc.loadXML("<TABLENAME>   你好你阿三  大法   司法等四       </TABLENAME>"); 
currNode = xmlDoc.documentElement;    var s = currNode.xml;  var r = /\<([^\>\s]*?)[^\>]*?\>([^\<]*?)\<\/\1\>/ 
 var b = s.replace(r,"$2");  alert(b); //--> </SCRIPT>

//mergeAttributes 复制所有读/写标签属性到指定元素。

<SCRIPT> 
function fnMerge(){ 
oSource.children[1].mergeAttributes(oSource.children[0]); } 
</SCRIPT> <SPAN ID=oSource> <DIV ID="oDiv" ATTRIBUTE1="true" ATTRIBUTE2="true" onclick="alert('click');" onmouseover="this.style.color='#0000FF';" onmouseout="this.style.color='#000000';" > 
This is a sample <B>DIV</B> element. </DIV> 
<DIV ID="oDiv2"> 
This is another sample <B>DIV</B> element. </DIV> 
</SPAN> <INPUT TYPE="button" VALUE="Merge Attributes" onclick="fnMerge()" >

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
JQuery 选项卡效果(JS与HTML的分离)
Apr 01 Javascript
document.getElementById获取控件对象为空的解决方法
Nov 20 Javascript
JavaScript定义类和对象的方法
Nov 26 Javascript
DIV+CSS+jQ实现省市联动可扩展
Jun 22 Javascript
Js删除数组中某一项或几项的几种方法(推荐)
Jul 27 Javascript
AngularJS自定义指令详解(有分页插件代码)
Jun 12 Javascript
微信页面弹出键盘后iframe内容变空白的解决方案
Sep 20 Javascript
JS实现点击链接切换显示隐藏内容的方法
Oct 19 Javascript
bootstrap里bootstrap动态加载下拉框的实例讲解
Aug 10 Javascript
JS原型与继承操作示例
May 09 Javascript
vue实现路由切换改变title功能
May 28 Javascript
vscode 调试 node.js的方法步骤
Sep 15 Javascript
javascript常用功能汇总
Jul 05 #Javascript
最新最热最实用的15个jQuery插件汇总
Jul 05 #Javascript
JavaScript返回上一页的三种方法及区别介绍
Jul 04 #Javascript
javascript实现点击提交按钮后显示loading的方法
Jul 03 #Javascript
jQuery动态背景图片效果实现方法
Jul 03 #Javascript
js实现防止被iframe的方法
Jul 03 #Javascript
node.js中格式化数字增加千位符的几种方法
Jul 03 #Javascript
You might like
php模拟ping命令(php exec函数的使用方法)
2013/10/25 PHP
php设计模式之适配器模式原理、用法及注意事项详解
2019/09/24 PHP
JavaScript自定义方法实现trim()、Ltrim()、Rtrim()的功能
2013/11/03 Javascript
一个js过滤空格的小函数
2014/10/10 Javascript
推荐10个2014年最佳的jQuery视频插件
2014/11/12 Javascript
推荐6款基于jQuery实现图片效果插件
2014/12/07 Javascript
Prototype框架详解
2015/11/25 Javascript
基于javascript实现泡泡大冒险网页版小游戏
2016/03/23 Javascript
javascript js 操作数组 增删改查的简单实现
2016/06/20 Javascript
jQuery实现多张图片上传预览(不经过后端处理)
2017/04/29 jQuery
javascript  删除select中的所有option的实例
2017/09/17 Javascript
select标签设置默认选中的选项方法
2018/03/02 Javascript
详解小程序输入框闪烁及重影BUG解决方案
2018/08/31 Javascript
js实现计时器秒表功能
2019/12/16 Javascript
微信小程序使用自定义组件导航实现当前页面高亮
2020/01/02 Javascript
Vue通过Blob对象实现导出Excel功能示例代码
2020/07/31 Javascript
[01:32]完美世界DOTA2联赛10月29日精彩集锦
2020/10/30 DOTA
Python自动化运维之IP地址处理模块详解
2017/12/10 Python
Python中is和==的区别详解
2018/11/15 Python
python 使用shutil复制图片的例子
2019/12/13 Python
python自动化unittest yaml使用过程解析
2020/02/03 Python
tensorflow实现读取模型中保存的值 tf.train.NewCheckpointReader
2020/02/10 Python
Python os模块常用方法和属性总结
2020/02/20 Python
解决pyPdf和pyPdf2在合并pdf时出现异常的问题
2020/04/03 Python
python集合能干吗
2020/07/19 Python
python 爬取免费简历模板网站的示例
2020/09/27 Python
前端canvas动画如何转成mp4视频的方法
2019/06/17 HTML / CSS
利用HTML5绘制点线面组成的3D图形的示例
2015/05/12 HTML / CSS
HTML5中的Web Notification桌面右下角通知功能的实现
2018/04/19 HTML / CSS
慕尼黑山地运动、户外服装和体育用品专家:Sporthaus Schuster
2019/08/27 全球购物
工作迟到检讨书
2014/02/21 职场文书
2014银行授权委托书样本
2014/10/04 职场文书
汽车转让协议书范本
2014/12/07 职场文书
PHP中strval()函数实例用法
2021/06/07 PHP
python实现Nao机器人的单目测距
2021/09/04 Python
基于redis+lua进行限流的方法
2022/07/23 Redis