日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

js基础练习题 二次封装函数

發布時間:2025/3/20 编程问答 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 js基础练习题 二次封装函数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目描述

已知函數 fn 執行需要 3 個參數。請實現函數 partial,調用之后滿足如下條件:
1、返回一個函數 result,該函數接受一個參數
2、執行 result(str3) ,返回的結果與 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必須顯式地調用str3,立即執行 // bind不是立即執行,未傳入str3時,并未執行,只是返回一個函數,等待參數傳入 // 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);

轉載于:https://www.cnblogs.com/jiye123/p/8134610.html

總結

以上是生活随笔為你收集整理的js基础练习题 二次封装函数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。