sort.js 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. const sortData = {
  2. result : [],
  3. type : {},
  4. parse(array , column , i) {
  5. let _this=this;
  6. let data = {};
  7. data['0']='';data['1']='';data['2']='';data['3']='';data['4']='';data['5']='';data['6']='';data['7']='';data['8']='';
  8. data['9']='';data['a']='';data['b']='';data['c']='';data['d']='';data['e']='';data['f']='';data['g']='';data['h']='';
  9. data['i']='';data['j']='';data['k']='';data['l']='';data['m']='';data['n']='';data['o']='';data['p']='';data['q']='';
  10. data['r']='';data['s']='';data['t']='';data['u']='';data['v']='';data['w']='';data['x']='';data['y']='';data['z']='';
  11. data['A']='';data['B']='';data['C']='';data['D']='';data['E']='';data['F']='';data['G']='';data['H']='';data['I']='';
  12. data['J']='';data['K']='';data['L']='';data['M']='';data['N']='';data['O']='';data['P']='';data['Q']='';data['R']='';
  13. data['S']='';data['T']='';data['U']='';data['V']='';data['W']='';data['X']='';data['Y']='';data['Z']='';
  14. array.forEach(function (obj) {
  15. if (!obj[column]) obj[column]='';
  16. if (!data[obj[column].charAt(i)]) data[obj[column].charAt(i)] = [obj];
  17. else data[obj[column].charAt(i)].push(obj);
  18. });
  19. let recursion=[];
  20. for (let key in data){
  21. if (!data[key]){
  22. delete data[key];
  23. continue;
  24. }
  25. if (data[key].length > 1){
  26. if ( !(!data[key].some(function (value, index) {
  27. return value[column] !== data[key][0][column];
  28. }))){
  29. recursion.push(key);
  30. }
  31. }
  32. }
  33. if (recursion.length > 0){
  34. i++;
  35. recursion.forEach(function (key) {
  36. data[key] = _this.parse(data[key] ,column , i);
  37. });
  38. }
  39. return data;
  40. },
  41. sort:function(array, column ,type, i=0 ) {
  42. this.result = [];
  43. this.type = type;
  44. //if (!Array.isArray(column)) column = [column];
  45. let columnName = column[0];
  46. column.splice(0,1);
  47. this.merge(this.parse(array, columnName, i), column, columnName);
  48. array.length = 0;
  49. array.push.apply(array,this.result);
  50. },
  51. merge(object, subordinate = [] ,columnName = '') {
  52. for (let key in object){
  53. if (Array.isArray(object[key])){
  54. if (object[key].length > 1 && subordinate.length > 0){
  55. let subordinateName = subordinate[0];
  56. subordinate.splice(0,1);
  57. object[key] = this.merge(this.parse(object[key], subordinateName, 0), subordinate, subordinateName);
  58. }
  59. if (this.type[columnName] === 'asc') this.result.push.apply(this.result,object[key]);
  60. else this.result.unshift.apply(this.result,object[key]);
  61. }else this.merge(object[key], [] ,columnName);
  62. }
  63. }
  64. };
  65. module.exports=sortData;