5. 内置构造函数
在JavaScript中最主要的数据类型有6种:
-
基本数据类型:字符串、数值、布尔、undefined、null
-
引用类型:对象
字符串。数值、布尔等基本数据类型也都有专门的构造函数,称为包装类型
JS中几乎所有的数据都可以基于构成函数创建
引用类型 :
-
Object,Array,RegExp(正则),Date 等
包装类型 :
-
String,Number,Boolean 等
5.1 引用类型
5.1.1 Object
Object 是内置的构造函数,用于创建普通对象。
//通过构造函数创建普通对象
const user = new Object({name:'小明',age:15})
推荐使用字面量方式声明对象,而不是 Object 构造函数
静态方法只有构造函数Object可以调用
Object.keys:
-
作用:Object.keys静态方法获取对象中所有属性(键)
-
语法:
const o = {name: '佩奇',age: 6 }
// 获得对象的所有键,并且返回是一个数
const arr = Object.keys(o)
console.log(arr) //['name', 'age']
-
注意: 返回的是一个数组
Object.values:
-
作用:Object.values静态方法获取对象中所有属性值
-
语法:
const o = {name: '佩奇',age: 6 }
// 获得对象的所有值,并且返回是一个数组
const arr = Object.values(o)
console.log(arr) //['佩奇', '6']
-
注意: 返回的是一个数组
Object.assign:
-
作用:Object.assign静态方法常用于对象拷贝
-
使用场景:给对象添加属性
-
语法:
// 拷贝对象 把o 拷贝给obj
const o = {name: '佩奇',age: 6 }
const obj = {}
Object.assign(obj,o)
console.log(obj) //{name: '佩奇',age: 6 }
// 给o新增属性
const o = {name: '佩奇',age: 6 }
Object.assign(o, {gender: '女'})
console.log(o) //{name: '佩奇',age: 6, gender: '女'}
5.1.2 Array
Array 是内置的构造函数,用于创建数组
const arr = new Array(3,5)
console.log(arr) //[3,5]
创建数组建议使用字面量创建,不用 Array构造函数创建
-
常见实例方法
方法 | 作用 | 说明 |
---|---|---|
forEach | 遍历数组 | 不返回,用于不改变值,经常用于查找打印输出值 |
filter | 过滤数组 | 筛选数组元素,并生成新数组 |
map | 迭代数组 | 返回新数组,新数组里面的元素是处理之后的值,经常用于处理数据 |
reduce | 累计器 | 返回函数累计处理的结果,经常用于求和等 |
reduce
-
reduce 返回函数累计处理的结果,经常用于求和等
-
语法:
arr.reduce(function (累计值, 当前元素[,索引号][,原数组]) {}, 起始值)
-
参数:起始值可以省略,如果写就作为第一次累计的起始值
-
累计值参数:
-
如果有起始值,则以起始值为准开始累计, 累计值 = 起始值
-
如果没有起始值, 则累计值以数组的第一个数组元素作为起始值开始累计
-
后面每次遍历就会用后面的数组元素累计到
累计值
里面 (类似求和里面的 sum )
-
-
使用场景:求和运算:
const arr = [3,6,2,3,4,2]
const count = arr.reduce((prev, item)=> prev + item )
console.log(count);
其他方法
-
推荐使用字面量方式声明数组,而不是
Array
构造函数 -
实例方法
forEach
用于遍历数组,替代for
循环 (重点) -
实例方法
filter
过滤数组单元值,生成新数组(重点) -
实例方法
map
迭代原数组,生成新数组(重点) -
实例方法
join
数组元素拼接为字符串,返回字符串(重点) -
实例方法
find
查找元素, 返回符合测试条件的第一个数组元素值,如果没有符合条件的则返回 undefined(重点) -
实例方法
every
检测数组所有元素是否都符合指定条件,如果所有元素都通过检测返回 true,否则返回 false(重点) -
实例方法
some
检测数组中的元素是否满足指定条件 如果数组中有元素满足条件返回 true,否则返回 false -
实例方法
concat
合并两个数组,返回生成新数组 -
实例方法
sort
对原数组单元值排序 -
实例方法
splice
删除或替换原数组单元 -
实例方法
reverse
反转数组 -
实例方法
findIndex
查找元素的索引值
伪数组转换为真数组
-
静态方法: Array.from()
<ul>
<li>1</li>
<li>2</li>
<li>3</li>
</ul>
<script>
//伪数组转化为真数组
const lis = document.querySelectorAll('li')
let liss = Array.from(lis)
liss.pop()
console.log(liss) //[li, li]
</script>
5.2 包装类型
-
在 JavaScript 中的字符串、数值、布尔具有对象的使用特征,如具有属性和方法
<script>
// 字符串类型
const str = 'hello world!'
// 统计字符的长度(字符数量)
console.log(str.length)
// 数值类型
const price = 12.345
// 保留两位小数
price.toFixed(2) // 12.34
</script>
-
之所以具有对象特征的原因是字符串、数值、布尔类型数据是 JavaScript 底层使用 Object 构造函数“包装”来的,被 称为包装类型
5.2.1 String
String
是内置的构造函数,用于创建字符串。
<script>
// 使用构造函数创建字符串
let str = new String('hello world!');
// 字面量创建字符串
let str2 = '你好,世界!';
// 检测是否属于同一个构造函数
console.log(str.constructor === str2.constructor); // true
console.log(str instanceof String); // false
</script>
常见实例方法
-
实例属性
length
用来获取字符串的度长(重点) -
实例方法
split('分隔符')
用来将字符串拆分成数组(重点)
const str1 = '2022-8-14'
const arr1 = str1.split('-')
console.log(arr1) //['2022', '8', '14']
-
实例方法
substring(需要截取的第一个字符的索引[,结束的索引号])
用于字符串截取(重点)
// 2.字符串的截取 substring(开始的索引号,结束的索引号)
const str = '123456789'
console.log(str.substring(3)) //456789
-
实例方法
startsWith(检测字符串[, 检测位置索引号])
检测是否以某字符开头(重点)
// 3.startsWith 判断是不是以某个字符开头
const str = 'gjhkuycghvjhbk'
console.log(str.startsWith('gj')) //true
console.log(str.startsWith('as')) //false
-
实例方法
includes(搜索的字符串[, 检测位置索引号])
判断一个字符串是否包含在另一个字符串中,根据情况返回 true 或 false(重点) (区分大小写)
// 4.includes 判断是不是某个字符包含在一个字符串中
const str = 'bvkabv lan'
console.log(str.includes('lan')) //true
/script>
-
实例方法
toUpperCase
用于将字母转换成大写 -
实例方法
toLowerCase
用于将就转换成小写 -
实例方法
indexOf
检测是否包含某字符 -
实例方法
endsWith
检测是否以某字符结尾 -
实例方法
replace
用于替换字符串,支持正则匹配 -
实例方法
match
用于查找字符串,支持正则匹配
注:String 也可以当做普通函数使用,这时它的作用是强制转换成字符串数据类型。
5.1.4 Number
Number 是内置的构造函数,用于创建数值
常用方法:
toFixed() 设置保留小数位的长度
const price = 12.15233
//保留两位小数 四舍五入
console.log(price.toFixed(2)) //12.15
总结:
-
推荐使用字面量方式声明数值,而不是
Number
构造函数 -
实例方法
toFixed
用于设置保留小数位的长度
转化为字符串:
-
String()
-
num.toString()