JS去重函数的扩展应用
数据:
账单id[1,1,1,1,2,2,2,3,3,3,3,3,3,3],
相对于账单id的金额[100,120,110,150,200,180,220,115,150,120,180,220,140,200],
要求:
去重账单id数组,按id分组账单金额总额数组,按账单分组账单金额明细(二维数组)。
JS方法实现:(该方法的前提是id与金额一一对应,且id已经排序)
/**
* 重构公司id和金额数组
* @param arrId:companyId数组
* @param arrAmount:金额数组
* @returns ids:去重后的id数组
* @returns amount:按id分组求和的金额数组
* @returns groupAmount:按id分组的二位金额数组
*/
function uniqueArray(arrId,arrAmount){
var ids = new Array(); //存放id新数组
var amount = new Array();//存放金额新数组
var groupAmount = new Array();//分组金额数组
var res =[ids,amount,groupAmount];//结果数组
var json = {};
var index =0;
for(var i = 0; i < arrId.length; i++){
if(!json[arrId[i]]){//不重复操作
ids.push(arrId[i]);
amount.push(arrAmount[i]);
json[arrId[i]] = 1;
groupAmount[index]=new Array();//声明二维数组
groupAmount[index].push(arrAmount[i]);
index++;
}else{ //重复时操作
amount[index-1] = parseFloat(amount[index-1])+ parseFloat(arrAmount[i]);
groupAmount[index-1].push(arrAmount[i]);
}
}
return res;
}
无序id的实现后续。。。
无序id数组的实现,示例代码如下:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
</head>
<script type="text/javascript">
var arrId =[1,1,2,1,3,1,2,3,3,3,2,3,3,3];
var arrAmount = [100,120,110,150,200,180,220,115,150,120,180,220,140,200];
var tmpRes = uniqueArray(arrId,arrAmount);
alert(tmpRes[0]+'----'+tmpRes[1]+'----'+tmpRes[2][0]+'||'+tmpRes[2][1]+'||'+tmpRes[2][2]);
function uniqueArray(arrId,arrAmount){
var ids = new Array(); //存放id新数组
var amount = new Array();//存放金额新数组
var groupAmount = new Array();//分组金额数组
var res =[ids,amount,groupAmount];//结果数组
var json = {};
var index =0;
for(var i = 0; i < arrId.length; i++){
if(!json[arrId[i]]){//不重复操作
ids.push(arrId[i]);
amount.push(arrAmount[i]);
json[arrId[i]] = 1;
groupAmount[index]=new Array();//声明二维数组
groupAmount[index].push(arrAmount[i]);
index++;
}else{ //重复时操作
//求arrId[i]的值位于ids的位置--这样才保证无序也可以实现
var ins = getIndexofOb(ids,arrId[i]);
// amount[index-1] = parseFloat(amount[index-1])+ parseFloat(arrAmount[i]);
// groupAmount[index-1].push(arrAmount[i]);
amount[ins] = parseFloat(amount[ins])+ parseFloat(arrAmount[i]);
groupAmount[ins].push(arrAmount[i]);
}
}
return res;
} /**
* 返回ob在arrOb中索引值,若不存在,返回-1
* @param arrOb
* @param ob
* @returns {number}
*/
function getIndexofOb(arrOb,ob){
for(var i= 0;i<arrOb.length;i++){
if(ob==arrOb[i]){
return i;
}
}
return -1;
}
</script>
<body> </body>
</html>
JS去重函数的扩展应用的更多相关文章
- JS的函数
函数由四部分组成 function+function name+parameter+body 方法调用模式 Object.add(); 函数调用模式: add(3,4) 构造器调用模式:JS是基于原型 ...
- JS匿名函数的理解
js匿名函数的代码如下:(function(){ // 这里忽略jQuery 所有实现 })(); 半年前初次接触jQuery 的时候,我也像其他人一样很兴奋地想看看源码是什么样的.然而,在看到源码的 ...
- ES6入门之函数的扩展
函数js原有的: 属性:arguments[].caller(调用该函数的引用,注意与callee分别开,callee指的是调用函数本身经常在递归中出现).length(形参个数).prototype ...
- IE7、IE8不兼容js trim函数的解决方法
IE兼容,有时候让人头疼,但又不得不去解决. 先看看一下代码: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xh ...
- 转载 jQuery和js自定义函数和文件的方法(全网最全)
jQuery和js自定义函数和文件的方法(全网最全) 版权声明:本文为像雾像雨又像风_http://blog.csdn.net/topdandan的原创文章,未经允许不得转载. https:// ...
- 【node.js】函数、路由
Node.js中函数的使用与Javascript类似,一个函数可以作为另一个函数的参数.我们可以先定义一个函数,然后传递,也可以在传递参数的地方直接定义函数. function say(word) { ...
- ES6 - Note3:数组、对象与函数的扩展
一.数组的扩展,ES6在数组扩展了一些API,以实现更多的功能 1.Array.from:可以将类数组和可遍历的数据结构转换成真正的数组,如下所示 var a = { '0':1,'1':1,leng ...
- JS回调函数全解析教程
转自:http://blog.csdn.net/lulei9876/article/details/8494337 自学jQuery的时候,看到一英文词(Callback),顿时背部隐隐冒冷汗.迅速g ...
- 学习js回调函数
<!DOCTYPE HTML> <html> <head> <meta charset="GBK" /> <title> ...
随机推荐
- 201503-2 数字排序 Java
思路: 将出现过的数以及次数放进Map中,转成List,用Comparator就可以排序了.参数中o2-o1,与排序规则相反,为降序 import java.util.ArrayList; impor ...
- textarea高度自适应解决方法
引入autosize.js <script src="./autosize.js"></script> autosize(document.getEleme ...
- C#判断两个字符串是否相等的方法 ,还有char赋空值办法。
string str1="Test"; string str2 = "Test"; if (str1==str2) //第一种判断方式 { //第二种判断方式 ...
- 人工智能必备之Python3.8.1-安装
1_下载Python 2_下载Python 3_下载Python 4_下载Python-选这里下载:Windows x86-64 executable installer 5_安装Python 6.自 ...
- uniapp结合小程序第三方插件“WechatSI”实现语音识别功能,进而实现终端控制
最近在用soket实现终端控制器的功能,然后就想用语音控制,这样显得更AI WechatSI在manifest.json中配置: 在vue中插入如下展示代码: <view class=" ...
- Django 多对多 关系
多对多,本意就是多个一对多的关系 定义多对多 ManyToManyField 字段 from django.db import models # 学生类 class Student(models.Mo ...
- ZZJ_淘淘商城项目:day02(淘淘商城01 - 项目讲解、环境搭建)
在用Eclipse的开发中,可手动排除不必要的依赖坐标传递. <!-- JPA的1.0依赖 --> <dependency> <groupId>javax.pers ...
- android中的适配器模式
原文: https://blog.csdn.net/beyond0525/article/details/22814129 类适配模式.对象适配模式.接口适配模式
- 爬取迷你mp4各个电影信息
网站:www.minimp4.com # coding=utf-8 import requests from lxml import etree class Minimpe_moves(object) ...
- Clairaut 定理 证明
(Clairaut 定理)设 $E$ 是 $\mathbf{R}^n$ 的开子集合,并设 $f:\mathbf{E}\to \mathbf{R}^{m}$ 是 $E$ 上的二次连续可微函数.那么对于一 ...