js基础练习题 二次封装函数
生活随笔
收集整理的這篇文章主要介紹了
js基础练习题 二次封装函数
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
題目描述
已知函數(shù) fn 執(zhí)行需要 3 個參數(shù)。請實現(xiàn)函數(shù) partial,調(diào)用之后滿足如下條件:1、返回一個函數(shù) result,該函數(shù)接受一個參數(shù)
2、執(zhí)行 result(str3) ,返回的結(jié)果與 fn(str1, str2, str3) 一致 示例1
輸入
var sayIt = function(greeting, name, punctuation) { return greeting + ', ' + name + (punctuation || '!'); }; partial(sayIt, 'Hello', 'Ellie')('!!!');輸出
Hello, Ellie!!!代碼
function partial(fn, str1, str2) {
var result=function(str3){
return fn.apply(this,[str1,str2,str3])
};
return result
}
要點
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 | // call和apply必須顯式地調(diào)用str3,立即執(zhí)行 // bind不是立即執(zhí)行,未傳入str3時,并未執(zhí)行,只是返回一個函數(shù),等待參數(shù)傳入 // this用于上下文不確定的情況 // call function partial(fn, str1, str2) { ????function result(str3) { ????????return fn.call(this, str1, str2, str3); ????} ?????return result; } // apply(這里只是為了對照) function partial(fn, str1, str2) { ????function result(str3) { ????????return fn.apply(this, [str1, str2, str3]); ????} ????return result; } // ES6 this指向undefined. const partial = (fn, str1, str2) => str3 => fn(str1, str2, str3); |
轉(zhuǎn)載于:https://www.cnblogs.com/jiye123/p/8134610.html
總結(jié)
以上是生活随笔為你收集整理的js基础练习题 二次封装函数的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 如何优雅地在React项目中使用Redu
- 下一篇: sharepoint 场帐号修改密码