javascript - js 有优雅的办法从外部 hijack 函数入参吗?
问题描述
let fn = (a, b, c) => { console.log(a, b, c)}fn1(0, 0, 0) // output: 0 0 0
想要 fn 每次调用的时候第二个参数总是加 2
即
fn(0, 0, 0) // output: 0 2 0fn(1, 1, 1) // output: 1 3 1
目前只找到一种很丑的写法去 hijack:
fn = (_ => { const innerFn = fn const newFn = (a, b, c) => { innerFn(a, b + 2, c) } Object.assign(newFn, innerFn) return newFn})()
有没有更好一点的包装方法?
问题解答
回答1:方法是没错,不过我总觉得你写的有点别扭……我觉得直接一点比较好……
// 原函数function fn(a, b, c) { console.log(a, b, c)}// 加工函数const addTwo = (fn) => (a, b, c) =>fn(a, b + 2, c);// 生成新函数const newFn = addTwo(fn);newFn(0, 0, 0); //0 2 0回答2:
想要 fn 每次调用的时候第二个参数总是加 2
呃呃呃。。其实无非就是分别给参数加上 0, 2, 0
也就是说从函数 fn 生成另外一个 偏函数 fnOffset
把 [0, 2, 0] 这三个参数 分别加到 fn(a, b, c) 上的 a b c 上
更广义的说:
把 [ .... ] 这 n 个参数 分别加到 fn() 的 arguments 的对应位置上
function fn(a, b, c){ console.log(a, b, c); }function adder(arr, fn, _this){ _this = _this || window; var toAdd = arr.slice(0, fn.length); return function(){var argu = Array.prototype.slice.call(arguments); fn.apply(_this, toAdd.map((item, idx) => { return argu[idx] + item; })); }}var fnOffset = adder([0, 2, 0], fn); fnOffset(0, 0, 0); fnOffset(2, 1, 0);


用 fn020 做变量名 应该更优雅把 = =
回答3:你描述的东西有点像ES6的Proxy,但是这个是无法polyfill的,可能不太适合在前端用。
相关文章:
1. 为什么span的color非要内联样式才起作用?2. javascript - swiper.js嵌套了swiper 初始设置不能向下一个滑动 结束后重新初始3. python - Django ManyToManyField 字段数据在 admin后台 显示不正确,这是怎么回事?4. angular.js - angular-ui-bootstrap 报错无法使用?5. python - 如何修改twisted自带的日志输出格式?6. docker - 如何修改运行中容器的配置7. 求救一下,用新版的phpstudy,数据库过段时间会消失是什么情况?8. 请问一下各位老鸟 我一直在学习独孤九贱 现在是在tp5 今天发现 这个系列视频没有实战9. 在cmd下进入mysql数据库,可以输入中文,但是查看表信息,不显示中文,是怎么回事,怎新手,请老师10. 如何使用git对word文档进行版本控制?

网公网安备