标签:
有一哥们在微信开发中,到生成签名这抓狂了一天
最后发现微信调试工具在IE和chrome下对字符的排序竟然不同。
嗯,这个问题引起了我的关注,于是根据微信工具里的对象数组格式,撸了几句代码调试了一下,发现在IE9下,sort遇到复杂对象压根就不工作。
先来简单的:
var k = ["a","A","123"]; k.sort(); console.log(k);
结果:123,A,a
元素是对象的:
var t = []; var tmp = new Object(); tmp.id = "batch_add_api_ticket"; tmp.val = "A" t.push(tmp); tmp = new Object(); tmp.id = "timestamp"; tmp.val = "b" t.push(tmp); tmp = new Object(); tmp.id = "nonce_str1"; tmp.val = "12" t.push(tmp); tmp = new Object(); tmp.id = "card_id"; tmp.val = "d213" t.push(tmp); t.sort(function(e,t){ var bln = e.val>=t.val; console.log(e.val + ">=" + t.val + " is " + bln); return bln; }); var c=""; for(i in t)c+=t[i].val; console.log(c);
IE9结果:Ab12d123
chrome结果:12Abd123
IE又增加了一个槽点,或许是有什么我等菜鸟不懂的玄鸡??
各种搜索无果,于是自己给Array增加一个冒泡排序(字典序)功能
Array.prototype.sort2 = function(fn){ var fn = fn || function(a, b){ return a > b;}; for(var i=0; i<this.length; i++){ for(var j=i; j<this.length; j++){ if(fn(this[i], this[j]) > 0){ var t = this[i]; this[i] = this[j]; this[j] = t; } } } return this; };
经测IE和Chrome结果一致,打完收工碎觉。
等等,怎么有个undefined。。
仔细看看,原来拼接字符串时用了for in循环,for..in循环计数器是字符串,而不是for循环中的数字,它会把prototype中的方法或属性给遍历出来(好强大),于是,我们还要判断一下
for(var i in t){ if(t.hasOwnProperty(i)){ c+=t[i].val; } }
嗯,输出终于正常了。碎觉碎觉。
标签:
原文地址:http://www.cnblogs.com/blackice/p/5031539.html