目录

前端笔记之手写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>

运行结果

本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
uhakadotcom2 小时前
归因工具:了解国内外顶级产品
算法·面试·github
百万蹄蹄向前冲3 小时前
三句话四分钟,豆包出题把吾秀
前端·人工智能·豆包marscode
半旧5183 小时前
重构谷粒商城11:node快速入门
java·前端·重构
菜鸟起航ing4 小时前
【Java面试系列】Spring Boot中自动配置原理与自定义Starter开发实践详解 - 3-5年Java开发必备知识
java·spring boot·面试·自动配置·自定义starter
uhakadotcom4 小时前
了解Dapr:构建分布式应用的强大工具
后端·面试·github
前端.火鸡4 小时前
认识vue中的install和使用场景
前端·javascript·vue.js
uhakadotcom4 小时前
Kibana:数据分析和可视化的强大工具
后端·面试·github
摆烂工程师4 小时前
Grok3 支持 DeeperSearch 的免费可用次数的查询了
前端·后端·程序员
pubuzhixing4 小时前
在线白板 - 如何从零实现一个自由画笔
前端·开源
uhakadotcom4 小时前
Grafana:数据可视化和监控平台的强大工具
后端·面试·github