JavaScript基础知识

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的用法

JavaScript的编写必须写在<script></script>标签之间,存在方式有两种:

  1. 直接在<script></script>里编写JavaScript代码
  2. 写在.js文件中,然后通过<script src="xxxx.js"></script>将js文件导入

JavaScript的存放位置:

  1. head标签里
  2. 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
tostring
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)

数组的定义:

var myCars=new Array("Saab","Volvo","BMW");
var myCars=["Saab","Volvo","BMW"];

常见功能:

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
test
1 var patt1=new RegExp("e");
2 document.write(patt1.exec("The best things in life are free"));
3 
4 #######输出#########
5 e
exec

 

  

  

 

posted @ 2018-03-22 20:30  菜鸟也有高飞的时候  阅读(230)  评论(0编辑  收藏  举报