前端基础 之JS
浏览目录
一、JavaScript语法基础
1、变量命名规范
- 变量名只能是 字母、数字、下划线或美元符号的任意组合
- 变量名不能是数字开头
- 关键字不能声明为变量名
- 建议用驼峰命名方式
- 变量名是区分大小写
- 变量的定义要具有可描述性
2、变量声明
- var 变量名 = 变量值;
- JavaScript属于动态类型(同一个变量可以存不同数据类型的值)
- 语句必须以分号结束
3、注释
- // 单行注释
- /*
多行注释
*/
二、JavaScript数据类型及类型查询
1、数字number
只有一种数字类型,数字可以带小数点,也可以不带
- 示例
var a = 12.34; var b = 20; var c = 123e5; # 12300000 var d = 123e-5; # 0.00123 ☆还有一种NaN,表示不是一个数字(Not a Number)
- 常用方法
# 将字符串转为数字(当传入的字符串参数不能转为数字时,变返回NaN) parseInt("123") # 返回123 parseInt("ABC") # 返回NaN,NaN属性是代表非数字值的特殊值,该属性用于指示某个值不是数字 parseFloat("123.456") # 返回123.456
2、字符串String
字符串可以是引号中的任意文本,可以使用单引号或双引号
- 示例
var a = "Hello"; var b = 'World'; var c = a + b; console.log(c); # 得到HelloWorld
- 常用方法
·String.length:返回长度 ·String.trim():移除空白 ·String.trimLeft():移除左边空白 ·String.trimRight():移除右边空白 ·String.charAt(n):返回第N个字符 ·String.concat(value, ...):拼接字符串 ·String.indexOf(substring, start):返回子序列位置 ·String.substring(from, to):根据索引获取子序列(顾头不顾尾) ·String.slice(start, end):切片 ·String.toLowerCase():转换成小写 ·String.toUpperCase():转换成大写 ·String.split(delimiter, limit):分割 ·string.slice(start, stop)和string.substring(start, stop)对比: ·两者的相同点: 如果start等于end,返回空字符串 如果stop参数省略,则取到字符串末 如果某个参数超过string的长度,这个参数会被替换为string的长度 ·substirng()的特点: 如果 start > stop ,start和stop将被交换 如果参数是负数或者不是数字,将会被0替换 ·silce()的特点: 如果 start > stop 不会交换两者 如果start小于0,则切割从字符串末尾往前数的第abs(start)个的字符开始(包括该位置的字符) 如果stop小于0,则切割在从字符串末尾往前数的第abs(stop)个字符结束(不包含该位置字符)
3、布尔类型Boolean
布尔只能有两个值:true 或 false(注意true和false都是小写)
- 示例
var x=true; var y=false;
4、数组Array
- 示例
·创建数组方式一: var cars=new Array(); cars[0]="A"; cars[1]="B"; cars[2]="C"; ·创建数组方式二: var cars=new Array("A","B","C");
- 常用方法
·Array.length:数组的长度 ·Array.push(element):尾部追加元素 ·Array.pop():获取尾部的元素 ·Array.unshift(element):头部插入元素 ·Array.shift():头部移除元素 ·Array.slice(start, end):切片 ·Array.reverse():反转 ·Array.join(seq):将数组元素连接成字符串 ·Array.concat(val, ...):连接数组 ·Array.sort():排序 ·关于鸡肋的JavaScript内置sort方法的解释及优化: /* 如果调用sort方法时没有传入参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。 如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数 a 和 b,其返回值如下: 若 a 小于 b,在排序后的数组中 a 应该出现在 b 之前,则返回一个小于 0 的值。 若 a 等于 b,则返回 0。 若 a 大于 b,则返回一个大于 0 的值。 */ // 根据上面的规则自行实现一个排序函数: function sortNumber(a,b) { return a - b } // 调用sort方法时将定义好的排序函数传入即可。 stringObj.sort(sortNumber)
5、对象Object
对象由花括号分隔。在括号内部,对象的属性以名称和值对的形式 (name : value) 来定义。属性由逗号分隔
- 示例
var person={ firstname : "Ya", lastname : "elegance", id : 818104 };
- 常用方法
name=person.lastname; name=person["lastname"];
6、空Null
表示值是空,一般在需要指定或清空一个变量时才会使用
7、未定义Undefined
当声明一个变量但未初始化时,该变量的默认值是undefined,函数无明确的返回值时,返回值也是undefined
8、类型查询
- 方法:typeof
- typeof是一个一元运算符(就像++,–,!,- 等一元运算符),不是一个函数,也不是一个语句
- 规则
- undefined - 如果变量是 Undefined 类型的
- boolean - 如果变量是 Boolean 类型的
- number - 如果变量是 Number 类型的
- string - 如果变量是 String 类型的
- object - 如果变量是一种引用类型或 Null 类型的
三、JavaScript运算符
1、算数运算符
- +:相加
- -:相减
- *:相乘
- /:相除
- %:取余
- ++:自加1 (注意:n++表示后自加,++n表示先自加)
- –:自减1 (注意:n–表示后自减,–n表示先自减)
2、比较运算符
- > :大于
- >= :大于等于
- < :小于
- <= :小于等于
- == :相等,判断值是否相等
- != :不等于
- === :严格相等,判断值、类型是否完全相等
- !== :严格不等于
3、逻辑运算符
- && :且
- || :或
- ! :非
4、赋值运算符
- = :赋值
- += :自加
- -= :自减
- *= :自乘
- /= :自除
四、JavaScript流程控制
1、if else
var a = 10; if (a > 5){ console.log("yes"); }else { console.log("no"); }
2、if-- else if --else
var a = 10; if (a > 5){ console.log("a > 5"); }else if (a < 5) { console.log("a < 5"); }else { console.log("a = 5"); }
3、switch
var day = new Date().getDay(); switch (day) { case 0: console.log("Sunday"); break; case 1: console.log("Monday"); break; default: console.log("...") }
注意:switch中的case子句通常都会加break语句,否则程序会继续执行后续case中的语句
4、for
for (var i=0;i<10;i++) { console.log(i); }
5、while
var i = 0; while (i < 10) { console.log(i); i++; }
6、三元运算
格式:判断条件?满足条件的返回值:不满足条件的返回值
var a = 1; var b = 2; var c = a > b ? a : b
五、JavaScript函数
1、函数定义
- 普通函数定义
function func() { console.log('hello world!'); }
- 带参数的函数定义
function func(arg1,arg2){ console.log('arg1:',arg1); console.log('arg2:',arg2); }
- 带返回值的函数定义
function func1(arg1,arg2){ return arg1+arg2; } fun1(1,2); //函数调用
- 匿名函数定义
var foo= function(arg1,arg2){ return arg1+arg2; } foo(1,2) //函数调用
- 立即执行函数定义
(function(arg1,arg2){ return arg1+arg2; })(1,2);
2、类数组对象arguments
- 作用
- Javascript并没有重载函数的功能,但是通过Arguments对象能够模拟重载;
- Javascript的每个函数都会有一个Arguments对象实例arguments,它引着函数的实参,它也有类似于数组的length属性。
- arguments.length为函数实参个数。
- arguments.callee引用函数自身。
- 示例
function func2(a,b) { console.log("总共有" + arguments.length + "个参数"); var ret = 0; for (var i=0;i<arguments.length;i++){ ret += arguments[i] } return ret; } console.log(func2(11,22,33));
3、局部变量&全局变量
- 局部变量
- 在Javascript函数内部声明变量(使用var)是局部变量,所以只能在函数内部访问它(该变量的作用域是函数内部);
- 只要函数运行完毕,本地变量就会被删除。
- 全局变量
- 在函数外声明的变量是全局变量,网页上的所有脚本和函数都能访问它。
- 变量生存周期:
- Javascript变量的生命周期从它们被声明的时开始;
- 局部变量会在函数运行以后被删除;
- 全局变量会在页面关闭后被删除。
4、作用域
首先在函数内部查找变量,找不到则到外层函数查找,逐步找到最外层。
var city = "BeiJing"; function f() { var city = "ShangHai"; function inner(){ var city = "ShenZhen"; console.log(city); } inner(); } f(); 结果: "ShenZhen"
var city = "BeiJing"; function Bar() { console.log(city); } function f() { var city = "ShangHai"; return Bar; } var ret = f(); ret(); 结果: "BeiJing"
var city = "BeiJing"; function f(){ var city = "ShangHai"; function inner(){ console.log(city); } return inner; } var ret = f(); ret(); 结果: "ShangHai"
六、词法分析
Javascript中在调用函数的那一瞬间,会先进行词法分析。
1、词法分析的过程
- 当函数调用的前一瞬间,会先形成一个激活对象:Avtive Object(AO),并会分析以下3个方面:
- 函数参数,如果有,则将此参数赋值给AO,且值为undefined。如果没有,则不做任何操作;
- 函数局部变量,如果AO上有同名的值,则不做任何操作。如果没有,则将此变量赋值给AO,并且值为undefiined。
- 函数声明,如果AO上有,则会将AO上的对象覆盖。如果没有,则不做任何操作。
2.注意:函数内部无论是使用参数还是使用局部变量都到AO上找。
var age = 18; function foo(){ console.log(age); var age = 22; console.log(age); } foo(); 结果: undefined 22
var age = 18; function foo(){ console.log(age); var age = 22; console.log(age); function age(){ console.log("呵呵"); } console.log(age); } foo(); 结果: function age() 22 22 词法分析过程: 1、分析参数,有一个参数,形成一个 AO.age=undefine; 2、分析变量声明,有一个 var age, 发现 AO 上面已经有一个 AO.age,因此不做任何处理 3、分析函数声明,有一个 function age(){...} 声明, 则把原有的 age 覆盖成AO.age=function(){...}; 最终,AO上的属性只有一个age,并且值为一个函数声明 执行过程: 注意:执行过程中所有的值都是从AO对象上去寻找 1、执行第一个 console.log(age) 时,此时的 AO.age 是一个函数,所以第一个输出的一个函数 2、这句 var age=22; 是对 AO.age 的属性赋值, 此时AO.age=22 ,所以在第二个输出的是 2 3、同理第三个输出的还是22, 因为中间再没有改变age值的语句了
七、JavaScript内置对象方法
1、介绍
- JavaScript中的所有事物都是对象:字符串、数字、数组、日期,等等。在JavaScript中,对象是拥有属性和方法的数据。
- 我们在学习基本数据类型的时候已经带大家了解了,JavaScript中的Number对象、String对象、Array对象等。
- 注意:var s1 = “abc”和var s2 = new String(“abc”)的区别:typeof s1 –> string而 typeof s2 –> Object
类型 | 内置对象 | 介绍 |
数据类型 | Number | 数字对象 |
数据类型 | String | 字符串对象 |
数据类型 | Boolean | 布尔值对象 |
组合对象 | Array | 数组对象 |
组合对象 | Math | 数学对象 |
组合对象 | Date | 日期对象 |
高级对象 | Object | 自定义对象 |
高级对象 | Error | 错误对象 |
高级对象 | Function | 函数对象 |
高级对象 | RegExp | 正则表达式 |
高级对象 | Global | 全局 |
2、自定义对象
- 创建、访问自定义对象
//方式一: var a = {"name": "Yang", "age": 18}; console.log(a.name); console.log(a["age"]); //方式二: var person=new Object(); // 创建一个person对象 person.name="Yang"; // person对象的name属性 person.age=18; // person对象的age属性
- 遍历对象中的内容
var a = {"name": "Yang", "age": 18}; for (var i in a){ console.log(i, a[i]); }
- JavaScript面向对象之继承(扩展)
// 父类构造函数 var Car = function (loc) { this.loc = loc; }; // 父类方法 Car.prototype.move = function () { this.loc ++; }; // 子类构造函数 var Van = function (loc) { Car.call(this, loc); }; // 继承父类的方法 Van.prototype = Object.create(Car.prototype); // 修复 constructor Van.prototype.constructor = Van; // 扩展方法 Van.prototype.grab = function () { /* ... */ };
3、Date对象
- 创建Date对象
//方法1:不指定参数 var d1 = new Date(); console.log(d1.toLocaleString()); //方法2:参数为日期字符串 var d2 = new Date("2008/8/8 20:08"); console.log(d2.toLocaleString()); var d3 = new Date("08/8/8 20:08"); console.log(d3.toLocaleString()); //方法3:参数为毫秒数 var d3 = new Date(5000); console.log(d3.toLocaleString()); console.log(d3.toUTCString()); //方法4:参数为年月日小时分钟秒毫秒 var d4 = new Date(2008,8,8,20,08,08,100); console.log(d4.toLocaleString()); //毫秒并不直接显示
- Date对象的方法
var d = new Date(); //getDay () 获取当前星期X(0-6,0代表星期天) //getMonth () 获取当前月份(0-11,0代表1月) //getFullYear () 获取完整的年份(4位,1970-????) //getYear () 获取当前年份(2位) //getHours () 获取当前小时数(0-23) //getMinutes () 获取当前分钟数(0-59) //getSeconds () 获取当前秒数(0-59) //getMilliseconds() 获取当前毫秒数(0-999) //getTime () 返回累计毫秒数(从1970/1/1午夜) //toLocaleDateString(); 获取当前日期 //toLocaleTimeString(); 获取当前时间 //toLocaleString( ); 获取日期与时间
4、JSON对象
方法示例
var str1 = '{"name": "Yang", "age": 18}'; var obj1 = {"name": "Yang", "age": 18}; // JSON字符串转换成对象 var obj = JSON.parse(str1); // 对象转换成JSON字符串 var str = JSON.stringify(obj1);
5、RegExp对象
- 创建方法
- 创建方法一
// 创建RegExp对象方式(逗号后面不要加空格) var reg1 = new RegExp("^[a-zA-Z][a-zA-Z0-9_]{5,11}$"); // 匹配响应的字符串 var s1 = "abc123"; //RegExp对象的test方法,测试一个字符串是否符合对应的正则规则,返回值是true或false。 reg1.test(s1); // true
-
- 创建方法二
// 匹配响应的字符串 var s1 = "abc123"; // /填写正则表达式/匹配模式(逗号后面不要加空格) var reg2 = /^[a-zA-Z][a-zA-Z0-9_]{5,11}$/.test(s1); // true
- 示例
// String对象与正则结合的4个方法 var s2 = "hello world"; s2.match(/o/g); // ["o", "o"] 查找字符串中 符合正则 的内容 s2.search(/h/g); // 0 查找字符串中符合正则表达式的内容位置 s2.split(/o/g); // ["hell", " w", "rld"] 按照正则表达式对字符串进行切割 s2.replace(/o/g, "s"); // "hells wsrld" 对字符串按照正则进行替换 // 关于匹配模式:g和i的简单示例 var s1 = "name:Adele age:18"; s1.replace(/a/, "替换"); // "n替换me:Adele age:18" s1.replace(/a/g, "替换"); // "n替换me:Adele 替换ge:18" 全局匹配 s1.replace(/a/gi, "替换"); // "n替换me:替换dele 替换ge:18" 不区分大小写
- RegExp对象使用时的几点之一事项
- 正则表达式(不能有空格)
- 匹配模式:常用g(全局匹配;找到所有匹配,而不是在第一个匹配后停止)和i(忽略大小写)
- 如果regExpObject带有全局标志g,test()函数不是从字符串的开头开始查找,而是从属性regExpObject.lastIndex所指定的索引处开始查找。该属性值默认为0,所以第一次仍然是从字符串的开头查找。当找到一个匹配时,test()函数会将regExpObject.lastIndex的值改为字符串中本次匹配内容的最后一个字符的下一个索引位置。当再次执行test()函数时,将会从该索引位置处开始查找,从而找到下一个匹配。因此,当我们使用test()函数执行了一次匹配之后,如果想要重新使用test()函数从头开始查找,则需要手动将regExpObject.lastIndex的值重置为 0。如果test()函数再也找不到可以匹配的文本时,该函数会自动把regExpObject.lastIndex属性重置为 0。
- 当我们不加参数调用RegExpObj.test()方法时, 相当于执行RegExpObj.test(“undefined”), 并且/undefined/.test()默认返回true。
6、Math对象
方法介绍:
对象 | 介绍 |
abs(x) | 返回数的绝对值 |
exp(x) | 返回 e 的指数 |
floor(x) | 对数进行下舍入 |
log(x) | 返回数的自然对数(底为e) |
max(x,y) | 返回 x 和 y 中的最高值 |
min(x,y) | 返回 x 和 y 中的最低值 |
pow(x,y) | 返回 x 的 y 次幂 |
random() | 返回 0 ~ 1 之间的随机数 |
round(x) | 把数四舍五入为最接近的整数 |
sin(x) | 返回数的正弦 |
sqrt(x) | 返回数的平方根 |
tan(x) | 返回角的正切 |