内置对象

内置对象

​ JavaScript 中的对象分为3种:自定义对象 、内置对象、 浏览器对象
​ 前面两种对象是JS 基础 内容,属于 ECMAScript; 第三个浏览器对象属于 JS 独有的, JS API 讲解内置对象就是指 JS 语言自带的一些对象,这些对象供开发者使用,并提供了一些常用的或是最基本而必要的功能(属性和方法),内置对象最大的优点就是帮助我们快速开发

​ JavaScript 提供了多个内置对象:Math、 Date 、Array、String等

查文档

​ 查找文档:学习一个内置对象的使用,只要学会其常用成员的使用即可,我们可以通过查文档学习,可以通过MDN/W3C来查询。
​ Mozilla 开发者网络(MDN)提供了有关开放网络技术(Open Web)的信息,包括 HTML、CSS 和万维网及 HTML5 应用的 API。
​ MDN:https://developer.mozilla.org/zh-CN/

Math对象

Math 对象不是构造函数,它具有数学常数和函数的属性和方法。跟数学相关的运算(求绝对值,取整、最大值等)可以使用 Math 中的成员。

属性、方法名 功能
Math.PI 圆周率
Math.floor() 向下取整
Math.ceil() 向上取整
Math.round() 四舍五入版 就近取整 注意 -3.5 结果是 -3
Math.abs() 绝对值
Math.max()/Math.min() 求最大和最小值
Math.random() 获取范围在[0,1)内的随机值

​ 注意:上面的方法使用时必须带括号

获取指定范围内的随机整数

1
2
3
function getRandom(min, max) {
return Math.floor(Math.random() * (max - min + 1)) + min;
}

日期对象

​ Date 对象和 Math 对象不一样,Date是一个构造函数,所以使用时需要实例化后才能使用其中具体方法和属性。Date 实例用来处理日期和时间

  • 使用Date实例化日期对象

    • 获取当前时间必须实例化:
    1
    var now = new Date();
    • 获取指定时间的日期对象
    1
    var future = new Date('2019/5/1');

    注意:如果创建实例时并未传入参数,则得到的日期对象是当前时间对应的日期对象

  • 使用Date实例的方法和属性

    ![](D:\学习资料\就业班学习资料\03-JavaScript基础 - 代码和作业\03-JavaScript基础 - 代码和作业\JavaScript基础第06天\4-笔记\images\图片1.png)

  • 通过Date实例获取总毫米数

    • 总毫秒数的含义

      ​ 基于1970年1月1日(世界标准时间)起的毫秒数

    • 获取总毫秒数

      1
      2
      3
      4
      5
      6
      7
      8
      9
      // 实例化Date对象
      var now = new Date();
      // 1. 用于获取对象的原始值
      console.log(date.valueOf())
      console.log(date.getTime())
      // 2. 简单写可以这么做
      var now = + new Date();
      // 3. HTML5中提供的方法,有兼容性问题
      var now = Date.now();

数组对象

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
instanceof Array //运算符 检测是否为数组
Array.isArray(参数) //检测是否为数组
.pop(); //删除数组末尾的元素 返回删除的元素
.push(); //给数组末尾添加元素 返回新数组的长度
.shift(); //删除数组第一个元素 返回删除的元素
.unshift(); //给数组开头添加新元素 返回新数组的长度
.reverse(); //数组倒序
.sort() //默认从小到大排序 对个位数有用
.sort(function(a,b) {return a-b;}); //自定义排序,从小到大
.sort(function(a,b) {return b-a;}); //自定义排序,从大到小
.indexOf(); //获取元素在数组的第一个索引,无则为-1(全等)
.indexOf('要查找的字符',[起始的位置]);
.lastIndexOf(); //获取元素在数组的最后一个索引,无则为-1(全等)
.lastIndexOf('要查找的字符',[起始的位置 从后数]);
.toString(); // 将数组转换成字符串
.join(分隔符); // 将数组转换成字符串还能修改分隔符
.slice(开始位置,结束位置) //方法返回一个新的数组对象,这一对象是一个由 begin 和 end 决定的原数组的浅拷贝(包括 begin,不包括end)。原始数组不会被改变
.splice(开始位置,结束位置,'要添加的值(可省略)'); //方法通过删除或替换现有元素或者原地添加新的元素来修改数组,并以数组形式返回被修改的内容。此方法会改变原数组。
arr1.concat(arr2); //合并两个或多个数组。返回一个新数组。

.map() // 法创建一个新数组,其结果是该数组中的每个元素是调用一次提供的函数后的返回值。
.some() // 检测数组中的元素是否满足指定条件(函数提供)return true会立即终止循环
.findIndex() // 返回传入一个测试条件(函数)符合条件的数组第一个元素位置。
.find() // 方法返回数组中满足提供的测试函数的第一个元素的值。否则返回 undefined
.includes() // 方法用来判断一个数组是否包含一个指定的值,根据情况,如果包含则返回 true,否则返回false。

字符串对象

基本包装类型

​ 为了方便操作基本数据类型,JavaScript 还提供了三个特殊的引用类型:String、Number和 Boolean。

​ 基本包装类型就是把简单数据类型包装成为复杂数据类型,这样基本数据类型就有了属性和方法。

1
2
3
// 下面代码有什么问题?
var str = 'andy';
console.log(str.length);

​ 按道理基本数据类型是没有属性和方法的,而对象才有属性和方法,但上面代码却可以执行,这是因为

​ js 会把基本数据类型包装为复杂数据类型,其执行过程如下 :

1
2
3
4
5
6
// 1. 生成临时变量,把简单类型包装为复杂数据类型
var temp = new String('andy');
// 2. 赋值给我们声明的字符变量
str = temp;
// 3. 销毁临时变量
temp = null;

字符串的不可变

​ 指的是里面的值不可变,虽然看上去可以改变内容,但其实是地址变了,内存中新开辟了一个内存空间。

​ 当重新给字符串变量赋值的时候,变量之前保存的字符串不会被修改,依然在内存中重新给字符串赋值,会重新在内存中开辟空间,这个特点就是字符串的不可变。
​ 由于字符串的不可变,在大量拼接字符串的时候会有效率问题

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
String.fromCharCode(); //从字符编码来看,代表的值
.charCodeAt(); //通过索引获取字符的ASCII码值
.charAt(); //通过索引获取字符 默认为0
[0]; //h5新增 通过索引获取字符
//字符串截取
.slice(,); //字符串从开始截取(包含开始)(不包含结束)
.substr(,); //方法返回一个字符串中从指定位置开始到指定字符数的字符(可能会被移除)
.substring(,); // 返回从指定位置开始到指定字符数或到末尾的字符
.sr1.concat(str2); //合并字符串 返回新的
.replace('被替换','替换') //替换对应的第一个匹配项(正则表达式可以全换)
.replaceAll('被替换','替换') //字符串全替换(可以用正则表达式)(node不支持)
.split('分隔符') //把字符串转换成数组 可以换分隔符 可以切割
toUpperCase() // 转换大写
toLowerCase() //转换小写
str.includes(); //判断一个字符串是否包含在另一个字符串中 返回布尔值
.indexOf(); //获取元素在字符串的第一个索引,无则为-1(全等)
.lastIndexOf(); //获取元素在字符串的最后一个索引,无则为-1(全等)
.toLocaleLowerCase(); //字符串转换为小写(大概)
.toLocaleUpperCase(); //字符串转换为大写(大概)
.toLowerCase(); //字符串转换为小写
.toUpperCase(); //字符串转换为大写 强制转换
.trim(); //从一个字符串的两端删除空白字符
.trimEnd() //trimRight 从一个字符串的末端删除空白字符
trimStart() //trimLeft 从一个字符串的开头删除空白字符
.startsWith(''); // 判断字符串是否以 开头
.endsWith(''); // 判断字符串是否以 结尾
.repeat(n); // 把字符串重复n次返回
.match(); // 返回一个字符串匹配正则表达式的结果。
.padStart(maxLength,fillString='') // 方法用另一个字符串填充当前字符串(如果需要的话,会重复多次),以便产生的字符串达到给定的长度。从当前字符串的左侧开始填充。
.padEnd(maxLength,fillString='') // 从当前字符串的右侧侧开始填充
97:a 65:A 32:" " 48:0 49:1 //ASCII对应值
arguments //只有函数才有的内置对象 存储了所有传递过来的实参 伪数组

简单数据类型和复杂数据类型

简单数据类型

简单类型基本数据类型值类型):在存储时变量中存储的是值本身,包括string ,number,boolean,undefined,null

复杂数据类型

复杂数据类型(引用类型):在存储时变量中存储的仅仅是地址(引用),通过 new 关键字创建的对象(系统对象、自定义对象),如 Object、Array、Date等;

堆栈

  • 堆栈空间分配区别:

  1、栈(操作系统):由操作系统自动分配释放存放函数的参数值、局部变量的值等。其操作方式类似于数据结构中的栈;

简单数据类型存放到栈里面

  2、堆(操作系统):存储复杂类型(对象),一般由程序员分配释放,若程序员不释放,由垃圾回收机制回收。

  • 简单数据类型的存储方式

    ​ 值类型变量的数据直接存放在变量(栈空间)中

  • 复杂数据类型的存储方式

    ​ 引用类型变量(栈空间)里存放的是地址,真正的对象实例存放在堆空间中

简单类型传参

​ 函数的形参也可以看做是一个变量,当我们把一个值类型变量作为参数传给函数的形参时,其实是把变量在栈空间里的值复制了一份给形参,那么在方法内部对形参做任何修改,都不会影响到的外部变量。

1
2
3
4
5
6
7
function fn(a) {
a++;
console.log(a);
}
var x = 10;
fn(x);
console.log(x);

复杂数据类型传参

​ 函数的形参也可以看做是一个变量,当我们把引用类型变量传给形参时,其实是把变量在栈空间里保存的堆地址复制给了形参,形参和实参其实保存的是同一个堆地址,所以操作的是同一个对象。

1
2
3
4
5
6
7
8
9
10
11
12
function Person(name) {
this.name = name;
}
function f1(x) { // x = p
console.log(x.name); // 2. 这个输出什么 ?
x.name = "张学友";
console.log(x.name); // 3. 这个输出什么 ?
}
var p = new Person("刘德华");
console.log(p.name); // 1. 这个输出什么 ?
f1(p);
console.log(p.name); // 4. 这个输出什么 ?