var complexComputation = function () { /* 内部处理,并返回一个node*/};
var findNodes = function (callback) { var nodes = []; var node = complexComputation(); // 如果回调函数可用,则执行它 if (typeof callback === "function") { callback(node); } nodes.push(node); return nodes; };
// 定义callback var hide = function (node) { node.style.display = "none"; }; // 查找node,然后隐藏所有的node var hiddenNodes = findNodes(hide);
// 使用匿名函数定义callback var blockNodes = findNodes(function (node) { node.style.display = 'block'; });
var menuId = $("ul.nav").first().attr("id"); var request = $.ajax({ url: "script.php", type: "POST", data: {id : menuId}, dataType: "html" }); //调用成功时的回调处理 request.done(function(msg) { $("#log").html( msg ); }); //调用失败时的回调处理 request.fail(function(jqXHR, textStatus) { alert( "Request failed: " + textStatus ); });
var conf = { username:"shichuan", first:"Chuan", last:"Shi" }; addPerson(conf);
// 事先设置好初始值 $.ajaxSetup({ url: "/xmlhttp/", global: false, type: "POST" }); // 然后再调用 $.ajax({ data: myData });
var setup = function () { console.log(1); return function () { console.log(2); }; }; // 调用setup 函数 var my = setup(); // 输出 1 my(); // 输出 2
// 或者直接调用也可
setup()();
var setup = function () { var count = 0; return function () { return ++count; }; }; // 用法 var next = setup(); next(); // 返回 1 next(); // 返回 2 next(); // 返回 3
var partialAny = (function (aps) { // 该函数是你们自执行函数表达式的结果,并且赋值给了partialAny变量 function func(fn) { var argsOrig = aps.call(arguments, 1); return function () { var args = [], argsPartial = aps.call(arguments), i = 0; // 变量所有的原始参数集, // 如果参数是partialAny._ 占位符,则使用下一个函数参数对应的值 // 否则使用原始参数里的值 for (; i < argsOrig.length; i++) { args[i] = argsOrig[i] === func._ ? argsPartial.shift() : argsOrig[i]; } // 如果有任何多余的参数,则添加到尾部 return fn.apply(this, args.concat(argsPartial)); }; } // 用于占位符设置 func._ = {}; return func; })(Array.prototype.slice);
// 定义处理函数 function hex(r, g, b) { return '#' + r + g + b; } //定义偏函数, 将hex的第一个参数r作为不变的参数值ff var redMax = partialAny(hex, 'ff', partialAny._, partialAny._); // 新函数redMax的调用方式如下,只需要传入2个参数了: console.log(redMax('11', '22')); // "#ff1122"
var __ = partialAny._; var greenMax = partialAny(hex, __, 'ff'); console.log(greenMax('33', '44')); var blueMax = partialAny(hex, __, __, 'ff'); console.log(blueMax('55', '66')); var magentaMax = partialAny(hex, 'ff', __, 'ff'); console.log(magentaMax('77'));
function add(x, y) { var oldx = x, oldy = y; if (typeof oldy === "undefined") { // partial return function (newy) { return oldx + newy; } } return x + y; }
// 测试 typeof add(5); // "function" add(3)(4); // 7 // 也可以这样调用 var add2000 = add(2000); add2000(10); // 2010
// 第一个参数为要应用的function,第二个参数是需要传入的最少参数个数 function curry(func, minArgs) { if (minArgs == undefined) { minArgs = 1; } function funcWithArgsFrozen(frozenargs) { return function () { // 优化处理,如果调用时没有参数,返回该函数本身 var args = Array.prototype.slice.call(arguments); var newArgs = frozenargs.concat(args); if (newArgs.length >= minArgs) { return func.apply(this, newArgs); } else { return funcWithArgsFrozen(newArgs); } }; } return funcWithArgsFrozen([]); }
var plus = curry(function () { var result = 0; for (var i = 0; i < arguments.length; ++i) { result += arguments[i]; } return result; }, 2);
plus(3, 2) // 正常调用 plus(3) // 偏应用,返回一个函数(返回值为3+参数值) plus(3)(2) // 完整应用(返回5) plus()(3)()()(2) // 返回 5 plus(3, 2, 4, 5) // 可以接收多个参数 plus(3)(2, 3, 5) // 同理
var minus = curry(function (x) { var result = x; for (var i = 1; i < arguments.length; ++i) { result -= arguments[i]; } return result; }, 2);
var flip = curry(function (func) { return curry(function (a, b) { return func(b, a); }, 2); });