Juery解決tablesorter中文排序和字符范圍的方法
本文實例講述了Juery解決tablesorter中文排序和字符范圍的方法。分享給大家供大家參考。具體分析如下:
tablesorter是jQuery插件中比較優(yōu)秀的一款表格排序插件,我相信大家都使用過或有所耳聞,我在這里就不過多介紹了,詳細信息可以看看官方網(wǎng)站:http://tablesorter.com/docs/(其中的demo做得比較完整)。
在使用了tablesorter開發(fā)的幾個項目中,發(fā)現(xiàn)了兩種類型的排序存在問題,如下:
第一個問題是無法對中文字符進行排序,這是因為在對字符排序時,是使用的unicode值進行的字符大小比較,代碼如下:
Js代碼
function sortText(a,b) {
return ((a < b) ? -1 : ((a > b) ? 1 : 0));
};
function sortTextDesc(a,b) {
return ((b < a) ? -1 : ((b > a) ? 1 : 0));
};
function sortText(a,b) {
return ((a < b) ? -1 : ((a > b) ? 1 : 0));
};
function sortTextDesc(a,b) {
return ((b < a) ? -1 : ((b > a) ? 1 : 0));
};
而我們想要得到的結(jié)果是按漢字拼音進行順序進行排序,因此我們將代碼修改為以下代碼即可:
Js代碼
function sortText(a,b) {
return a.localeCompare(b);
};
function sortTextDesc(a,b) {
return b.localeCompare(a);
};
function sortText(a,b) {
return a.localeCompare(b);
};
function sortTextDesc(a,b) {
return b.localeCompare(a);
};
localeCompare方法是JS自帶的方法,不用多說,望文生義就知道這個方法是根據(jù)當前區(qū)域下對字符的大小進行比較,不過這個方法無法處理多音字。
第二個問題是無法對超出了范圍的數(shù)值型數(shù)據(jù)進行排序,這是因為在進行數(shù)值類型轉(zhuǎn)換時,存在數(shù)據(jù)值失真的情況,例如:
Js代碼
alert(parseFloat('9999999999999999')); // 10000000000000000
alert(parseFloat('10000000000000001')); // 10000000000000000
alert(parseFloat('10000000000000004')); // 10000000000000004
alert(parseFloat('10000000000000005')); // 10000000000000004
alert(parseFloat('10000000000000006')); // 10000000000000006
alert(parseFloat('9999999999999999')); // 10000000000000000
alert(parseFloat('10000000000000001')); // 10000000000000000
alert(parseFloat('10000000000000004')); // 10000000000000004
alert(parseFloat('10000000000000005')); // 10000000000000004
alert(parseFloat('10000000000000006')); // 10000000000000006
這樣的偏差會使得排序結(jié)果不準確,為了避免這種問題,應該不使用原始值進行比較,而是應該引入權值,數(shù)值從左到右,每一位數(shù)值對應的權值遞減,然后根據(jù)權值和原始值計算出的新值用于比較,這就只需要修改formatFloat方法就能解決這個問題了。
Js代碼
this.formatFloat = function(s) {
// TODO
var i = parseFloat(s);
return (isNaN(i)) ? 0 : i;
};
希望本文所述對大家的jQuery程序設計有所幫助。
相關文章
jQuery中圖片展示插件highslide.js的簡單dom
Highslide是一個非常美觀的圖片燈箱插件,下面這篇文章主要給大家介紹了關于jQuery中圖片展示插件highslide.js的簡單dom,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2018-04-04
jQuery .attr()和.removeAttr()方法操作元素屬性示例
本文為大家詳細介紹下如何使用jQuery的.attr()和.removeAttr()方法讀取,添加,修改,刪除元素的屬性,不會的朋友可以參考下哈,希望對大家有所幫助2013-07-07
Jquery實現(xiàn)仿京東商城省市聯(lián)動菜單
這篇文章主要介紹了Jquery實現(xiàn)仿京東商城省市聯(lián)動菜單的簡單實例演示,可以選擇對應省、市、縣,希望大家可以喜歡。2015-11-11

