web前端面试-- 手写原生Javascript方法(new、Object.create)

web面试题

本人是一个web前端开发工程师,主要是vue框架,整理了一些面试题,今后也会一直更新,有好题目的同学欢迎评论区分享 ;-)

web面试题专栏:点击此处


手动实现Object.create

通过Object.create,可以联想到之前讲的JS的7种继承方式之一 原型式继承

实现

js 复制代码
function myCreate(obj) {
    function Fn() { }
    Fn.prototype = obj;
    return new Fn();
}

测试

js 复制代码
var obj = { a: 1, b: 2 }
var obj1 = myCreate(obj)
console.log("obj1:", obj1);
console.log("obj1.a:", obj1.a);

var obj2 = Object.create(obj)
console.log("obj2:", obj2);
console.log("obj2.a:", obj2.a);

new操作符

  1. 新建一个空对象
  2. 将对象的原型__proto__ 指向Fn的prototype
  3. 运行构造函数,并且通过.call 修改函数的作用域,指向obj
  4. 返回构造函数生成的对象,如果不是对象,则返回obj

实现

js 复制代码
function myNew(Fn,...args){
	let obj = Object.create(null);
	obj.__proto__ = Fn.prototype;
	let result = Fn.call(obj,...args);
	return result instanceof Object ? result : obj;
}

测试

js 复制代码
function Fruits(name, price) {
	this.name = name;
	this.price = price;
	this.sayName = function () {
	  console.log(`我是水果:${this.name}`);
	};
	this.sayPrice = function () {
	  console.log(`${this.name}的价格:${this.price}...`);
	};
	return {
	  sayName: () => {
	    console.log(`我是水果:${this.name}`);
	  },
	  sayPrice: () => {
	    console.log(`${this.name}的价格:${this.price}...`);
	  },
	};
}

let banana = new Fruits("香蕉", 10);
banana.sayName();
banana.sayPrice();
console.log(banana);

function myNew(Fn, ...args) {
	let obj = Object.create(null);
	obj.__proto__ = Fn.prototype;
	let ret = Fn.call(obj, ...args);
	return ret instanceof Object ? ret : obj;
}

let banana2 = myNew(Fruits, "香蕉2号", 20);
banana2.sayName();
banana2.sayPrice();
console.log(banana2);

未完待续...

相关推荐
Passion不晚10 分钟前
Java 全栈开发中的最佳实践:从前端到后端的完整流程
java·前端·全栈
Moon里2 小时前
【CSS】字体文本
前端·css
Jonathan Star6 小时前
两个圆形 一个z里面一个z外面,z里面的大,颜色不同 html
前端·html
Pandaconda7 小时前
【计算机网络 - 基础问题】每日 3 题(二十七)
开发语言·经验分享·笔记·后端·计算机网络·面试·职场和发展
洛小豆7 小时前
前端开发必备:三种高效定位动态类名元素的 JavaScript 技巧
开发语言·前端·javascript·面试
Pandaconda7 小时前
【计算机网络 - 基础问题】每日 3 题(二十四)
开发语言·经验分享·笔记·后端·计算机网络·面试·职场和发展
啵一杯7 小时前
leetcode621. 任务调度器
服务器·前端·数据结构·算法·c#
2401_857297918 小时前
2025校招内推-招联金融
java·前端·算法·金融·求职招聘
媛媛要加油呀8 小时前
鸿蒙面试题库收集(一):ArkTS&ArkUI-基础理论
华为·面试·职场和发展·harmonyos
琴~~9 小时前
前端全屏模式切换
前端·javascript