JavaScript 是互联网上最流行的脚本语言,是一种轻量级的编程语言,可插入 HTML 页面的编程代码,由浏览器执行


1 <script type="text/javascript"> 2 function Plus(){ 3 // alert(123) 4 var st=document.getElementById("count").value 5 var st_int=parseInt(st) 6 var new_int=st_int+1 7 document.getElementById("count").value=new_int 8 } 9 function jian(){ 10 // alert(123) 11 var st=document.getElementById("count").value 12 var st_int=parseInt(st) 13 var new_int=st_int-1 14 document.getElementById("count").value=new_int 15 } 16 </script>
JavaScript的用法
JavaScript的编写必须写在<script></script>标签之间,存在方式有两种:
- 直接在<script></script>里编写JavaScript代码
- 写在.js文件中,然后通过<script src="xxxx.js"></script>将js文件导入
JavaScript的存放位置:
- head标签里
- body标签里,一般放在body代码块底部
数据类型
- 字符串(String)
- 数字(Number)
- 布尔(Boolean)
- 数组(Array)
- 对象(Object)
- 空(Null)
- 未定义(Undefined)
字符串
常见的功能:
String 对字符串的支持
String.charAt( ) 返回字符串中的第n个字符
String.charCodeAt( ) 返回字符串中的第n个字符的代码
String.concat( ) 连接字符串
String.fromCharCode( ) 从字符编码创建—个字符串
String.indexOf( ) 检索字符串
String.lastIndexOf( ) 从后向前检索一个字符串
String.length 字符串的长度
String.localeCompare( ) 用本地特定的顺序来比较两个字符串
String.match( ) 找到一个或多个正则表达式的匹配
String.replace( ) 替换一个与正则表达式匹配的子串
+ $&表示匹配成功的项
+ 如果在匹配中加入分组的话,$1代表第一个组,以此类推 $n代表第n个组
+ $$输出一个$
+ $`:位于匹配子串左侧的文本
+ $':位于匹配子串右侧的文本
String.search( ) 检索与正则表达式相匹配的子串
String.slice( ) 抽取一个子串
String.split( ) 将字符串分割成字符串数组
String.substr( ) 抽取一个子串
String.substring( ) 返回字符串的一个子串
String.toLocaleLowerCase() 把字符串转换小写
String.toLocaleUpperCase() 将字符串转换成大写
String.toLowerCase( ) 将字符串转换成小写
String.toString( ) 返回字符串
String.toUpperCase( ) 将字符串转换成大写
String.valueOf( ) 返回字符串
数字(Number)
在JavaScript中,数字不分为整数类型和浮点型类型,所有的数字都是由 浮点型类型
常用的属性和方法:
Infinity,无穷大。可使用 isFinite(num) 来判断。
Number 对数字的支持
Number.MAX_VALUE 最大数值
Number.MIN_VALUE 最小数值
Number.NaN 特殊的非数字值
可以使用isNaN(num)来判断一个数是否为NaN
Number.NEGATIVE_INFINITY负无穷大
Number.POSITIVE_INFINITY正无穷大
Number.toExponential( ) 用指数计数法格式化数字
Number.toFixed( ) 采用定点计数法格式化数字
Number.toLocaleString( )把数字转换成本地格式的字符串
Number.toPrecision( ) 格式化数字的有效位
Number.toString( ) 将—个数字转换成字符串
可以使用 toString() 方法 输出16进制、8进制、2进制。


1 var myNumber=128; 2 myNumber.toString(16); // 返回 80 3 myNumber.toString(8); // 返回 200 4 myNumber.toString(2); // 返回 10000000
Number.valueOf( ) 返回原始数值
parseInt(..) 将某值转换成数字,不成功则NaN
parseFloat(..) 将某值转换成浮点数,不成功则NaN
布尔(Boolean)
如果boolean为0,-0,null,“”,false,undefined,NaN,那么对象的值为false,否则为true
- == 比较值相等
- != 不等于
- === 比较值和类型相等
- !=== 不等于
- || 或
- && 且


1 a=123 2 123 3 b="123" 4 "123" 5 a==b 6 true 7 a===b 8 false
数组(Array)
数组的定义:
常见功能:
Array 对数组内部的支持
Array.concat( ) 连接数组
Array.join( ) 将数组元素连接起来以构建一个字符串
Array.length 数组的大小
Array.pop( ) 删除并返回数组的最后一个元素
Array.push( ) 给数组添加元素
Array.reverse( ) 颠倒数组中元素的顺序
Array.shift( ) 将元素移出数组
Array.slice(start, deleteCount, value...) 返回数组的一部分,可插入、删除或替换数组的元素
obj.splice(n,
0
,val) 指定位置插入元素
obj.splice(n,
1
,val) 指定位置替换元素
obj.splice(n,
1
) 指定位置删除元素
Array.sort( ) 对数组元素进行排序
Array.splice( ) 插入、删除或替换数组的元素
Array.toLocaleString( ) 把数组转换成局部字符串
Array.toString( ) 将数组转换成一个字符串
Array.unshift( ) 在数组头部插入一个元素
对象(Object)
JavaScript是面向对象的语言,但是JavaScript没有class,只有函数,使用函数来构造对象
对象构造
function person(firstname,lastname,age,eyecolor)
{
this.firstname=firstname;
this.lastname=lastname;
this.age=age;
this.eyecolor=eyecolor;
}
obj=new person("xxx","xxx",18,"xxx")
通过定义一个函数来创建一个对象,通过new来创建一个对象,这个相当于类的构造函数,形式有点像C++。虽然我们也可以在函数里面定义方法,但是这样的话,每创建一个对象,都会在内存里开辟内存来存储方法,这肯定是不行的,所有我们可以通过以下方法来创建‘’类”的方法:
类名(也就上面的函数名).prototype={
方法名:function(){
return this.Name+this.Age
}
}
或者写成:
类名.prototype.方法名=function(){
...
}
时间处理对象(Date)
Date 操作日期和时间的对象
Date.getDate( ) 返回一个月中的某一天
Date.getDay( ) 返回一周中的某一天
Date.getFullYear( ) 返回Date对象的年份字段
Date.getHours( ) 返回Date对象的小时字段
Date.getMilliseconds( ) 返回Date对象的毫秒字段
Date.getMinutes( ) 返回Date对象的分钟字段
Date.getMonth( ) 返回Date对象的月份字段
Date.getSeconds( ) 返回Date对象的秒字段
Date.getTime( ) 返回Date对象的毫秒表示
Date.getTimezoneOffset( ) 判断与GMT的时间差
Date.getUTCDate( ) 返回该天是一个月的哪一天(世界时)
Date.getUTCDay( ) 返回该天是星期几(世界时)
Date.getUTCFullYear( ) 返回年份(世界时)
Date.getUTCHours( ) 返回Date对象的小时字段(世界时)
Date.getUTCMilliseconds( ) 返回Date对象的毫秒字段(世界时)
Date.getUTCMinutes( ) 返回Date对象的分钟字段(世界时)
Date.getUTCMonth( ) 返回Date对象的月份(世界时)
Date.getUTCSeconds( ) 返回Date对象的秒字段(世界时)
Date.getYear( ) 返回Date对象的年份字段(世界时)
Date.parse( ) 解析日期/时间字符串
Date.setDate( ) 设置一个月的某一天
Date.setFullYear( ) 设置年份,也可以设置月份和天
Date.setHours( ) 设置Date对象的小时字段、分钟字段、秒字段和毫秒字段
Date.setMilliseconds( ) 设置Date对象的毫秒字段
Date.setMinutes( ) 设置Date对象的分钟字段和秒字段
Date.setMonth( ) 设置Date对象的月份字段和天字段
Date.setSeconds( ) 设置Date对象的秒字段和毫秒字段
Date.setTime( ) 以毫秒设置Date对象
Date.setUTCDate( ) 设置一个月中的某一天(世界时)
Date.setUTCFullYear( ) 设置年份、月份和天(世界时)
Date.setUTCHours( ) 设置Date对象的小时字段、分钟字段、秒字段和毫秒字段(世界时)
Date.setUTCMilliseconds( ) 设置Date对象的毫秒字段(世界时)
Date.setUTCMinutes( ) 设置Date对象的分钟字段和秒字段(世界时)
Date.setUTCMonth( ) 设置Date对象的月份字段和天数字段(世界时)
Date.setUTCSeconds( ) 设置Date对象的秒字段和毫秒字段(世界时)
Date.setYear( ) 设置Date对象的年份字段
Date.toDateString( ) 返回Date对象日期部分作为字符串
Date.toGMTString( ) 将Date转换为世界时字符串
Date.toLocaleDateString( ) 回Date对象的日期部分作为本地已格式化的字符串
Date.toLocaleString( ) 将Date转换为本地已格式化的字符串
Date.toLocaleTimeString( ) 返回Date对象的时间部分作为本地已格式化的字符串
Date.toString( ) 将Date转换为字符串
Date.toTimeString( ) 返回Date对象日期部分作为字符串
Date.toUTCString( ) 将Date转换为字符串(世界时)
Date.UTC( ) 将Date规范转换成毫秒数
Date.valueOf( ) 将Date转换成毫秒表示
正则表达式对象(RegExp)
- /....../:定义正则表达式
- /....../g:全局匹配
- /....../i:不区分大小写
- /....../m:多行匹配
功能:
RegExp 用于模式匹配的正则表达式
RegExp.exec( ) 通用的匹配模式
RegExp.global 正则表达式是否全局匹配
RegExp.ignoreCase 正则表达式是否区分大小写
RegExp.lastIndex 下次匹配的起始位置
RegExp.source 正则表达式的文本
RegExp.test( ) 检测一个字符串是否匹配某个模式
RegExp.toString( ) 把正则表达式转换成字符串


1 var patt1=new RegExp("e"); 2 document.write(patt1.test("The best things in life are free")); 3 4 #####输出###### 5 true


1 var patt1=new RegExp("e"); 2 document.write(patt1.exec("The best things in life are free")); 3 4 #######输出######### 5 e