js基础05_js类、原型对象、原型链&案例(解决无限debugger)

1、prototype

一般用来解决js中的类,用于添加方法

【注意】一般可以用如下来在js对象中添加方法,但是这个是有个严重的问题。比如创建其他类多了,那么就会导致,每次创建一个对象都要创建这个方法,如果有100甚至更多对象,那么创建更多的方法就会浪费内存

javascript 复制代码
// 问题:
// 1. 方法呢?
// 2. 类呢?
function Person(name, age){
    this.name = name;
    this.age = age;
    // 这样写是有很大问题的, 如果Person的方法有100个. 意味着, 每创建一个对象, 方法就要完全重新复刻一遍
    this.chi = function(){ // ?
        console.log(this.name, "在吃东西");
    }
}

所以引出概念prototype,这个就是js中的类,我们在类里面创建方法而不是对象

js继承:A继承自B

javascript 复制代码
// A.prototype.__proto__ = B.prototype
function.Animal(){
}
function.Cat(){}

Cat.prototype.__proto__ = Animal.prototype;

var c = new Cat();
c.chi()

为什么Function无法解决无限debugger的问题,如下图:

原因如下图

所以正确的改法如下:

javascript 复制代码
// // 用原型链可以解决无限debugger的逻辑
// // 用哪个, 改哪个
// Function.prototype.constructor = function(arg){
//     arg = arg.replaceAll("debugger;", "");
//     arg = arg.replaceAll("debugger", "");
//     return new Function(arg);
// }
相关推荐
山河木马1 小时前
渲染管线-计算得到gl_Position(顶点着色器)之后续GPU流程
javascript·webgl·图形学
竹林8181 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
kyriewen4 小时前
别再每次都 Google 了:我整理了前端日常最常踩的 10 个 Git 坑,附速查表
前端·javascript·git
SmartBoyW5 小时前
深入ECMAScript规范:彻底搞懂JS隐式类型转换与底层ToPrimitive机制
前端·javascript
用户852495071846 小时前
解密 JavaScript 中的 this:谁才是真正的调用者?
javascript·面试
Heo6 小时前
Vite进阶用法详解
前端·javascript·面试
铁皮饭盒7 小时前
Next.js 风格路由内置?Bun FileSystemRouter 凭啥这么香
javascript
小林ixn8 小时前
别再背八股了!从 5 个真实场景彻底搞懂 JavaScript 的 this
javascript
东风破_9 小时前
JavaScript 面试常考的字符串算法:从反转字符串到回文判断
前端·javascript
巴勒个啦9 小时前
D3.js 入门实战:用力导向图可视化项目依赖关系
javascript