js如何查找json数据中的最大值和最小值方法 目录 js查找json数据中的最大值和最小值 使用Math对象来获取最大值和最小值 使用for循环来获取最大值和最小值 获取最大值和最小值返回对应的json数据 用reduce()获取JSON中某个字段值最大的项 需求 语法
目录
- js查找json数据中的最大值和最小值
- 使用Math对象来获取最大值和最小值
- 使用for循环来获取最大值和最小值
- 获取最大值和最小值返回对应的json数据
- 用reduce()获取JSON中某个字段值最大的项
- 需求
- 语法
- 返回值
- 回调函数语法
- 总结
js查找json数据中的最大值和最小值
js操作数组的方式有很多种,查找json数据中的最大值和最小值也是经常用到,那么接下来就介绍2种方式来实现。
先准备好json数据,根据数组中的age值比较大小:
var array = [
{name:'张三1',age:10},
{name:'张三2',age:40},
{name:'张三3',age:40},
{name:'张三4',age:33},
{name:'张三5',age:2},
{name:'张三6',age:2},
]
使用Math对象来获取最大值和最小值
1. 获取最大值:
var max = Math.max.apply(Math, array.map(function(o) {
return o.age;
}))
console.log(max);// 40
2. 获取最小值:
var min = Math.min.apply(Math, array.map(function(o) {
return o.age;
}))
console.log(min);// 2
使用for循环来获取最大值和最小值
1. 获取最大值:
var max = arr[0].age;
for (var i = 1; i < arr.length; i++) {
max = max < arr[i].age ? arr[i].age : max;
}
console.log(max);// 40
2. 获取最小值:
var min = arr[0].age;
for (var i = 1; i < arr.length; i++) {
min = min > arr[i].age ? arr[i].age : min;
}
console.log(min);// 2
获取最大值和最小值返回对应的json数据
1. 获取含有最大值的数据:
var maxAgeArr = arr.filter(item=>item.age==max);
console.log(maxAgeArr);//[{name:'张三2',age:40},{name:'张三3',age:40}]
2. 获取含有最小值的数据:
var minAgeArr = arr.filter(item=>item.age==min);
console.log(minAgeArr);//[{name:'张三5',age:2},{name:'张三6',age:2}]
用reduce()获取JSON中某个字段值最大的项
需求
获取JSON中value值最大的项
[{
value: 1
},{
value: 2
},{
value: 3
}]
语法
array.reduce(callback[, initialValue])
参数 | 说明 |
---|---|
array | 必需。数组对象 |
callback | 必需。一个接受最多四个参数的函数。对于数组中的每个元素,reduce 方法都会调用 callback函数一次。 |
initialValue | 可选。如果指定 initialValue,则它将用作初始值。第一次调用 callback 函数会将此值作为参数。 |
返回值
通过最后一次调用回调函数获得的累积结果。
回调函数语法
function callbackfn(previousValue, currentValue, currentIndex, array)
参数 | 说明 |
---|---|
previousValue | 通过上一次调用回调函数获得的值。如果向 reduce 方法提供 initialValue,则在首次调用函数时,previousValue 为 initialValue。 |
currentValue | 当前数组元素的值。 |
currentIndex | 当前数组元素的数字索引。 |
array | 包含该元素的数组对象。 |
示例:
let maxValue = data.reduce((prev, cur) => {
return prev.value > cur.value ? prev : cur
})
// maxValue = { value:3 }
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。
沃梦达教程
本文标题为:js如何查找json数据中的最大值和最小值方法
猜你喜欢
- 如何使用 JSON 格式的 jQuery AJAX 从 .cfm 页面输出查 2022-01-01
- addEventListener 在 IE 11 中不起作用 2022-01-01
- CSS媒体查询(最大高度)不起作用,但为什么? 2022-01-01
- 使用RSelum从网站(报纸档案)中抓取多个网页 2022-09-06
- 400或500级别的HTTP响应 2022-01-01
- Quasar 2+Apollo:错误:找不到ID为默认的Apollo客户端。如果您在组件设置之外,请使用ProvideApolloClient() 2022-01-01
- Css:将嵌套元素定位在父元素边界之外一点 2022-09-07
- 失败的 Canvas 360 jquery 插件 2022-01-01
- Flexslider 箭头未正确显示 2022-01-01
- Fetch API 如何获取响应体? 2022-01-01