【js基础】函数柯里化

1. 函数柯里化

1.函数柯里化: 一个currying函数首先会接受一些参数,接受了这些参数之后,该函数并不会立即求值,而是继续返回另外一个函数,刚才传入的参数在函数形成的闭包中被保存起来。待到函数被真正需要求值的时候,之前传入的所有参数都会被一次性用于求值。
2. 例子1:

function uri_curring (protocol) {
    return function (hostname, pathname) {
        return `${protocol}${hostname}${pathname}`
    }
}

const uri_https = uri_curring('https:// ')

let uri1 = uri_https('www.csdn.com', '/关注')
let uri2 = uri_https('www.csdn.com', '/点赞')
let uri3 = uri_https('www.csdn.com', '/收藏')

console.log(uri1, uri2, uri3);

结果:
在这里插入图片描述
3. 例子2:

// 判断兼容哪种事件监听方式
const whichEvent = (function() {
    if (window.addEventListener) {
        // element :哪个元素需要添加事件监听
        // type : 元素需要添加什么类型的事件
        // listner : 就是执行的回调函数
        // useCapture : 进行事件冒泡 还是 捕获的选择
        return function(element, type, listner, useCapture) {
            element.addEventListener(type, function(e) {
                // 重新this指向
                listner.call(element, e)
            }, useCapture)
        }
    } else if (window.attachEvent) {
        // ie默认支持事件冒泡
        return function(element, type, handler) {
            element.attachEvent('on' + type, function(e) {
                handler.call(element, e)
            })
        }
    }
})()

2. 参考

JavaScript函数柯里化 - Web前端工程师面试题讲解

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

想做一只快乐的修狗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值