重温javascript --(三)对象

2024-04-26 15:28
文章标签 java script 对象 重温

本文主要是介绍重温javascript --(三)对象,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

对象

一. 对象创建

1. var a = {} 字面量创建

2. 构造函数

  1. 系统构造函数Object()var per = new Object()

  2. 自定义构造函数

     function Person(name){this.name = name,this.age = 18}var person = new Person('limei')
    

    new 关键字 会在构造函数内部:

    1. 隐性创建 var this ={};
    2. 赋值this.xxx = xxx;
    3. 最后隐性返回 return this;
  3. Object.create()方法:

Object.create(proto, [propertiesObject])

  • proto:必需。新创建的对象的 __proto__
  • propertiesObject:可选。如果该参数是一个对象,那么其自有可枚举属性(即那些自有属性且其 enumerabletrue 的属性)的键值对会被添加到新创建对象的对应属性上,作为新创建对象的自有属性。这些属性的描述符由 propertiesObject 中对应属性的值提供。

示例:

// 1.
const obj = Object.create(null) // obj 为 {}
console.log(emptyObject.__proto__); // 输出:undefined// 2.
const person = {sex: '男',say: function () {console.log(`${this.name}说:我今年${this.age}了,我的性别是:${this.sex}`)}
}
const xiaoMing = Object.create(person, {// 定义一个数据描述符  age: {  value: 19,  writable: true,  enumerable: true,  configurable: true  },// 定义一个访问器描述符  look: {  get: function() {  return 'Hello, ' + this.name;  },  enumerable: true,  configurable: true  } 
})
// 输出
xiaoMing.name = "小明"
xiaoMing.sex = "女"
xiaoMing.say() // 小明说:我今年19了,我的性别是:女
xiaoMing.look // 'Hello, 小明'

3. 属性引用

对象属性可以通过两种主要方式访问:点符号(.)和方括号([]

// 1. 点符号(.)
let obj = {  name: 'Alice',  age: 30,'my-prop': '自定义的属性' 
};  console.log(obj.name); // 输出 'Alice'  
console.log(obj.age);  // 输出 30// 2. 方括号([])
console.log(obj['age']) // 输出30let propName = 'name';  
console.log(obj[propName]); // 输出 'Alice'  console.log(obj['my-prop']) // 输出 自定义的属性

二. 原型(prototype

  1. obj.prototype 对象的原型(每个函数对象才会拥有prototype
    prototype是函数对象的一个属性,它定义了构造函数制造出的对象的公共祖先,通过该构造函数产生的对象,可以继承改原型的属性和方法,原型也是对象。
  2. __proto__
    • 每个对象都有__proto__属性,去访问自己的原型
    • 大多数对象最后的原型都会指向Object.prototype

    var obj = Object.create(null); // obj无原型,无__proto__,无constructor

    1. var obj = {};obj.__proto__ = Object.prototype;2. Person.prototype.name = '构造函数Person的原型'function Person(){};var person = new Person();person.name; // 访问先查看自身属性,没有去其原型上查找person.__proto__  ------>  Person.prototype
    
  3. 每个原型对象都会自动获得一个constructor属性,这个属性指向创建它的构造函数。

    这样做的目的是为了在原型链上能够正确地追踪到实例的构造函数。
    通常,当你定义一个构造函数并创建它的实例时,这个实例的constructor属性会指向该构造函数。

    function Person(name, age) {  this.name = name;  this.age = age;  
    }  // 构造函数上prototype的constructor指向自己 
    console.log(Person.prototype.constructor === Person); // 输出: true  // 创建一个Person实例  
    let person = new Person('Alice', 30);  // 检查person的constructor属性  
    console.log(person.constructor === Person); // 输出: true  
    console.log(person.constructor.name); // 输出: "Person"
    
  4. Object.create(proto, [propertiesObject]) 建一个新对象,使用现有的对象来提供新创建的对象的__proto__
  5. call, apply 改变this指向,

callapply的主要区别在于它们如何接收参数:
call接受一个参数列表,而apply接受一个参数数组。
这两个方法都允许你改变函数内部的this上下文,这在处理回调函数、对象方法以及继承等场景中非常有用

// 1. call
function Car(age, sex){this.name = '小刘',this.age = age,this.sex = sex
};
var obj = {};
Car.call(obj,112, '男'); // 将Car内this的指向指向 obj// 2. apply
function Car(age, sex){this.name = '小刘',this.age = age,this.sex = sex
};
var obj = {};
Car.apply(obj,[112, '女']);

三. 继承、命名空间、对象枚举

  1. 继承
    <div id="inherit"></div>

    // 继承方法
    var inherit = (function(){var F = function (){}; // 闭包私有化变量,不属于对象,和对象同属于同一个AO对象return function(Target,Origin){F.prototype = Origin.prototype;Target.prototype = new F();Target.prototype.constructor = Target;Target.prototype.uber = Origin.prototype;}
    }());function Car(name){this.name = name
    };
    Car.prototype.whool = 4;function BaoMa(){}inherit(BaoMa,Car);BaoMa.prototype.age = '百年历史';
    var baoma = new BaoMa();
    
  2. 命名空间

    // 1.
    var obj = {eat:{li:{name: '小李定义的eat'},zhang:{name: '小张定义的eat'}},drink:{li:{name:'小李定义的drink'}},};<!-- 调用 -->var li = obj.eat.li;li.name// 2. 利用闭包实现,不污染全局变量var name = '全局name变量';
    var init = (function (){var name = '函数内部name变量';function say(){console.log(name);}return function(){say()}
    }());
  3. 对象枚举

    1. for...in语句用于遍历一个对象的可枚举属性(包括自有属性和继承自原型链的属性)。它会枚举对象的每一个可枚举属性,并为每个属性执行一次循环体。
    var obj = {name:'小刘',age: 18,sex: 'male',wife: '小宋',__proto__:{lastName:'Deng'}
    }
    Object.prototype.abc = 123;
    for(var prop in obj){console.log(`${prop} -- ${obj[prop]}`)
    }
    
    1. hasOwnProperty是一个方法,用于检查一个对象自身(不包括其原型链)是否具有指定的属性
    // 上例 obj
    for(var prop in obj){if(obj.hasOwnProperty(prop)){console.log(`${prop} -- ${obj[prop]}`)}
    }
    
    1. in 运算符用于检查对象自身及其原型链中是否存在某个属性。它会返回一个布尔值,如果对象或其原型链上有一个名为给定字符串的属性,则返回 true;否则返回false
    // 上例 obj
    console.log('name' in obj) // true
    console.log('abc' in obj) // true
    
    1. instanceof是一个运算符,用于测试构造函数的 prototype 属性是否出现在对象的原型链中的任何位置。换句话说,它用来判断一个对象是否是一个构造函数的实例
    // 区分数组[]和对象{}
    //  typeof([]); ---> object 
    //  typeof({}); ---> object
    var arr = [];
    var obj = {};
    // 1. instanceof 方法
    arr instanceof Array;  // true
    obj instanceof Array;  // false
    arr instanceof Object;  // true
    obj instanceof Object;  // true
    // 2. constructor 
    arr.constructor // function Array
    obj.constructor // function Object
    // 3. call toString
    Object.prototype.toString.call([]); // '[object Array]'
    Object.prototype.toString.call({}); // '[object Object]'
    

四、 this

  1. 函数预编译过程 this 指向window
  2. 全局作用域里 this指向window
  3. call/apply: 改变函数运行时 this指向
  4. obj.func()func()里的this 指向obj(谁调用指向谁)

五、arguments 函数实参的类数组对象(use strict严格模式下禁用)

  1. arguments.length 对象长度
  2. arguments.callee 指向函数自身引用
  3. func.caller 函数的属性,函数被谁调用,返回谁
// 'use strict' // 严格模式下禁用
var num = (function (n) {if (n === 1) {return 1}return n * arguments.callee(n - 1)
}(5))
num // 120function demo() {test();
}
function test() {console.log(test.caller);
}
demo();

这篇关于重温javascript --(三)对象的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/937953

相关文章

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

spring中的ImportSelector接口示例详解

《spring中的ImportSelector接口示例详解》Spring的ImportSelector接口用于动态选择配置类,实现条件化和模块化配置,关键方法selectImports根据注解信息返回... 目录一、核心作用二、关键方法三、扩展功能四、使用示例五、工作原理六、应用场景七、自定义实现Impor

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.