JavaScript是前端攻城师经常要用到的,属于网络的脚本语言。JavaScript 被用来改进设计、验证表单、检测浏览器、创建cookies,等等等等。是因特网上最流行的脚本语言,并且可在所有主要的浏览器中运行。它是通过嵌入或调入在标准的HTML语言中实现的。它的出现弥补了HTML语言的缺陷,它是Java与HTML折衷的选择,具有几个基本特点:1、是一种脚本编写语言;2、基于对象的语言;3、简单性;4、安全性;5、动态性的;6、跨平台性。
JavaScript的出现,它可以使得信息和用户之间不仅只是一种显示和浏览的关系,而是实现了一种实时的、动态的、可交式的表达能力。从而基于CGI静态的HTML页面将被可提供动态实时信息,并对客户操作进行反应的Web页面的取代。JavaScript脚本正是满足这种需求而产生的语言。它深受广泛用户的喜爱的欢迎。下面每一项都是JS中的小技巧,但十分的实用!
1. document.write(""); 输出语句
2. JS中的注释为//
3. 传统的HTML文档顺序是:
document->html->(head,body)
4. 一个浏览器窗口中的DOM顺序是:
window->(navigator,screen,history,location,document)
5. 得到表单中元素的名称和值:
document.getElementById("表单中元素的ID号").name(或value)
6. 一个小写转大写的JS:
document.getElementById("output").value=document.getElementById("input").value.toUpperCase();
7. JS中的值类型:
String,Number,Boolean,Null,Object,Function
8. JS中的字符型转换成数值型:
parseInt(),parseFloat()
9. JS中的数字转换成字符型:
("" 变量)
10. JS中的取字符串长度是:
(length)
11. JS中的字符与字符相连接使用 号.
12. JS中的比较操作符有:
==等于,!=不等于,>,>=,<.<=
13. JS中声明变量使用:
var来进行声明
14. JS中的判断语句结构:
if(condition){}else{}
15. JS中的循环结构:
for([initial expression];[condition];[upadte expression]) {inside loop}
16. 循环中止的命令是:
break
17. JS中的函数定义:
function functionName([parameter],...){statement[s]}
18. 当文件中出现多个form表单时.可以用document.forms[0],document.forms[1]来代替.
19. 窗口:
打开窗口window.open(), 关闭一个窗口:window.close(), 窗口本身:self
20. 状态栏的设置:
window.status="字符";
21. 弹出提示信息:
window.alert("字符");
22. 弹出确认框:
window.confirm();
23. 弹出输入提示框:
window.prompt();
24. 指定当前显示链接的位置:
window.location.href="URL"
25. 取出窗体中的所有表单的数量:
document.forms.length
26. 关闭文档的输出流:
document.close();
27. 字符串追加连接符: =
28. 创建一个文档元素:
document.createElement(),document.createTextNode()
29. 得到元素的方法:
document.getElementById()
30. 设置表单中所有文本型的成员的值为空:
var form = window.document.forms[0]
for (var i = 0; i<form.elements.length;i ){
if (form.elements.type == "text"){
form.elements.value = "";
}
}
31. 复选按钮在JS中判断是否选中:
document.forms[0].checkThis.checked
(checked属性代表为是否选中返回TRUE或FALSE)
32. 单选按钮组(单选按钮的名称必须相同):
取单选按钮组的长度document.forms[0].groupName.length
33. 单选按钮组判断是否被选中也是用checked.
34. 下拉列表框的值:
document.forms[0].selectName.options[n].value
(n有时用下拉列表框名称加上.selectedIndex来确定被选中的值)
35. 字符串的定义:
var myString = new String("This is lightsword");
36. 字符串转成大写:
string.toUpperCase(); 字符串转成小写:string.toLowerCase();
37. 返回字符串2在字符串1中出现的位置:
String1.indexOf("String2")!=-1则说明没找到.
38. 取字符串中指定位置的一个字符:
StringA.charAt(9);
39. 取出字符串中指定起点和终点的子字符串:
stringA.substring(2,6);
40. 数学函数:
Math.PI(返回圆周率),Math.SQRT2(返回开方),Math.max(value1,value2)返回两个数中的最大值,Math.pow(value1,10)返回value1的十次方,Math.round(value1)四舍五入函数,Math.floor(Math.random()*(n 1))返回随机数
41. 定义日期型变量:
var today = new Date();
42. 日期函数列表:
dateObj.getTime()得到时间,dateObj.getYear()得到年份,dateObj.getFullYear()得到四位的年份,
dateObj.getMonth()得到月份,dateObj.getDate()得到日,dateObj.getDay()得到日期几,
dateObj.getHours()得到小时,dateObj.getMinutes()得到分,dateObj.getSeconds()得到秒,
dateObj.setTime(value)设置时间,dateObj.setYear(val)设置年,
dateObj.setMonth(val)设置月,dateObj.setDate(val)设置日,
dateObj.setDay(val)设置星期几,dateObj.setHours设置小时,dateObj.setMinutes(val)设置分,
dateObj.setSeconds(val)设置秒 [注意:此日期时间从0开始计]
43. FRAME的表示方式:
[window.]frames[n].ObjFuncVarName,frames["frameName"].ObjFuncVarName,frameName.ObjFuncVarName
44. parent代表父亲对象,top代表最顶端对象
45. 打开子窗口的父窗口为:opener
46. 表示当前所属的位置:this
47. 当在超链接中调用JS函数时用:(javascript :)来开头后面加函数名
48. 在老的浏览器中不执行此JS:<!-- //-->
49. 引用一个文件式的JS:<script type="text/javascript" src="aaa.js"></script>
50. 指定在不支持脚本的浏览器显示的HTML:<noscript></noscript>
51. 当超链和onCLICK事件都有时,则老版本的浏览器转向a.html,否则转向b.html.
例:<a href="a.html" onclick="location.href='b.html';return false">dfsadf</a>
52. JS的内建对象有:
Array,Boolean,Date,Error,EvalError,
Function,Math,Number,Object,RangeError,ReferenceError,
RegExp,String,SyntaxError,TypeError,URIError
53. JS中的换行:\n
54. 窗口全屏大小:
<script>function fullScreen(){ this.moveTo(0,0);this.outerWidth=screen.availWidth;
this.outerHeight=screen.availHeight;}window.maximize=fullScreen;</script>
55. JS中的all代表其下层的全部元素
56. JS中的焦点顺序:document.getElementByid("表单元素").tabIndex = 1
57. innerHTML的值是表单元素的值:
如<p id="para">"how are <em>you</em>"</p>,则innerHTML的值就是:how are <em>you</em>
58. innerTEXT的值和上面的一样,只不过不会把<em>这种标记显示出来.
59. contentEditable可设置元素是否可被修改,isContentEditable返回是否可修改的状态.
60. isDisabled判断是否为禁止状态.disabled设置禁止状态
61. length取得长度,返回整型数值
62. addBehavior()是一种JS调用的外部函数文件其扩展名为.htc
63. window.focus()使当前的窗口在所有窗口之前.
64. blur()指失去焦点.与FOCUS()相反.
65. select()指元素为选中状态.
66. 防止用户对文本框中输入文本:
onfocus="this.blur()"
67. 取出该元素在页面中出现的数量:
document.all.tags("div(或其它HTML标记符)").length
68. JS中分为两种窗体输出:模态和非模态.
window.showModaldialog(),window.showModeless()
69. 状态栏文字的设置:
window.status='文字',默认的状态栏文字设置:window.defaultStatus = '文字.';
70. 添加到收藏夹:
external.AddFavorite("http://www.97zzw.com";,"97站长网");
71. JS中遇到脚本错误时不做任何操作:
window.onerror = doNothing; 指定错误句柄的语法为:window.onerror = handleError;
72. JS中指定当前打开窗口的父窗口:
window.opener,支持opener.opener...的多重继续.
73. JS中的self指的是当前的窗口
74. JS中状态栏显示内容:window.status="内容"
75. JS中的top指的是框架集中最顶层的框架
76. JS中关闭当前的窗口:window.close();
77. JS中提出是否确认的框:if(confirm("Are you sure?")){alert("ok");}else{alert("Not Ok");}
78. JS中的窗口重定向:window.navigate("http://www.97zzw.com";);
79. JS中的打印:window.print()
80. JS中的提示输入框:window.prompt("message","defaultReply");
81. JS中的窗口滚动条:window.scroll(x,y)
82. JS中的窗口滚动到位置:window.scrollby
83. JS中设置时间间隔:setInterval("expr",msecDelay)或setInterval(funcRef,msecDelay)或setTimeout
84. JS中的模态显示在IE4 行,在NN中不行:showModalDialog("URL"[,arguments][,features]);
85. JS中的退出之前使用的句柄:
function verifyClose(){event.returnValue="we really like you and hope you will stay longer.";}} window.=verifyClose;
86. 当窗体第一次调用时使用的文件句柄:onload()
87. 当窗体关闭时调用的文件句柄:onunload()
88. window.location的属性:
protocol(http:),hostname(www.97zzw.com),port(80),host(www.yuzi.me:80),
pathname("/a/a.html"),hash("#giantGizmo",指跳转到相应的锚记),href(全部的信息)
89. window.location.reload()刷新当前页面.
90. window.history.back()返回上一页,window.history.forward()返回下一页,
window.history.go(返回第几页,也可以使用访问过的URL)
91. document.write()不换行的输出,document.writeln()换行输出
92. document.body.noWrap=true;防止链接文字折行.
93. 变量名.charAt(第几位),取该变量的第几位的字符.
94. "abc".charCodeAt(第几个),返回第几个字符的ASCii码值.
95. 字符串连接:string.concat(string2),或用 =进行连接
96. 变量.indexOf("字符",起始位置),返回第一个出现的位置(从0开始计算)
97. string.lastIndexOf(searchString[,startIndex])最后一次出现的位置.
98. string.match(regExpression),判断字符是否匹配.
99. string.replace(regExpression,replaceString)替换现有字符串.
100. string.split(分隔符)返回一个数组存储值.
101. string.substr(start[,length])取从第几位到指定长度的字符串.
102. string.toLowerCase()使字符串全部变为小写.
103. string.toUpperCase()使全部字符变为大写.
104. parseInt(string[,radix(代表进制)])强制转换成整型.
105. parseFloat(string[,radix])强制转换成浮点型.
106. isNaN(变量):测试是否为数值型.
107. 定义常量的关键字:const,定义变量的关键字:var
108. oncontextmenu="window.event.returnValue=false" 将彻底屏蔽鼠标右键
<table border oncontextmenu=return(false)><td>no</td></table>可用于Table
109. <body onselectstart="return false"> 取消选取、防止复制
110. onpaste="return false" 不准粘贴
111. oncopy="return false;" oncut="return false;" 防止复制
112. <link rel="Shortcut Icon" href="favicon.ico"> IE地址栏前换成自己的图标
113. <link rel="Bookmark" href="favicon.ico"> 可以在收藏夹中显示出你的图标
114. <input style="ime-mode:disabled"> 关闭输入法
115. <a href="javascript:if(confirm("确实要删除吗?"))location="boos.aspx?&areyou=删除&page=1"">删除</a> 删除时确认
116. 光标是停在文本框文字的最后
<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()">
JS事件大全
onClick IE3|N2|O3 鼠标点击事件,多用在某个对象控制的范围内的鼠标点击
onDblClick IE4|N4|O 鼠标双击事件
onMouseDown IE4|N4|O 鼠标上的按钮被按下了
onMouseUp IE4|N4|O 鼠标按下后,松开时激发的事件
onMouseOver IE3|N2|O3 当鼠标移动到某对象范围的上方时触发的事件
onMouseMove IE4|N4|O 鼠标移动时触发的事件
onMouseOut IE4|N3|O3 当鼠标离开某对象范围时触发的事件
onKeyPress IE4|N4|O 当键盘上的某个键被按下并且释放时触发的事件.[注意:页面内必须有被聚焦的对象]
onKeyDown IE4|N4|O 当键盘上某个按键被按下时触发的事件[注意:页面内必须有被聚焦的对象]
onKeyUp IE4|N4|O 当键盘上某个按键被按放开时触发的事件[注意:页面内必须有被聚焦的对象]
页面相关事件 事件 浏览器支持 描述
onAbort IE4|N3|O 图片在下载时被用户中断
onBeforeUnload IE4|N|O 当前页面的内容将要被改变时触发的事件
onError IE4|N3|O 捕抓当前页面因为某种原因而出现的错误,如脚本错误与外部数据引用的错误
onLoad IE3|N2|O3 页面内空完成传送到浏览器时触发的事件,包括外部文件引入完成
onMove IE|N4|O 浏览器的窗口被移动时触发的事件
onResize IE4|N4|O 当浏览器的窗口大小被改变时触发的事件
onScroll IE4|N|O 浏览器的滚动条位置发生变化时触发的事件
onStop IE5|N|O 浏览器的停止按钮被按下时触发的事件或者正在下载的文件被中断
onUnload IE3|N2|O3 当前页面将被改变时触发的事件
表单相关事件 事件 浏览器支持 描述
onBlur IE3|N2|O3 当前元素失去焦点时触发的事件 [鼠标与键盘的触发均可]
onChange IE3|N2|O3 当前元素失去焦点并且元素的内容发生改变而触发的事件 [鼠标与键盘的触发均可]
onFocus IE3|N2|O3 当某个元素获得焦点时触发的事件
onReset IE4|N3|O3 当表单中RESET的属性被激发时触发的事件
onSubmit IE3|N2|O3 一个表单被递交时触发的事件
滚动字幕事件 事件 浏览器支持 描述
onBounce IE4|N|O 在Marquee内的内容移动至Marquee显示范围之外时触发的事件
onFinish IE4|N|O 当Marquee元素完成需要显示的内容后触发的事件
onStart IE4|N|O 当Marquee元素开始显示内容时触发的事件
编辑事件 事件 浏览器支持 描述
onBeforeCopy IE5|N|O 当页面当前的被选择内容将要复制到浏览者系统的剪贴板前触发的事件
onBeforeCut IE5|N|O 当页面中的一部分或者全部的内容将被移离当前页面[剪贴]并移动到浏览者的系统剪贴板时触发的事件
onBeforeEditFocus IE5|N|O 当前元素将要进入编辑状态
onBeforePaste IE5|N|O 内容将要从浏览者的系统剪贴板传送[粘贴]到页面中时触发的事件
onBeforeUpdate IE5|N|O 当浏览者粘贴系统剪贴板中的内容时通知目标对象
onContextMenu IE5|N|O 当浏览者按下鼠标右键出现菜单时或者通过键盘的按键触发页面菜单时触发的事件 [试试在页面中的<body>中加入onContentMenu="return false"就可禁止使用鼠标右键了]
onCopy IE5|N|O 当页面当前的被选择内容被复制后触发的事件
onCut IE5|N|O 当页面当前的被选择内容被剪切时触发的事件
onDrag IE5|N|O 当某个对象被拖动时触发的事件 [活动事件]
onDragDrop IE|N4|O 一个外部对象被鼠标拖进当前窗口或者帧
onDragEnd IE5|N|O 当鼠标拖动结束时触发的事件,即鼠标的按钮被释放了
onDragEnter IE5|N|O 当对象被鼠标拖动的对象进入其容器范围内时触发的事件
onDragLeave IE5|N|O 当对象被鼠标拖动的对象离开其容器范围内时触发的事件
onDragOver IE5|N|O 当某被拖动的对象在另一对象容器范围内拖动时触发的事件
onDragStart IE4|N|O 当某对象将被拖动时触发的事件
onDrop IE5|N|O 在一个拖动过程中,释放鼠标键时触发的事件
onLoseCapture IE5|N|O 当元素失去鼠标移动所形成的选择焦点时触发的事件
onPaste IE5|N|O 当内容被粘贴时触发的事件
onSelect IE4|N|O 当文本内容被选择时的事件
onSelectStart IE4|N|O 当文本内容选择将开始发生时触发的事件
数据绑定 事件 浏览器支持 描述
onAfterUpdate IE4|N|O 当数据完成由数据源到对象的传送时触发的事件
onCellChange IE5|N|O 当数据来源发生变化时
onDataAvailable IE4|N|O 当数据接收完成时触发事件
onDatasetChanged IE4|N|O 数据在数据源发生变化时触发的事件
onDatasetComplete IE4|N|O 当来子数据源的全部有效数据读取完毕时触发的事件
onErrorUpdate IE4|N|O 当使用onBeforeUpdate事件触发取消了数据传送时,代替onAfterUpdate事件
onRowEnter IE5|N|O 当前数据源的数据发生变化并且有新的有效数据时触发的事件
onRowExit IE5|N|O 当前数据源的数据将要发生变化时触发的事件
onRowsDelete IE5|N|O 当前数据记录将被删除时触发的事件
onRowsInserted IE5|N|O 当前数据源将要插入新数据记录时触发的事件
数据绑定 事件 浏览器支持 描述
onAfterPrint IE5|N|O 当文档被打印后触发的事件
onBeforePrint IE5|N|O 当文档即将打印时触发的事件
onFilterChange IE4|N|O 当某个对象的滤镜效果发生变化时触发的事件
onHelp IE4|N|O 当浏览者按下F1或者浏览器的帮助选择时触发的事件
onPropertyChange IE5|N|O 当对象的属性之一发生变化时触发的事件
onReadyStateChange IE4|N|O 当对象的初始化属性值发生变化时触发的事件