前端笔记之手写call

前言

大家好 我是歌谣 上节课我们已经说过了关于手写apply和手写call的讲解 这节课我们继续来进行手写bind的讲解

bind演示

xml 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>手写bind.html</title>
</head>
<body>
    <script>
         var geyao = {
            name: "geyao",
            show() {
                console.log(this, "this")
                console.log(` 我是${this.name}`)
            }
        }
        var fangfang = {
            name: "fangfang"
        }
        let fn=geyao.show.bind(fangfang)
        fn()
    </script>
</body>
</html>

运行结果

分析

核心的功能就是第一会改变this的指向 第二函数不会立刻执行

代码

javascript 复制代码
 var geyao = {
            name: "geyao",
            show() {
                console.log(this, "this")
                console.log(` 我是${this.name}`)
            }
        }
        var fangfang = {
            name: "fangfang"
        }
        Function.prototype.myBind = function (content, args) {
            
            let fn = Symbol('geyao')
            fn = this
            return function Fn() {
                // 这里arguments的作用是拿到Fn中传入的参数
                return fn.call(content, args)
            }
        }
        let fn = geyao.show.myBind(fangfang)
        fn()
      

运行结果

思考

这里还需要对new bind进行一个实现 不是上述所说的这么简单

ini 复制代码
  function geyao() {
            this.fangfang = 'fangfang';
        }
        var geyaoFoo = geyao.bind();
        var obj = new geyaoFoo();
        console.log(obj.fangfang); 

运行结果

最终代码

bash 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>手写bind2.html</title>
</head>
<body>
    <script>
        Function.prototype.myBind = function (context, ...args) {
            let geyao = Symbol('geyao')
            geyao = this
            return function Fangfang() {
                if (this instanceof Fangfang) {
                    return new geyao(...args, ...arguments)
                }
                return geyao.call(context, arguments)
            }
        }
        function geyao() {
            this.fangfang = 'fangfang';
        }
        var geyaoFoo = geyao.myBind();
        var obj = new geyaoFoo();
        console.log(obj.fangfang);
    </script>
</body>

</html>

运行结果

相关推荐
cxxcode19 分钟前
Vite 热更新(HMR)原理详解
前端
HelloReader29 分钟前
Tauri 架构从“WebView + Rust”到完整工具链与生态
前端
Bigger42 分钟前
告别版本焦虑:如何为 Hugo 项目定制专属构建环境
前端·架构·go
代码匠心2 小时前
AI 自动编程:一句话设计高颜值博客
前端·ai·ai编程·claude
_AaronWong4 小时前
Electron 实现仿豆包划词取词功能:从 AI 生成到落地踩坑记
前端·javascript·vue.js
cxxcode4 小时前
I/O 多路复用:从浏览器到 Linux 内核
前端
用户5433081441944 小时前
AI 时代,前端逆向的门槛已经低到离谱 — 以 Upwork 为例
前端
JarvanMo4 小时前
Flutter 版本的 material_ui 已经上架 pub.dev 啦!快来抢先体验吧。
前端
恋猫de小郭4 小时前
AI 可以让 WIFI 实现监控室内人体位置和姿态,无需摄像头?
前端·人工智能·ai编程
哀木4 小时前
给自己整一个 claude code,解锁编程新姿势
前端