js實現中文名的排序

漢字的排序,如果含有英文的話,各排個的,互補影響。

<body>
<select class="sel" id="ect">
	<option value="蛋蛋">蛋蛋</option>
	<option value="笨笨">笨笨</option>
	<option value="小明">小明</option>
	<option value="笨蛋">笨蛋</option>
	<option value="汐">汐</option>
	<option value="Jack">Jack</option>
	<option value="Daniel">Daniel</option>
	<option value="克傑">克傑</option>
	<option value="信宗">信宗</option>
	<option value="fido">fido</option>
	<option value="tom">tom</option>
	<option value="jerry">jerry</option>	
</select>
<input type="submit" value="排序" onClick="order()"/>
</body>

javascript的部分:

<script src="jquery-1.11.2.js"></script>
<script type="text/javascript">
	function order(){
		$("select option").sort(function(a,b){ 
		    var aText = $(a).text(); 
		    var bText = $(b).text(); 
		    if(typeof aText =="string" && typeof bText == "string"){
		    	return aText.localeCompare(bText);
		    } 
		}).appendTo('select') ;	
	}
</script>

注:localeCompare() 方法用於字符串編碼的排序

  sort() 方法用於數組元素的排序


通訊錄排序:

function pySegSort(arr,empty) {
    if(!String.prototype.localeCompare)
        return null;
     
    var letters = "*ABCDEFGHJKLMNOPQRSTWXYZ".split('');
    var zh = "阿八嚓噠妸發旮哈譏咔垃麻拏噢妑七呥扨它穵夕丫帀".split('');
     
    var segs = [];
	
    var curr;
    $.each(letters, function(i,n){
        curr = {letter: this, data:[]};
        $.each(arr, function(k,v) {
            if((!zh[i-1] || zh[i-1].localeCompare(v.text) <= 0) && v.text.localeCompare(zh[i]) == -1) {
                curr.data.push(this);
            }
        });
        if(empty || curr.data.length) {
			py.push(this);
            segs.push(curr);
            curr.data.sort(function(a,b){
                return a.text.localeCompare(b.text);
            });
        }
    });
	
    return segs;
}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章