function cp(f,c){ var g,h; f=g=f.v.toLowerCase(), c=h=c.v.toLowerCase(); //数字[包括货币符号] -- 排序 //去掉空格,并转换成浮点数,不成功返回NaN, var i=parseFloat(f.replace(/(\$|\,)/g,'')), n=parseFloat(c.replace(/(\$|\,)/g,'')); if( !isNaN(i)&&!isNaN(n) ){ //如果是数字执行... g=i,h=n ; } //日期 -- 排序 //Date.parse 返回指定的日期和时间据 1970/1/1 午夜(GMT 时间)之间的毫秒数。 //不成功返回NaN, i=Date.parse(f); n=Date.parse(c); if( !isNaN(i)&&!isNaN(n) ){ //如果是日期执行... g=i; h=n; } //汉字比较 -- 排序 if(/^[\u0391-\uFFE5]+$/.test(f)){ return f.localeCompare(c); } // return f.v.localeCompare(c.v); return g>h ? 1 :(g<h?-1:0) };
作者并没有考虑到中文问题,对于大多数外国朋友而言可能并不要这个功能,比如ext缺省并不包含这个方案的解决...
这里我仅仅提供了中文排序的方案,对于其他字符,可以自行实现...
测试代码见附件: