【修订中】js 中apply call bind 用法

一、call、apply可以翻译成继承或者借调 区别:传参不同

  • 可以调用函数
  • 可以改变函数中this的指向

二、js 语法词法:

  • 普通函数

构造函数:

  • 为什么不在构造函数中写方法

    function Student(n, a) {
    this.uname = n;
    this.age = a;
    this.sayHi = function () {
    console.log('大家好', this.uname);
    }
    }

    // sayHi = function () {
    // console.log('大家好', this.uname);
    // }
    // // 二.在原型中定义方法
    // Student.prototype.sayHi = function () {
    // console.log('大家好');

    // 三.实例化对象
    var stu = new Student('xiaoming', 20);
    var stu1 = new Student('xiaomei', 18);

    // console.log(stu.sayHi)
    // console.log(sayHi())
    // 四.测试
    console.log(stu.sayHi === stu1.sayHi); false

只要new 一次 就会新开一个新的空间地址 如果有1万个 就会开1万个空间地址,就会浪费地址资源,所以不在构造函数中写方法,那如何解决这个问题呢 就是使用原型对象解决

解决方法是(也不支持):这样写虽然显示true 但是作为普通函数就会出现undeinfd

复制代码
function Student(n, a) {
    this.uname = n;
    this.age = a;
    this.sayHi = sayHi
}

sayHi = function () {
    console.log('大家好', this.uname);
}
// // 二.在原型中定义方法
// Student.prototype.sayHi = function () {
//     console.log('大家好');

// 三.实例化对象
var stu = new Student('xiaoming', 20);
var stu1 = new Student('xiaomei', 18);

stu.sayHi()
sayHi()   //如果拿普通方法去调用的时候 就会出现大家好 undefind 
// 四.测试
console.log(stu.sayHi === stu1.sayHi); true
所以针对上面这些问题的想法 共享方法就是从原型对象上处理

原型对象

实例对象

原型模式:方法共享

构造函数与原型对象的关系 函数一定有一个prototype 实例对象(对象)一定有_proto_ 他俩是相等的

实例对象与原型对象的关系

在构造函数中定义属性

在原型中定义方法

只要是引用类型都存在__proto__ 属性 哪些是引用类型?对象 数组 函数

只要是函数类型都存在 prototype

函数的__proto__指向的是什么?

函数的prototype 指向的是什么?

相关推荐
Adellle2 天前
5. 原型模式
原型模式
乐悠小码4 天前
Java设计模式精讲---04原型模式
java·设计模式·原型模式
火鸟27 天前
给予虚拟成像台尝鲜版十,完善支持HTML原型模式
原型模式·通用代码生成器·给予虚拟成像台·给予·html原型模式·快速原型·rust语言
乙己4078 天前
设计模式——原型模式(prototype)
设计模式·原型模式
仙人掌_lz9 天前
Multi-Agent的编排模式总结/ Parlant和LangGraph差异对比
人工智能·ai·llm·原型模式·rag·智能体
午安~婉11 天前
javaScript八股问题
开发语言·javascript·原型模式
火鸟213 天前
给予虚拟成像台尝鲜版九,支持 HTML 原型模式
html·原型模式·通用代码生成器·给予虚拟成像台·给予·html原型模式·快速原型
数据知道14 天前
Go语言设计模式:原型模式详解
设计模式·golang·原型模式
JS.Huang14 天前
【JavaScript】构造函数与 new 运算符
开发语言·javascript·原型模式
Yeniden15 天前
设计模式>原型模式大白话讲解:就像复印机,拿个原件一复印,就得到一模一样的新东西
java·设计模式·原型模式·1024程序员节