javascript - js 有優(yōu)雅的辦法從外部 hijack 函數(shù)入?yún)幔?/h1>
瀏覽:128日期:2023-09-21 18:52:02
問題描述
let fn = (a, b, c) => { console.log(a, b, c)}fn1(0, 0, 0) // output: 0 0 0
想要 fn 每次調(diào)用的時(shí)候第二個(gè)參數(shù)總是加 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})()
有沒有更好一點(diǎn)的包裝方法?
問題解答
回答1:方法是沒錯(cuò),不過我總覺得你寫的有點(diǎn)別扭……我覺得直接一點(diǎn)比較好……
// 原函數(shù)function fn(a, b, c) { console.log(a, b, c)}// 加工函數(shù)const addTwo = (fn) => (a, b, c) =>fn(a, b + 2, c);// 生成新函數(shù)const newFn = addTwo(fn);newFn(0, 0, 0); //0 2 0回答2:
想要 fn 每次調(diào)用的時(shí)候第二個(gè)參數(shù)總是加 2
呃呃呃。。其實(shí)無非就是分別給參數(shù)加上 0, 2, 0
也就是說從函數(shù) fn 生成另外一個(gè) 偏函數(shù) fnOffset
把 [0, 2, 0] 這三個(gè)參數(shù) 分別加到 fn(a, b, c) 上的 a b c 上
更廣義的說:
把 [ .... ] 這 n 個(gè)參數(shù) 分別加到 fn() 的 arguments 的對(duì)應(yīng)位置上
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);
![javascript - js 有優(yōu)雅的辦法從外部 hijack 函數(shù)入?yún)幔? src=]()
![javascript - js 有優(yōu)雅的辦法從外部 hijack 函數(shù)入?yún)幔? src=]()
用 fn020 做變量名 應(yīng)該更優(yōu)雅把 = =
回答3:你描述的東西有點(diǎn)像ES6的Proxy,但是這個(gè)是無法polyfill的,可能不太適合在前端用。
標(biāo)簽:
JavaScript
相關(guān)文章:
1. macOS Sierra 10.12 安裝mysql 5.7.1出現(xiàn)錯(cuò)誤2. mysql - 拖拽重排序后怎么插入數(shù)據(jù)庫(kù)?3. android - 安卓做前端,PHP做后臺(tái)服務(wù)器 有什么需要注意的?4. javascript - 天貓首頁(yè)首屏數(shù)據(jù)來源5. mysql 獲取時(shí)間函數(shù)unix_timestamp 問題?6. mysql - 僅僅只是把單引號(hào)與反斜杠轉(zhuǎn)義不用prepare statement能否避免sql注入?7. php - 生產(chǎn)環(huán)境下,給MySQL添加索引,修改表結(jié)構(gòu)操作,如何才能讓線上業(yè)務(wù)不受影響?8. mysql主主同步,從庫(kù)不同步應(yīng)該怎么解決?9. mysql在限制條件下篩選某列數(shù)據(jù)相同的值10. 新入手layuiadmin,部署到tp中。想用php自已寫一個(gè)后臺(tái)管理系統(tǒng)。
問題描述
let fn = (a, b, c) => { console.log(a, b, c)}fn1(0, 0, 0) // output: 0 0 0
想要 fn 每次調(diào)用的時(shí)候第二個(gè)參數(shù)總是加 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})()
有沒有更好一點(diǎn)的包裝方法?
問題解答
回答1:方法是沒錯(cuò),不過我總覺得你寫的有點(diǎn)別扭……我覺得直接一點(diǎn)比較好……
// 原函數(shù)function fn(a, b, c) { console.log(a, b, c)}// 加工函數(shù)const addTwo = (fn) => (a, b, c) =>fn(a, b + 2, c);// 生成新函數(shù)const newFn = addTwo(fn);newFn(0, 0, 0); //0 2 0回答2:
想要 fn 每次調(diào)用的時(shí)候第二個(gè)參數(shù)總是加 2
呃呃呃。。其實(shí)無非就是分別給參數(shù)加上 0, 2, 0
也就是說從函數(shù) fn 生成另外一個(gè) 偏函數(shù) fnOffset
把 [0, 2, 0] 這三個(gè)參數(shù) 分別加到 fn(a, b, c) 上的 a b c 上
更廣義的說:
把 [ .... ] 這 n 個(gè)參數(shù) 分別加到 fn() 的 arguments 的對(duì)應(yīng)位置上
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 做變量名 應(yīng)該更優(yōu)雅把 = =
回答3:你描述的東西有點(diǎn)像ES6的Proxy,但是這個(gè)是無法polyfill的,可能不太適合在前端用。
