【JavaScript】内置对象及常用方法

本文详细介绍了JavaScript的内置对象,包括Object、Boolean、Array、String、Number、Math、Date、RegExp、Json、Error和Function。讨论了深拷贝与浅拷贝的区别,提供了深拷贝的实现方式,并探讨了各种对象的方法,如Object.keys()、Object.values()、Array的遍历方法、字符串方法、数字方法和日期处理方法。此外,还涉及到了AJAX的基础概念。
摘要由CSDN通过智能技术生成

JavaScript 内置对象及常用方法

一、Object

Object 构造函数创建一个对象包装器。

几乎所有的对象都是Object类型的实例,它们都会从Object.prototype继承属性和方法。Object构造函数,会根据给定的参数创建对象:

  • 创建的对象是一个空对象,在该对象上没有继承 Object.prototype 原型链上的属性或者方法

    Object.create(null) // {}   No properties
    
  • 如果给定值是 null 或 undefined,将会创建并返回一个空对象,该对象继承Object.prototype 原型链上的属性或者方法

    new Object(null) // {}   [[prototype]]: Object
    
  • 如果传进去的是一个原始类型的值,则会构造其包装类型的对象

    new Object(2) // {2}
    
  • 如果传进去的是引用类型的值,仍然会返回这个值,经他们复制的变量保有和源对象相同的引用地址

    new Object([1, 2]) // [1, 2]
    

具有Object类型的实例方法:

  • toString()

    返回当前对象的字符串形式,返回值为String类型

    var a = [1,'2',true].toString();
    console.log('a: ', a); // '1,2,true'
    
    var b = (new Date()).toString();
    console.log('b: ', b); // 'Tue Oct 20 2020 13:35:05 GMT+0800 (China Standard Time)'
    
    var c = ({
         name: 'hai'}).toString();
    console.log('c: ', c); // '[object Object]'
    
    var fuc = function () {
         
        console.log('123')
    }
    var d = fuc.toString();
    console.log('d: ', d); // "function () {console.log('123')}"
    
  • toLocaleString

    返回当前对象的"本地化"字符串形式,以便于当前环境的用户辨识和使用,返回值为String类型

    (1234567).toLocaleString(); // "1,234,567"
    (1.234567).toLocaleString(); // "1.235"
    (new Date()).toLocaleString(); // "2020/10/20 下午1:40:08"
    
  • valueOf()

    返回指定对象的原始值

    Array:返回数组对象本身
    Date:返回时间戳

    new Date(2013, 7, 18, 23, 11, 59, 230).valueOf() // 1376838719230
    

    Number:返回数字值
    Boolean:返回布尔值true或false
    Function:返回函数本身
    Object:返回对象本身
    String:返回字符串值

Object 构造函数的方法:

  • Object.assign(target, …sources)

    • 复制一个对象

      const obj = {
              a: 1 };
      const copy = Object.assign({
             }, obj);
      console.log(copy); // { a: 1 }
      

      对于深拷贝的问题:
      Object.assign()拷贝的是(可枚举)属性值。

      const v1 = "abc";
      const v2 = true;
      const v3 = 10;
      const v4 = Symbol("foo")
      
      const obj = Object.assign({
             }, v1, null, v2, undefined, v3, v4); 
      // 原始类型会被包装,null 和 undefined 会被忽略。
      // 注意,只有字符串的包装对象才可能有自身可枚举属性。
      console.log(obj); // { "0": "a", "1": "b", "2": "c" }
      

      如果属性值为简单类型(如string, number),得到的新对象为深拷贝。
      如果属性值为对象或其它引用类型,得到的新对象为浅拷贝。

      let obj1 = {
              a: 0 , b: {
              c: 0}};
      let obj2 = Object.assign({
             }, obj1);
      console.log('obj2: ', obj2); // obj2:  { a: 0, b: { c: 0 } }
      
      obj2.a = 1;
      console.log('obj1: ', obj1); // obj1:  { a: 0, b: { c: 0 } }
      console.log('obj2: ', obj2); // obj2:  { a: 1, b: { c: 0 } }
      
      obj2.b.c = 2;
      console.log('obj1: ', obj1); // obj1:  { a: 0, b: { c: 2 } }
      console.log('obj2: ', obj2); // obj2:  { a: 1, b: { c: 2 } }
      

      谈一谈你对深拷贝和浅拷贝的理解。

      数据分为基本数据类型和引用数据类型。深拷贝和浅拷贝只是针对引用数据类型的操作。

      • 浅拷贝只复制指向某个对象的指针,而不复制对象本身,新旧对象还是共享同一块内存。
      • 深拷贝会另外创造一个一模一样的对象,新对象跟原对象不共享内存,修改新对象不会改到原对象。

      手写一个深拷贝:递归实现深拷贝

      // 标准深拷贝
      function deepClone(source) {
             
          // [] => Array {} => Object
          const targetObj = source.constructor === Array ? [] : {
             }
          for (let key in source) {
             
              if(Object.hasOwnProperty.call(source, key)) {
             
                  if(source[key] && typeof source[key] === 'object') {
             
                      // 引用数据类型,递归
                      targetObj[key] = deepClone(source[key])
                  } else {
             
                      // 基本数据类型,直接赋值
                      targetObj[key] = source[key]
                  }
              }
          }
          return targetObj
      }
      
    • 合并对象
      目标对象自身也会改变;
      对象中的属性具有相同的键,后面的源对象的属性将类似地覆盖前面的源对象的属性。

      const o1 = {
              a: 1 };
      const o2 = {
              b: 2 };
      const o3 = 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Komorebi゛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值