实际开发中一些实用的JS数据处理方法
写在开头
JavaScript
是一种脚本语言,最初是为了网页提供交互式前端功能而设计的
,而现在,通过 Node.js,JavaScript 还可以用于编写服务器端代码。
JavaScript 具有动态性、基于原型的面向对象特性、弱类型、多范式、支持闭包执行环境、支持函数式编程等特点,非常适合编写动态 Web 应用程序。
从语言发展的角度来看,JavaScript 已经成为了现代 Web 开发的核心技术之一。与此同时,JavaScript 的生态系统也在不断壮大,有众多的库和框架可供开发人员选择,包括 Vue.js、React、Angular 等,可以大大提高开发效率和质量。
综上,JavaScript 是一种非常灵活和易于使用的编程语言,适用于动态 Web 应用程序、桌面应用程序、移动应用程序等各种应用场景。它不仅具有良好的性能和可扩展性,还具有丰富的生态系统和强大的社区支持。
常见的一种数据结构:对象数组
对象数组是由多个对象组成的数组。每个对象都包含一些属性和对应的属性值。这些属性可以是字符串、数字、布尔值或其他对象等数据类型。
对象数组通常用于存储和处理相关数据集合。通过使用对象数组,可以轻松地访问和操作数据的各个部分。比如可以使用过滤、映射、排序、分组、聚合计
算等技巧,对对象数组中的数据进行加工,以生成需要的数据结构或满足特定业务需求。
例如,可以使用对象数组来存储员工信息,每个员工都是一个包含姓名、工号、职位等属性的独立对象。或者可以使用对象数组来存储电商订单信息,每个订单都是一个包含产品名称、价格、数量等属性的对象。
在 JavaScript
中,常见的对象数组处理方法有 map()、filter()、sort()、reduce()
等,可以大大简化对象数组的处理过程。总的来说,对象数组是 JavaScript
中常用的一种数据结构,广泛应用于各种应用程序场景。
一些案例参考
1. 数据过滤
在 JavaScript 中,filter()
是一种数组方法,它可以用于过滤一个数组并返回符合特定条件的项。filter()
方法会创建一个新数组,新数组中包含了满足过滤条件的原数组中的所有项。
filter()
方法接受一个回调函数作为参数,并且回调函数可以接受三个参数:当前元素、元素的索引、包含该元素的数组。回调函数应该返回一个布尔值,表示该元素是否应该包含在新数组中。如果回调函数返回 true
,则该元素会被包含在新数组中,否则就会被过滤掉。
以下是一些 filter()
方法的使用示例:
const fruits = ['apple', 'banana', 'orange', 'pear'];// 只保留长度大于 5 的项
const filteredFruits = fruits.filter(fruit => fruit.length > 5);
console.log(filteredFruits); // ['banana', 'orange']const numbers = [1, 2, 3, 4, 5];// 只保留奇数
const oddNumbers = numbers.filter(number => number % 2 !== 0);
console.log(oddNumbers); // [1, 3, 5]const users = [{ name: 'Tom', age: 18 },{ name: 'Lucy', age: 22 },{ name: 'Lily', age: 16 },{ name: 'Jim', age: 25 }
];// 只保留年龄大于 20 的用户
const adultUsers = users.filter(user => user.age > 20);
console.log(adultUsers); // [{ name: 'Lucy', age: 22 }, { name: 'Jim', age: 25 }]
总之,filter()
方法是一种非常有用的数组方法,可以帮助开发人员很容易地从一个数组中获取符合特定条件的项。
2. 数据映射
在 JavaScript 中,map()
方法是一种数组方法,它可以用于将数组中的每个元素应用于一个函数,并返回一个新的数组,新数组中的每个元素都是该函数的返回值。该方法不会改变原数组,而是返回一个新的数组。
map()
方法接受一个回调函数作为参数,并且回调函数可以接受三个参数:当前元素、元素的索引、包含该元素的数组。回调函数应该返回一个值,就是将该值添加到新数组中的元素的值。
以下是一些 map()
方法的使用示例:
const numbers = [1, 2, 3, 4, 5];// 将数组中的每个数字加倍
const doubledNumbers = numbers.map(number => number * 2);
console.log(doubledNumbers); // [2, 4, 6, 8, 10]const fruits = ['apple', 'banana', 'orange'];// 将每个水果名字变成大写字母
const uppercaseFruits = fruits.map(fruit => fruit.toUpperCase());
console.log(uppercaseFruits); // ['APPLE', 'BANANA', 'ORANGE']const users = [{ name: 'Tom', age: 18 },{ name: 'Lucy', age: 22 },{ name: 'Lily', age: 16 },{ name: 'Jim', age: 25 }
];// 获取所有用户的名字
const names = users.map(user => user.name);
console.log(names); // ['Tom', 'Lucy', 'Lily', 'Jim']
总之,map()
方法是一种非常实用的数组方法,可以将一个数组中的元素转换为新的元素,并返回一个基于原始数组的新数组。
3. 数据排序
const users = [{ name: 'Tom', age: 18 },{ name: 'Lucy', age: 22 },{ name: 'Lily', age: 16 },{ name: 'Jim', age: 25 },{ name: 'Bob', age: 30 }
];// 按照年龄从小到大排序
const sorted = users.sort((a, b) => a.age - b.age);
console.log(sorted); // [{ name: 'Lily', age: 16 }, { name: 'Tom', age: 18 }, { name: 'Lucy', age: 22 }, { name: 'Jim', age: 25 }, { name: 'Bob', age: 30 }]
在 JavaScript 中,sort()
方法是一种数组方法,它可以用于对数组进行排序操作,排序结果可以是升序或降序。sort()
方法按照 Unicode 编码顺序对数组中的元素进行排序,即默认情况下按照字符串形式排序。
sort()
方法返回一个排序后的数组。原始数组不被修改,而是返回一个新的排好序的数组。
sort()
方法可以接受一个可选的比较函数,用于指定排序规则。比较函数应该接受两个参数,代表要进行比较的两个元素,并返回一个数字表示它们的排序顺序。如果返回值为负数,则表示第一个元素应该排在第二个元素之前;如果返回值为正数,则表示第一个元素应该排在第二个元素之后;如果返回值为零,则表示两个元素相对位置不变。
以下是一些 sort()
方法的使用示例:
const numbers = [3, 8, 6, 1, 9];// 将数字数组进行升序排序
const ascendingNumbers = numbers.sort((a, b) => a - b);
console.log(ascendingNumbers); // [1, 3, 6, 8, 9]// 将数字数组进行降序排序
const descendingNumbers = numbers.sort((a, b) => b - a);
console.log(descendingNumbers); // [9, 8, 6, 3, 1]const fruits = ['apple', 'banana', 'orange'];// 将水果数组进行升序排序
const ascendingFruits = fruits.sort();
console.log(ascendingFruits); // ['apple', 'banana', 'orange']// 将水果数组进行降序排序
const descendingFruits = fruits.sort((a, b) => b.localeCompare(a));
console.log(descendingFruits); // ['orange', 'banana', 'apple']
总之,sort()
方法是一种功能丰富的数组方法,可以对数组进行排序操作,并支持自定义排序规则。
4. 数据聚合计算
const users = [{ name: 'Tom', age: 18, gender: 'male' },{ name: 'Lucy', age: 22, gender: 'female' },{ name: 'Lily', age: 16, gender: 'female' },{ name: 'Jim', age: 25, gender: 'male' },{ name: 'Bob', age: 30, gender: 'male' }
];// 按照性别分组
const grouped = users.reduce((result, current) => {(result[current.gender] = result[current.gender] || []).push(current);return result;
}, {});console.log(grouped);
/*
{male: [{ name: 'Tom', age: 18, gender: 'male' },{ name: 'Jim', age: 25, gender: 'male' },{ name: 'Bob', age: 30, gender: 'male' }],female: [{ name: 'Lucy', age: 22, gender: 'female' },{ name: 'Lily', age: 16, gender: 'female' }]
}
*/
const orders = [{ product: 'Apple', price: 10, count: 2 },{ product: 'Pear', price: 8, count: 3 },{ product: 'Banana', price: 6, count: 4 },{ product: 'Orange', price: 7, count: 5 }
];// 计算所有订单的总价格
const total = orders.reduce((result, current) => result + current.price * current.count, 0);
console.log(total); // 102
在 JavaScript 中,reduce()
方法是一种数组方法,它可以用于对数组中的元素逐个应用一个函数并将其结果汇总为单个值。该方法接受一个函数作为参数,并且该函数会接受一个累积值和当前迭代的元素,然后将这两个值组合为一个新的累积值。
reduce()
方法可以用于求和、计算平均值、计算最大值等各种操作。该方法的结果是最终的累积值,可以是数字、字符串或任何 JavaScript 数据类型。
以下是一些 reduce()
方法的使用示例:
const numbers = [1, 2, 3, 4, 5];// 计算数字数组中所有数字的和
const sum = numbers.reduce((accumulator, currentValue) => accumulator + currentValue, 0);
console.log(sum); // 15// 计算数字数组中所有数字的平均值
const average = numbers.reduce((accumulator, currentValue, index, array) => {accumulator += currentValue;if (index === array.length - 1) {return accumulator / array.length;} else {return accumulator;}
}, 0);
console.log(average); // 3const words = ['apple', 'banana', 'orange'];// 将所有单词合并为一个字符串
const mergedString = words.reduce((accumulator, currentValue) => accumulator + currentValue, '');
console.log(mergedString); // 'applebananaorange'
总之,reduce()
方法是一种非常实用的数组方法,可以对数组中的元素进行累积操作,并返回一个最终的累积值。
相关文章:

实际开发中一些实用的JS数据处理方法
写在开头 JavaScript 是一种脚本语言,最初是为了网页提供交互式前端功能而设计的,而现在,通过 Node.js,JavaScript 还可以用于编写服务器端代码。 JavaScript 具有动态性、基于原型的面向对象特性、弱类型、多范式、支持闭包执行…...

10:00进去,10:05就出来了,这问的也太变态了···
从外包出来,没想到死在另一家厂子了。 自从加入这家公司,每天都在加班,钱倒是给的不少,所以也就忍了。没想到5月一纸通知,所有人不许加班,薪资直降30%,顿时有吃不起饭的赶脚。 好在有个兄弟内推…...

GPT时代,最令人担心的其实是“塔斯马尼亚效应”
目录 教育到底教什么? 过度依赖GPT可能导致文明退化 GPT可以帮助人类破解“学海无涯极限”悖论 春季学期伊始,全球各地的老师们如临大敌,因为学生们带着ChatGPT杀过来了。Study.com的调研显示,每10个学生中就有超过9个知道Chat…...
基于容器技术和服务发现的全新大数据平台弹性伸缩方法
随着科技的不断发展,各个行业都在不断地数字化和智能化。在这个过程中,大数据技术成为了许多行业的重要支撑。而随着大数据技术的普及,行业分类和设备装置的不断更新换代,弹性伸缩成为了一个不可避免的问题。本文将介绍基于服务发…...
php8 match
刚从 php7 升级到 php8 时 我在使用 switch 语句,结果出现了一个提示: "switch statement can be converted to match expression" 翻译过来就是: switch语句可以转换为match表达式 我当时在想,match 应该是php8 的…...

ADS-B接收机Radarcape
1.设备简介 Radarcape是一款便携、高性能、功能强大的ADS-B地面接收机。Radarcape的设备清单包含:ADS-B接收机主机,专业级ADS-B天线,GPS天线,电源线,网线。 2. 功能特点 Radarcape可以通过网口输出飞机的原始数据D…...
软件测评师2012年下半年考试真题<更新中。。。>
1.2012 年下半年全国计算机技术与软件专业技术资格(水平)考试日期是 11月4号。 2.在 CPU 中,控制器 不仅要保证指令的正确执行,还要能够处理异常事件。 3.循环冗余校验码(CRC) 利用生成多项式进行编码。设数据位为 k 位…...

ChatGPT 使用 拓展资料:开始构建你的优质Prompt
ChatGPT 使用 拓展资料:开始构建你的优质Prompt...

Hystrix原理
一.概述 在软件架构领域,容错特指容忍并防范局部错误,不让这种局部错误不断扩大。我们在识别风险领域,风险可以分为已知风险和未知风险,容错直接应对的就是已知风险,这就要求针对的场景是:系统之间调用延时…...

内网外网分离模式下,通过网关转发,来部署前后端分离的系统
前言 最近为某银行系统部署了一套商城系统,网络环境比较特别,思路记录下,其中商场系统使用前后端分离模式部署。 该银行网络环境: 外网服务器:外网可以访问到它,不能访问外网。 网关服务器:跟…...

基于 Amazon API Gatewy 的跨账号跨网络的私有 API 集成
一、背景介绍 本文主要讨论的问题是在使用 Amazon API Gateway,通过 Private Integration、Private API 来完成私有网络环境下的跨账号或跨网络的 API 集成。API 管理平台会被设计在单独的账号中(亚马逊云科技提供的是多租户的环境),因为客观上不同业务…...
SSH远程连接时报错kex_exchange_identification: Connection closed by remote host
简介 在SSH服务器上进行远程内容时,会经常出现kex_exchange_identification: Connection closed by remote host内容,主要是由于远程计算机登录节点的数量限制问题。 解释 在 SSH 服务器上,最大并发登录会话数是由 ‘MaxSessions’ 参数来…...

一、CNNs网络架构-基础网络架构
目录 1.LeNet 2.AlexNet 2.1 激活函数:ReLU 2.2 随机失活:Droupout 2.3 数据扩充:Data augmentation 2.4 局部响应归一化:LRN 2.5 多GPU训练 2.6 论文 3.ZFNet 3.1 网络架构 3.2 反卷积 3.3 卷积可视化 3.4 ZFNet改…...
[开发|C++] C++的基本运算符说明笔记
基本运算符说明 C是一种功能强大的编程语言,提供了多种运算符来执行各种基本操作。下面是一些常见的C基本运算符及其说明: 算术运算符: :加法运算符,用于执行两个操作数的相加操作。 -:减法运算符…...
抖音定位功能的作用
随着智能手机和社交网络的普及,人们日常生活中对于位置信息的需求也越来越高。而抖音作为一款以短视频为主的社交应用,其定位技术也备受关注。本文将就抖音的定位功能进行探究,介绍抖音如何获取、处理和利用用户的位置信息,并探讨…...

阿里 P9 推荐的 Spring 领域巅峰之作,直接颠覆了我对 Spring 的认知
写在前面 你第一次接触 spring 框架是在什么时候?相信很多人和我一样,第一次了解 spring 都不是做项目的时候用到,而是在网上看到或者是听到过一个叫做 spring 的框架,这个框架号称完爆之前的 structs 和 structs2,吸…...

R语言结构方程模型(SEM)在生态学领域中的实践应用
结构方程模型(Sructural Equation Model)是一种建立、估计和检验研究系统中多变量间因果关系的模型方法,它可以替代多元回归、因子分析、协方差分析等方法,利用图形化模型方式清晰展示研究系统中变量间的因果网络关系,…...
Java设计模式-模板方法模式
简介 在软件开发中,设计模式是一种被广泛采用的方法,用于解决常见的设计问题。模板方法模式是其中一种重要的设计模式之一,它提供了一种将算法的结构骨架固定,但允许子类实现具体步骤的机制。 模板方法模式是一种行为型设计模式…...
Start JDKFlightRecorder--人工翻译
可以同时运行多个JFR记录,并且每个JFR记录都可以使用不同的配置,你可以使用不同的JFR记录去捕获不同的事件集。但是,为了使JFR内部逻辑更加精简,生成的记录始终包含当时活动的所有记录的所有事件的并集。这意味着,运行…...

Python3安装pyhanlp最佳解决方法
1、Hanlp介绍 Hanlp是一款中文自然语言处理工具。Hanlp支持多种自然语言处理任务,包括分词、词性标注、命名实体识别、依存句法分析、情感分析、文本分类等。其主要优点包括: 高准确率:Hanlp采用了基于神经网络的分词方法,有效提…...
浅谈 React Hooks
React Hooks 是 React 16.8 引入的一组 API,用于在函数组件中使用 state 和其他 React 特性(例如生命周期方法、context 等)。Hooks 通过简洁的函数接口,解决了状态与 UI 的高度解耦,通过函数式编程范式实现更灵活 Rea…...

19c补丁后oracle属主变化,导致不能识别磁盘组
补丁后服务器重启,数据库再次无法启动 ORA01017: invalid username/password; logon denied Oracle 19c 在打上 19.23 或以上补丁版本后,存在与用户组权限相关的问题。具体表现为,Oracle 实例的运行用户(oracle)和集…...
零门槛NAS搭建:WinNAS如何让普通电脑秒变私有云?
一、核心优势:专为Windows用户设计的极简NAS WinNAS由深圳耘想存储科技开发,是一款收费低廉但功能全面的Windows NAS工具,主打“无学习成本部署” 。与其他NAS软件相比,其优势在于: 无需硬件改造:将任意W…...

8k长序列建模,蛋白质语言模型Prot42仅利用目标蛋白序列即可生成高亲和力结合剂
蛋白质结合剂(如抗体、抑制肽)在疾病诊断、成像分析及靶向药物递送等关键场景中发挥着不可替代的作用。传统上,高特异性蛋白质结合剂的开发高度依赖噬菌体展示、定向进化等实验技术,但这类方法普遍面临资源消耗巨大、研发周期冗长…...
Leetcode 3577. Count the Number of Computer Unlocking Permutations
Leetcode 3577. Count the Number of Computer Unlocking Permutations 1. 解题思路2. 代码实现 题目链接:3577. Count the Number of Computer Unlocking Permutations 1. 解题思路 这一题其实就是一个脑筋急转弯,要想要能够将所有的电脑解锁&#x…...
反射获取方法和属性
Java反射获取方法 在Java中,反射(Reflection)是一种强大的机制,允许程序在运行时访问和操作类的内部属性和方法。通过反射,可以动态地创建对象、调用方法、改变属性值,这在很多Java框架中如Spring和Hiberna…...
Unit 1 深度强化学习简介
Deep RL Course ——Unit 1 Introduction 从理论和实践层面深入学习深度强化学习。学会使用知名的深度强化学习库,例如 Stable Baselines3、RL Baselines3 Zoo、Sample Factory 和 CleanRL。在独特的环境中训练智能体,比如 SnowballFight、Huggy the Do…...

云原生玩法三问:构建自定义开发环境
云原生玩法三问:构建自定义开发环境 引言 临时运维一个古董项目,无文档,无环境,无交接人,俗称三无。 运行设备的环境老,本地环境版本高,ssh不过去。正好最近对 腾讯出品的云原生 cnb 感兴趣&…...
#Uniapp篇:chrome调试unapp适配
chrome调试设备----使用Android模拟机开发调试移动端页面 Chrome://inspect/#devices MuMu模拟器Edge浏览器:Android原生APP嵌入的H5页面元素定位 chrome://inspect/#devices uniapp单位适配 根路径下 postcss.config.js 需要装这些插件 “postcss”: “^8.5.…...
LangChain知识库管理后端接口:数据库操作详解—— 构建本地知识库系统的基础《二》
这段 Python 代码是一个完整的 知识库数据库操作模块,用于对本地知识库系统中的知识库进行增删改查(CRUD)操作。它基于 SQLAlchemy ORM 框架 和一个自定义的装饰器 with_session 实现数据库会话管理。 📘 一、整体功能概述 该模块…...