|
另外推薦一下月影的書――"王者歸來",如果你每周js的coding時間大于5小時,還是值得一讀的。
1.函數膠水,有很多同學用jq用習慣了,有時就為一個類似于c#里的event+=delegate而用jq,似乎有點劃不來,這幾原型函數就夠了。
復制代碼 代碼如下:
Function.prototype.$concat = function(){
var funcs = [this].concat(Array.apply([], arguments));
return function(){
var ret = [];
for(var i = 0; i < funcs.length; i++){
var func = funcs[i] instanceof Function ? funcs[i] : new Function(funcs[i]);
ret.push(func.apply(this, arguments));
}
return ret;
}
}
//var concat = (function a(a){
// alert("a:"+a);
//}).$concat(function b(b){
// alert("b:"+b);
//});
//concat(1);
2.函數柯靈化,柯靈化是面向函數式語言的一個重要特性,和大部分人所持有的面向過程的編程思想區別很大,就我愚見,日常工作中,函數柯靈化除了能把一些代碼寫得優雅(或許還有詭異)以外,不是特別的"必要"。
復制代碼 代碼如下:
Function.prototype.$curry=function(){
with({that:this})
return function()
{
var args = Array.prototype.slice.call(arguments);
if(args.length<that.length)
{
return function(){
var _args = args.concat(Array.prototype.slice.call(arguments));
return that.$curry().apply(this,_args);
}
}
else return that.apply(this,args);
}
}
//var curry=(function f(a,b,c){
// alert([a,b,c]);
// }).$curry();
//curry(1)(2)(3);
//curry(1,2)(3);
3.對象閉包。這個詞是我造的,不過看一下注釋里的調用便可以理解,這個函數原本是為了證明with和閉包的等價性,但卻提供了一個極有價值的模式。
復制代碼 代碼如下:
Function.prototype.$bind=function(object){
var callback = function () {
return arguments[0];
}
with(object){
return eval('callback(' + this.toString() + ')');
}
}
//var obj = {a:1,b:2};
//var bind=(function (){
// a=10;
// b=11;
//}).$bind(obj);
//bind();
//alert(obj.a);
4. string.Format。怕是很多js coder都想有一個c#(Java類似)里的string.Format方法,其實一點也不麻煩。
復制代碼 代碼如下:
String.prototype.$format=function(){
var ret;
for(var i=1;i<arguments.length;i++){
var exp = new RegExp('//{' + (i-1) + '//}','gm');
ret = (ret||this).replace(exp,arguments[i-1]);
}
return ret;
}
//alert("{0},{1},{4}".$format(0,1,2));
以后有機會還會陸續分享一些這樣犀利的函數。暫且給些函數合計取個名字,就叫 p.js 吧。
JavaScript技術:犀利的js 函數集合,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。