Javascript OrderBy
要在js 实现orderBy
基本知识就是 array.sort
array.sort(function(a,b){
a 表示 row 0
b 表示 row 1
它会loop多次
你可以比较 if(a > b) return 1
做出一个return , return 的结果 >0 代表你要这2个row对换位置
})
要实现orderBy呢
逻辑就是在比较的时候如果出现一样值,你要拿接下来的column做对比,直到完结!是一种梯归手法
if(a > b) return 1
else (a < b) return -1
else
{
平手
var a = row1["color"] //换下一个column的值对比
var b = row2["color"]
if(a > b) return 1
else if ..
else ...
又平手再循环...
}
sort 是游览器自带的功能。它的sort法法我不知道,排序本来就有很多很多种方法。(但可以支持上面的思想!这样很不错)。
一般我们对orderBy的思想可能是先sort 第一次,然后把相同的分层多个part ,在每个层sort 一次,一直这样循环 。 这其实是错误的。
在第一次loop时就要把逻辑给进去。一次sort 完成就可以了。
下面上一段代码,基本上可以用,只是要修改一些基本函数的依赖。
//orderBy array是引用哦
Array.prototype.orderBy = function (conditionList) {
conditionList = facade_(conditionList);
//一个外观处理
//上层调用:
//array.orderBy()顺序(not support value object|array)
//array.orderBy("-")逆序(not support value object|array)
//array.orderBy("code,-color,size") - 代表desc code代表attr (not support 有2中valueType的)
//array.orderBy("0,-1,2") 0代表 array index (not support 有2中valueType的)
function facade_(para) {
//如果para 完全没有
if (para === undefined) {
return [{}]; //顺序,只能处理 value not array|object
}
else if (G.isString(para)) {
var split = para.split(",");
var conditionList = [];
split.forEach(function (value) {
var condition = {};
var firstChar = value.charAt(0);
if (firstChar === "-") {
condition.numberSort = "desc";
value = value.substring(1);
}
if (value != "") {
if (G.canBeNumber(value)) {
value = +value;
}
condition.sortKey = value; //试图转去number
}
conditionList.push(condition);
});
return conditionList;
}
}
//API : 调用
//var result = array.orderBy([{ sortKey, numberFirst, numberSort, otherSort }]) 只区分是number or not number
//sortKey : attr 或者 array的i , 没有代表value不是array|object
//numberFirst : true|false, default 是true , 当value有不同类型,时候number排在前面
//numberSort : "desc"|"" default 是 "" 如果要desc,这是必填!
//otherSort : "desc"|"" default 是 "" , 如果只有一种类型,那么就只用numberSort就可以了
//逻辑规则,length = 0 error
//value 是对象或array就一定有 conditionList[0].sortKey
//value 是对象或array, 结构一定要一样,比如长短或attr
//精华 :
//array.sort(function(a,b){})
//a,b 代表row
//return > 0 代表要转
var loop = function (v1, v2, conditionList, conditionIndex) {
var result;
var condition = conditionList[conditionIndex];
//处理value
var a = v1, b = v2;
var sortKey = condition.sortKey;
if (sortKey !== undefined) {
a = v1[sortKey];
b = v2[sortKey];
}
//区分 valueType
var typeA = G.s.fn.myTypeOf(a);
var typeB = G.s.fn.myTypeOf(b);
if (typeA === typeB) {
result = (condition.numberSort === undefined || condition.numberSort !== "desc") ? 1 : -1; //这个是给number的
if (typeA !== "number" && condition.otherSort !== undefined) {
result = (condition.otherSort !== "desc") ? 1 : -1;
}
if (a > b) {
return result; //return 1 代表转
}
else if (a < b) {
return -result;
}
else {
//打平手的话梯归比下一个,当有多个orderBy
conditionIndex++;
if (conditionList[conditionIndex] !== undefined) {
return loop(v1, v2, conditionList, conditionIndex); //梯归
}
else {
return 0;
}
}
}
else {
//类型不同不能比,就看number要不要去前面就好
result = (condition.is_numberFirst === undefined || condition.is_numberFirst === true) ? -1 : 1;
if (typeA === "number") return result; //a 是number , 如果你要number在前就不要转 -1
return -result;
}
};
this.sort(function (v1, v2) {
return loop(v1, v2, conditionList, 0);
});
return this;
};
简单的可以这样调用 :
array.orderBy()顺序(not support value object|array)
array.orderBy("-")逆序(not support value object|array)
array.orderBy("code,-color,size") - 代表desc code代表attr (not support 有2中valueType的)
array.orderBy("0,-1,2") 0代表 array index (not support 有2中valueType的)
Javascript OrderBy的更多相关文章
- 让C#可以像Javascript一样操作Json
Json的简介 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的文本格式,但是也使用了 ...
- LINQ查询操作符之Select、Where、OrderBy、OrderByDescending、GroupBy、Join、GroupJoin及其对应的查询语法
介绍 ·Select - Select选择:延迟 ·Where - Where查询:延迟 ·OrderBy - 按指定表达式对集合正序排序:延迟 ·OrderByDescend ...
- AngularJS学习--- AngularJS中数据双向绑定(two-way data-binding) orderBy step4
1.切换工作目录 git checkout step- #切换分支,切换到第4步 npm start #启动项目 2.代码 app/index.html Search: <input ng-mo ...
- 淡扯javascript编程思想
一.面向对象-OOD 虽然js面向对象的编程思想已经老话常谈了,但了为了文章的完整性,我还是把它加了进来,尽量以不太一样的方式讲述(虽然也没什么卵不一样的). 1.面向对象,首先得有类的概念,没有 ...
- Javascript实现Linq查询方式
Linq是.net平台一个重要的技术,全称Language Integrated Query.通过构建快速查询语句,可快速从数据库或集合中筛选数据集.以查询数据库相同的方式操作内存数据. 在ECMAS ...
- 对JavaScript对象数组按指定属性和排序方向进行排序
引子 在以数据为中心的信息系统中,以表格形式展示数据是在常见不过的方式了.对数据进行排序是必不可少的功能.排序可以分为按单个字段排序和按多个字段不同排序方向排序.单字段排序局限性较大,不能满足用户对数 ...
- LINQ to JavaScript
JSLINQ 是一个将LINQ对象转化为JavaScript对象的工具 .它是构建在JavaScript的数组对象的基础上进行转换的,如果您使用的是一个数组,你可以使用LINQ到javascript ...
- JAVASCRIPT实现XML分页
为了方便用户查看大批量数据,我们会用到动态分页,因此分页功能是我们在网站上见过的最普遍也是最常用的一个功能模块了.而以往的信息分页都是连接到数据库的,每一次点击都必须要后台数据库的支持.这样不但服务器 ...
- .NET 3.5(5) - LINQ查询操作符之Select、Where、OrderBy、OrderByDescending
.NET 3.5(5) - LINQ查询操作符之Select.Where.OrderBy.OrderByDescending 介绍 ·Select - Select选择:延迟 ·Where ...
随机推荐
- C# 实现3Des加密 解密
3Des对每个数据块进行了三次的DES加密算法,是DES的一个更安全的变形.比起最初的DES,3DES更为安全. 都是感觉一目了然的摘过来. 下面是加密解密的源码.ECB模式的. public cla ...
- 用otl写的oracle取数工具,执行传入在查询语句,把结果输出到文件
项目中经常需要用到此类型的工具 #pragma warning (disable:4786) #include <iostream> #include <map> #inclu ...
- IOS实现小型计算器
作为一名初学者,编辑一款能够在IOS操作系统上运行的计算器是一件很值得自豪的事情,网络上虽然后很多相关的文章和代码,功能也很强大但是我感觉相关的计算器比加复杂,晦涩难懂,所以我想通过这个小小的计算器, ...
- java cmd常用命令
熟悉Java的常用命令 面试例题11:使用jar命令. 请使用jar命令,将test文件夹压缩成.jar文件,并简述其压缩包的结构. 考点:对于Java程序员来说,更多情况下是使用集成Java开发工具 ...
- make文件中静态连接库在command里面的位置
linux软件第一次调用动态连接库的时候要延迟几秒,怀疑在突然掉库的时候动态库加载耗费了时间,所以造成延时,遂改为静态库方式,原来的makefile文件是 testmac: cp $( ...
- 大数据笔记01:大数据之Hadoop简介
1. 背景 随着大数据时代来临,人们发现数据越来越多.但是如何对大数据进行存储与分析呢? 单机PC存储和分析数据存在很多瓶颈,包括存储容量.读写速率.计算效率等等,这些单机PC无法满足要求. 2. ...
- iTerm2和oh-my-zsh的个性化定制
终于在某东做活动新入手了一台air,看身边小伙伴的mac的终端感觉好炫酷,于是乎准备自己也捯饬捯饬,google了一下,发现了osx平台上的终端神器iTerm2和用来代替bash的oh-my-zsh, ...
- 关于禁止在 .NET Framework 中执行用户代码。启用 "clr enabled" 配置选项
这个问题是我新装好sql2008r2以后,我把服务器上的数据库还原到本地,取代码里跟踪测试的时候,出现的这个问题. 然后我在网上找了之后在sql里直接新建查询执行如下语句: exec sp_confi ...
- 关于.net类型转换判断问题
做项目时,发现这个问题,由于数据库中的字段可能为null,如果在.net程序直接转换时,比如 ltTime.Text =DateTime.Parse(dt.Rows[0]["m_Time&q ...
- DIV布局之道一:DIV块的水平并排、垂直并排
DIV布局网页元素的方式主要有三种:平铺(并排).嵌套.覆盖(遮挡).本文先讲解平铺(并排)方式. 1.垂直平铺(垂直排列) 请看如下代码 CSS部分: CSS Code复制内容到剪贴板 .lay1{ ...