javascript-es6 (五)

内置构造函数

在 JavaScript 中 最主要 的数据类型有 6 种:
基本数据类型:
字符串、数值、布尔、undefined、null
引用类型:
对象
但是,我们会发现有些特殊情况:

javascript 复制代码
//普通字符串
const str = 'peiqi'
console.log(str.length)  //5
//出现这种情况的原因:在js底层中,将一些 简单的数据类型 包装成了 引用数据类型 
const str = new String('peiqi') 

其实字符串、数值、布尔、等基本类型也都有专门的构造函数,这些我们称为包装类型。
JS中几乎所有的数据都可以基于构成函数创建
引用类型
Object,Array,RegExp,Date 等
包装类型
String,Number,Boolean 等

Object

Object 是内置的构造函数,用于创建普通对象

​​
学习三个常用静态方法(静态方法就是只有构造函数Object可以调用的)

javascript 复制代码
//需求:要想获取对象里面的属性和值,该怎么做?
const peiqi = {name:'佩奇',age:18}

//传统方法:
for(let k in peiqi){
    console.log(k)  //name age
    console.log(peiqi[k])  //佩奇 18
}

Object.keys 静态方法获取对象中所有属性(键)

javascript 复制代码
const peiqi = {name:'佩奇',age:18}
//获得对象的所有键,并且返回的是一个数组
const arr = Object.keys(peiqi)
console.log(arr)  //['name','age']

注意: 返回的是一个数组
Object.values 静态方法获取对象中所有属性值

javascript 复制代码
const peiqi = {name:'佩奇',age:18}
//获得对象的所有属性值,并且返回的也是一个数组
const arr = Object.values(peiqi)
console.log(arr)   //['佩奇',18]

注意: 返回的也是一个数组

Object. assign 静态方法常用于对象拷贝

javascript 复制代码
//拷贝对象 把 peiqi 拷贝给 obj
const peiqi = {name:'佩奇',age:18}
const obj = {}
Object.assign(obj,peiqi)
console.log(obj)  //{name:'佩奇',age:18}

经常使用的场景是:给对象添加属性

javascript 复制代码
//给 peiqi 新增属性
const peiqi = {name:'佩奇',age:18}
Object.assign(peiqi,{gender:'女'})
console.log(peiqi)  //{name:'佩奇',age:18,gender:'女'}

Array

Array 是内置的构造函数,用于创建数组
1. 数组常见实例方法 - 核心方法

作用: reduce 返回函数累计处理的结果,经常用于求和等
基本语法:

javascript 复制代码
//arr.reduce(function(上一次值,当前值){}, 初始值)
const arr = [1,2,3]

//1.没有初始值
const total = arr.reduce((prev,current) {
    return prev + current
})
console.log(total)  //6

//2.有初始值
const total = arr.reduce((prev,current) {
    return prev + current
},10)
console.log(total)  //16

累计值参数:

  1. 如果有起始值,则以起始值为准开始累计, 累计值 = 起始值
  2. 如果没有起始值, 则累计值以数组的第一个数组元素作为起始值开始累计 {如果第一个数组元素是对象 ,则必须要设置初始值}
  3. 后面每次遍历就会用后面的数组元素 累计到 累计值 里面 (类似求和里面的 sum )

2. 数组常见方法-其他方法
实例方法 find() 查找元素,返回符合测试条件的第一个数组元素值,如果没有符合条件的则返回underfined(重点)

javascript 复制代码
const arr = ['red', 'blue', 'green']

    const re = arr.find((item) => {
        return item === 'blue'
})
    console.log(re);

应用:

javascript 复制代码
const arr = [
    {name:'苹果',price:12},
    {name:'香蕉',price:18}
]
//找苹果这个对象,并且返回这个对象
const apple = arr.find(function(item){
    return item.name === '苹果'
})
console.log(apple) /*{name:'苹果',price:12}*/

实例方法 every() 测试一个数组内的所有元素是否都能通过某个指定函数的测试。它返回一个布尔值

javascript 复制代码
const arr = [1, 2, 3, 4]
    const re = arr.every((item) => {
    return item > 2
})
    console.log(re)  //false

实例方法 some() 检测数组中的元素是否满足指定条件,如果数组中有元素满足条件返回true,否则返回false

相关推荐
裴嘉靖5 分钟前
uniapp做的APP和安卓苹果做的什么区别
前端
申阳7 分钟前
Day 20:开源个人项目时的一些注意事项
前端·后端·程序员
天蓝色的鱼鱼13 分钟前
大文件上传实战:基于Express、分片、Web Worker与压缩的完整方案
前端·node.js
500佰16 分钟前
解读NotebookLM基于AI的PTT生成 程序化处理方法
前端·google·程序员
前端老宋Running16 分钟前
别再给组件“打洞”了:这才是 React 组件复用的正确打开方式
前端·javascript·前端框架
u***284716 分钟前
Spring Boot项目接收前端参数的11种方式
前端·spring boot·后端
chilavert31819 分钟前
技术演进中的开发沉思-224 Ajax面向对象与框架
javascript·okhttp
pcm12356720 分钟前
java中用哈希表写题碰到的误区
java·前端·散列表
盗德24 分钟前
最全音频处理WaveSurferjs配置文档二(事件)
前端·javascript
恋猫de小郭29 分钟前
解读 Claude 对开发者的影响:AI 如何在 Anthropic 改变工作?
android·前端·ai编程