在上篇文章给大家介绍了JavaScript sort数组排序方法和自我实现排序方法小结,用自己的方法实现了数字数组的排序。
当然,实际运用中,我还是会使用sort方法更加方便.但是,我上一篇博文,仅仅是实现了数字排序,而srot方法默认可是能给字母实现排序的哦!而我的代码只能排序数字,看起来还是弱弱的.
所以,我得加上能排字母甚至中文的排序方法.
实现代码
$(function(){ var arr = ["Jack","Book","Fung",76,"Love","Mark","中国","china","phone","刘德华"]; console.log('原数组'); console.log(arr); console.log('for方法从小到大排序'); console.log(arrSortMinToMax(arr)); console.log('for方法从大到小排序'); console.log(arrSortMaxToMin(arr)); console.log('原数组'); console.log(arr); }); function arrMinNum(arr){ var minNum = Infinity, index = -1,minVul = ""; for (var i = 0; i < arr.length; i++) { if (typeof(arr[i]) == "string") { if (arr[i].charCodeAt()<minNum) { minNum = arr[i].charCodeAt(); minVul = arr[i]; index = i; } }else { if (arr[i]<minNum) { minNum = arr[i]; minVul = arr[i] index = i; } } }; return {"minNum":minVul,"index":index}; } function arrSortMinToMax(arr){ var arrNew = []; var arrOld = arr.concat(); for (var i = 0; i < arr.length; i++) { arrNew.push(arrMinNum(arrOld).minNum); arrOld.splice(arrMinNum(arrOld).index,1) }; return (arrNew); } function arrMaxNum(arr){ var maxNum = -Infinity, index = -1,maxVul = ""; for (var i = 0; i < arr.length; i++) { if (typeof(arr[i]) == "string") { if (arr[i].charCodeAt()>maxNum) { maxNum = arr[i].charCodeAt(); maxVul = arr[i]; index = i; } }else { if (arr[i]>maxNum) { maxNum = arr[i]; maxVul = arr[i]; index = i; } } }; return {"maxNum":maxVul,"index":index}; } function arrSortMaxToMin(arr){ var arrNew = []; var arrOld = arr.slice(0); for (var i = 0; i < arr.length; i++) { arrNew.push(arrMaxNum(arrOld).maxNum); arrOld.splice(arrMaxNum(arrOld).index,1); }; return (arrNew); }
运行截图如下:
排序原理
如果是数字,则直接是数字进行比对
如果是字符串,则使用charCodeAt()转换成Unicode编码进行排序.
Unicode 是 0 - 65535 之间的整数
其他说明
按照正常的排序逻辑,应该是:数字比一切字母都小,字母比一切中文都小,中文应该按照首字拼音的首字母排序.
我的这段代码除了字母比一切中文都小这一条实现了,其他都没有实现.
逻辑也应该可以实现,把数字字母中文分别找出来,数字跟数组进行比较,字母跟字母比较,中文跟中文比较,然后拼接数组
中文获取首字的首字母可能稍微麻烦一点.
汉字居然可以直接比对的.
如上图所示,张飞想要做老大是有道理的.JavaScript终于在千年之后为张飞正名,当年他就应该是做老大的!~
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
更新日志
2024年11月27日
2024年11月27日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]