js进阶——this和对象原型

1. this 在 JavaScript 中的应用

在 JavaScript 中,this 的值取决于函数的执行上下文和调用方式。以下是 this 在不同上下文中的行为解释:

A. 全局上下文(非严格模式)

在全局执行上下文中,this 指向全局对象(在浏览器中是 window 对象,在 Node.js 中是 global 对象)。

console.log(this); // 在浏览器中,this 指向 window 对象
B. 函数上下文

函数内部的 this 取决于函数的调用方式:

  1. 作为对象的方法调用
    当函数作为对象的方法被调用时,this 指向调用该方法的对象。

    const obj = {name: 'Alice',greet() {console.log(this.name);}
    };
    obj.greet(); // 输出 'Alice', 因为 this 指向 obj
    
  2. 作为普通函数调用
    在非严格模式下,普通函数调用中的 this 指向全局对象(浏览器中为 window),而在严格模式下,thisundefined

    function showName() {console.log(this.name);
    }// 非严格模式下
    showName(); // this 指向 window,可能会输出 undefined// 严格模式下
    'use strict';
    showName(); // this 是 undefined,调用会抛出错误
    
  3. 构造函数调用
    当使用 new 关键字调用构造函数时,this 指向新创建的对象。

    function Person(name) {this.name = name;
    }const person = new Person('Bob');
    console.log(person.name); // 输出 'Bob', this 指向新对象 person
    
  4. 箭头函数中的 this
    箭头函数不绑定自己的 this,它会捕获上下文中最近的 this 值。箭头函数常用于避免 this 在不同上下文中变化。

    const obj = {name: 'Carol',greet: function() {const innerFunc = () => {console.log(this.name); // this 来自 obj 上下文};innerFunc();}
    };obj.greet(); // 输出 'Carol'
    
C. callapplybind

这三个方法可以显式地绑定 this,并控制函数中的 this 值。

  1. call
    使用 call 可以显式指定 this,并立即调用函数。

    function greet() {console.log(this.name);
    }const person = { name: 'David' };
    greet.call(person); // 输出 'David'
    
  2. apply
    applycall 类似,但它接受的是数组作为参数。

    function introduce(age, country) {console.log(`${this.name}, ${age}, from ${country}`);
    }const person = { name: 'Eva' };
    introduce.apply(person, [25, 'USA']); // 输出 'Eva, 25, from USA'
    
  3. bind
    bind 会返回一个新函数,this 永远绑定到指定的值。

    const person = { name: 'Frank' };
    const boundFunc = greet.bind(person);
    boundFunc(); // 输出 'Frank'
    

2. 对象原型(Prototype)

JavaScript 中的原型机制是对象之间继承的核心。每个 JavaScript 对象都有一个与之相关联的原型对象(prototype),通过它可以实现属性和方法的继承。

A. 原型链

每个对象都有一个内部属性 [[Prototype]](可以通过 __proto__ 访问)。如果在对象上找不到某个属性,JavaScript 会沿着原型链向上查找,直到找到该属性或到达原型链的顶端(null)。

const animal = {speak() {console.log('Animal sound');}
};const dog = {bark() {console.log('Woof!');}
};// 将 dog 的原型设为 animal
dog.__proto__ = animal;dog.bark(); // 输出 'Woof!'
dog.speak(); // 输出 'Animal sound', 来自 animal 的原型
B. 构造函数与原型

当通过构造函数创建对象时,构造函数的 prototype 属性会成为新对象的原型。

function Person(name) {this.name = name;
}Person.prototype.greet = function() {console.log(`Hello, my name is ${this.name}`);
};const john = new Person('John');
john.greet(); // 输出 'Hello, my name is John'
C. Object.create()

Object.create() 是一个常用方法,可以创建一个新对象,并将其原型设置为指定的对象。

const parent = {speak() {console.log('I am parent');}
};const child = Object.create(parent);
child.speak(); // 输出 'I am parent', child 继承了 parent 的方法
D. 原型链继承的缺陷

由于 JavaScript 中的对象共享同一原型,当修改原型对象的属性时,所有继承该原型的对象都会受到影响。

function Animal() {}Animal.prototype.legs = 4;const dog = new Animal();
const cat = new Animal();dog.legs = 3; // 修改实例属性
console.log(cat.legs); // 输出 4,cat 的 legs 没有受到影响Animal.prototype.legs = 2; // 修改原型属性
console.log(dog.legs); // 输出 3,实例属性优先
console.log(cat.legs); // 输出 2,受原型修改影响

总结

  • this 是 JavaScript 中一个强大但有时难以理解的机制,其值取决于函数调用的方式。
  • 原型机制和原型链是 JavaScript 中对象继承的基础,构成了对象与函数的继承关系。

深入理解 this 和对象原型可以帮助你更好地掌握 JavaScript 的复杂机制,在构建复杂应用程序时写出更清晰、可维护的代码。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1542505.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

Windows下 批量重命名文件【bat实现】-两个小问题

Windows下 批量重命名文件【bat实现】_bat批量重命名文件ren-CSDN博客 上面是原来的教程,我遇到了两个小问题,问题及解决如下: ①dir/b>rename.csv : 无法将“dir/b>rename.csv”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。…

【每天学个新注解】Day 2 Lombok注解简解(一)—@Data、@Build、@Value

Data 相当于同时使用了 Getter 、Setter 、RequiredArgsConstructor、ToString、EqualsAndHashCode 1、如何使用 需要同时使用Getter 、Setter 、RequiredArgsConstructor、ToString、EqualsAndHashCode注解一个Bean的时候。 2、代码示例 例: Data public cla…

CCC SPAKE2+流程解析

1、SPAKE2流程及SCP03通道介绍 SPAKE2流程发生在CCC车主配对过程中的Phase2。 SPAKE2流程为车辆和手机之间的数据交换建立了一个安全通道SCP03。 那这个SCP03通道是干啥的? 我们可以先简单的理解为:建立安全通道前,车辆和手机之间交互的AP…

剖解反转链表

剖解反转链表 思路: 1.若链表为空或者只存在一个节点,就无需反转,直接返回head 2.若存在多个节点 首先将head.next给到cur,并将head.next置为null 剩余的节点就利用头插法,反转链表 class Solution {public ListNo…

基于SpringBoot+Vue+MySQL的特色旅游网站系统

系统展示 用户前台界面 管理员后台界面 系统背景 随着旅游业的蓬勃发展,人们对旅游体验的需求日益多样化与个性化。传统的旅游信息查询与预订方式已难以满足现代游客的需求。因此,我们开发了这款基于SpringBootVueMySQL的特色旅游网站系统。该系统旨在通…

MySQL高阶1917-Leetcodify好友推荐

目录 题目 准备数据 分析数据 总结 题目 为 Leetcodify 用户推荐好友。我们将符合下列条件的用户 x 推荐给用户 y : 用户 x 和 y 不是好友,且用户 x 和 y 在同一天收听了相同的三首或更多不同歌曲。 注意,好友推荐是单向的&#xff0c…

web前端字段大小写下划线转换工具

文章目录 前言一、如何使用?二、相关代码总结 前言 程序员在敲代码的过程中都要命名一些字段,但是Java语言对字段的命名规范和sql命名规范不一样,如下图所示,这种机械性的转换工作很劳神费力,为了省点劲写了一个web小…

pdf怎么编辑修改内容?试试这四款工具!

作为一个经常探索各种办公软件的人,今天我打算和大家聊聊一个我们工作中经常会遇到的问题——编辑PDF文件。我们都知道,PDF文件以其格式稳定、不易被篡改而受到青睐,但这也意味着一旦需要修改内容,就变得相当棘手。不过&#xff0…

设计模式之类结构模式例题

答案:B A 知识点: 设计模式中类结构模式分别是:工厂方法模式,适配器模式,模板方法模式,解释器模式 记忆方法:公司里有个模特小姐姐,公是工厂模式,司是适配器模式&…

Mapper代理

文章目录 Mapper代理路径一定要写对Mapper代理方式加载配置文件 (包扫描的方式) Mapper代理 好像就是能 包名.方法。 反正就是防止硬编码,更灵活,更适用。 路径一定要写对 Mapper代理方式加载配置文件 (包扫描的方式…

fiddler抓包08_抓Android手机请求

课程大纲 手机抓包,电脑端的设置和IOS端相同,设置一次即可,无需重复设置。 前提:电脑和手机连接同一个局域网 土小帽电脑和手机都连了自己的无线网“tuxiaomao”。 Step1. 电脑端设置 ① 打开Fiddler - 开启抓包(F12…

Windows下如何定时执行自定义任务

目录 一.前言二.设置定时自动执行自定义任务 一.前言 本文环境是Windows11系统。 有时候我们希望能够在Windows下定时自动执行自定义任务,比如检测数据库服务的状态。那在Windows下怎么定时自动执行自定义任务,这篇文章介绍一种方法。 二.设置定时自动…

计算机毕业设计推荐-基于python的电子图书阅读推荐平台【源码+文档+讲解】

💖🔥作者主页:毕设木哥 精彩专栏推荐订阅:在 下方专栏👇🏻👇🏻👇🏻👇🏻 实战项目 文章目录 实战项目 一、基于python的电子图书阅读推…

吴津雨银洁刘雅雯获得国际超模大赛四川总决赛网络组三甲

9月8日众人期盼已久的都江堰杯2024国际超模大赛四川总决赛在三遗之城都江堰落下帷幕。国际超模大赛已经举办第12个年头,每年为时尚界、模特界输送无数的优秀时尚模特人才,让世界超模中出现更多的中国面孔。大赛在全球已经布局多个国家及地区,…

项目第七弹:消费者管理模块

项目第七弹:消费者管理模块 一、为何要有这个模块?二、消费者是否需要持久化?三、怎么设计?1.如何抽象描述?1.回想一下基于生产消费模型的线程池2.如何组织3.消息处理与确认问题的解决4.自动确认标志5.消费者代码 2.队…

【计算机组成原理】主存储器深度解析

📢博客主页:https://blog.csdn.net/2301_779549673 📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正! 📢本文由 JohnKi 原创,首发于 CSDN🙉 📢未来很长&#…

DETR论文翻译与理解

DETR(Detection with transformer) DETR:End to End Object Detection with Transformer 论文链接:2005.12872 (arxiv.org) 参考视频:https://www.bilibili.com/video/BV1GB4y1X72R/?spm_id_from333.788&vd_…

JBoss反序列化漏洞CVE-2017-12149

1.环境搭建 cd vulhub-master/jboss/CVE-2017-12149 docker-compose up -d 2.访问漏洞地址 3.漏洞验证 http://47.121.211.205:8080/invoker/readonly 返回500说明漏洞存在 4.使用漏洞进行利用 直接执行命令

人脸识别换装技术实现记录-1

最近,研究了下人脸识别换装,确定了技术方案和技术路线,并最终实现了想要达成的效果,现将制作过程中遇到的问题以及实现的过程记录下来,以便回顾总结的同时,也和其他想实现人脸识别换装的同学分享下经验,避免踩坑。 本项目主要是在Android系统上实现人脸换装的效…

简单图解一下线性注意力机制

知乎:刀刀宁链接:https://zhuanlan.zhihu.com/p/718156896 线性注意力机制的文章有很多了,在本篇笔记中,我们简单地对各种方法进行一下图解比较,串一下当前的线性注意力机制,涉及的公式极少,主要…