强化JS基础水平的10个单行代码来喽!(必看)

news2024/11/15 3:53:49

目录

 生成数组

数组简单数据去重

多数组取交集

重新加载当前页面

滚动到页面顶部

查找最大值索引

进制转换

文本粘贴

删除无效属性

随机颜色生成


生成数组

当你需要要生成一个0-99的数组

// 生成一个0-99的数组
// 方案一
const createArr = n => Array.from(new Array(n), (v, i) => i);
const arr = createArr(100);
console.log(arr, "------------");
// 方案二 利用fill填充和map改变数组
const createArr1 = n => new Array(n).fill(0).map((v, i) => i);
const arr1 = createArr1(100);
console.log(arr1, "------------");

Array.from() 是 ECMAScript 6 中新增的一个方法,它可以从类数组对象或可迭代对象(如字符串、Set、Map、NodeList 等)创建一个新的数组实例。

举例如下:

// 从类数组对象创建数组
let arrayLike = {0: 'a', 1: 'b', 2: 'c', length: 3};
let arr = Array.from(arrayLike);
console.log(arr); // 输出: ["a", "b", "c"]

// 从 NodeList 创建数组
let divs = document.querySelectorAll('div');
let divArray = Array.from(divs);
console.log(divArray.length); // 输出: 找到的div元素数量

// 同时使用映射函数
let numbers = Array.from([1, 2, 3, 4], x => x * 2);
console.log(numbers); // 输出: [2, 4, 6, 8]

数组简单数据去重

当你需要将数组中的所有重复的元素只保留一个

// 去重
const removeData = list => [...new Set(list)];
console.log(removeData([0, 0, 1, 2, 1, 3, 5, 2]), "------------");

 

Set是es6新增的数据结构,似于数组,但它的一大特性就是所有元素都是唯一的,没有重复的值,我们一般称为集合。

也可以对对象数组进行去重,使用Set数据结构去除重复对象:new Set(strings)进行转型。

  • 但是因为它是一个类似数组结构,所以需要转型为真正的数组去使用。所以需要用Array.from。
  • 注:如果里面不是一个string类型,而是对象不会去重
  • 因此需要对里面的对象数据都转为string类型,去重后再转parse
const list =[
    { name: "张三", age: 18, address: "北京" },
    { name: "李四", age: 20, address: "天津" },
    { name: "张三", age: 18, address: "北京" },
]
 
const strings = list.map((item) => JSON.stringify(item)) // 1、转化成string类型
const removeDupList = Array.from(new Set(strings))  // 2、转化为真正的数组
const result = removeDupList.map((item) => JSON.parse(item)) // 3、字符串类型转化为对象类型
console.log('数组去重',result)  // [{name: '张三', age: 18, address: '北京'}, {name: '李四', age: 20, address: '天津'}]

多数组取交集

当你需要取多个数组中的交集

// 多数组取交集
const intersection = (a, ...arr) => {
  return [...new Set(a)].filter(v => arr.every(b => b.includes(v)));
};
intersection([1, 2, 3, 4], [2, 3, 4, 7, 8], [1, 3, 4, 9]);

 

web

重新加载当前页面

const reload = () => location.reload();
reload()

滚动到页面顶部

如果你需要将页面翻到最顶部

const goToTop = () => window.scrollTo(0, 0);
goToTop(

查找最大值索引

但你需要找到一个数组中的最大值的索引

const indexOfMax = arr => arr.reduce((prev, curr, i, a) => (curr > a[prev] ? i : prev));
indexOfMax([1, 3, 4, 7, 5]); // 2
console.log(indexOfMax([1, 3, 4, 7, 5]), "------------");

参数: 
 参数一: callback 函数(执行数组中每个值的函数,包含四个参数):

  •     prev 必需 (上一次调用回调返回的值,或者是提供的初始值(initialValue))
  •     cur 必需(数组中当前被处理的元素)
  •     index 可选 (当前元素在数组中的索引)
  •     arr 可选 (调用 reduce 的数组)

参数二:initialValue 可选 (表示初始值,作为第一次调用 callback 的第一个参数。)

  •     提供初始值,cur 从数组第一项开始,若不提供初始值,则 cur 从第二项开始执行,对应的第一次 prev 是数组第一项的值 

reduce()方法可以搞定的东西特别多,就是循环遍历能做的,reduce都可以做,比如数组求和、数组求积、统计数组中元素出现的次数、数组去重等等。

reduce() 方法对数组中的每个元素执行一个由您提供的reduce函数(依次执行),将其结果汇总为单个返回值。

进制转换

将10进制转换成n进制,可以使用toString(n)

const toDecimal = (num, n = 10) => num.toString(n);
// 假设数字10要转换成2进制
toDecimal(10, 2); // '1010'
console.log(toDecimal(10, 2), "------------");

将n进制转换成10进制,可以使用parseInt(num, n)

const toDecimalism = (num, n = 10) => parseInt(num, n);
toDecimalism(1010, 2);
console.log(toDecimalism(1010, 2), "------------");

 

文本粘贴

当你需要复制文本到粘贴板上

const copy = (text) => navigator.clipboard?.writeText && navigator.clipboard.writeText(text)
copy('你需要粘贴的文本')

删除无效属性

当你需要删除一个对象中的属性值为null或undefined的所有属性


const removeNullUndefined = (obj) => Object.entries(obj).reduce((a, [k, v]) => (v == null ? a : ((a[k] = v), a)), {});

removeNullUndefined({name: '', age: undefined, sex: null}) // { name: '' }

 上面一长串连体写法可能不易懂,我拆分了一下,等价于下面写法

const removeNullUndefined = obj =>
  Object.entries(obj).reduce((a, [k, v]) => {
    if (v == null) { //console.log( undefined == null ) //true因此这里只需要判断null即可
      return a;
    } else {
      a[k] = v;
      return a;
    }
  }, {});
  console.log(removeNullUndefined({ name: "1", age: undefined, sex: null }), "------------");

 

console.log( undefined == null ) //true

原因:

        null 和 undefined都代表着无效的值。

        规范中提到, 要比较相等性之前,不能将 null 和 undefined 转换成其他任何值,并且规定null 和 undefined 是相等的。

console.log( undefined === null ) //false

全等于状态下,是false,这个很好理解了。它们不属于同一数据类型。

        typeof null  // object

        typeof undefined  // undefined

随机颜色生成

当你需要获取一个随机颜色

const getRandomColor = () => `#${Math.floor(Math.random() * 0xffffff).toString(16)}`;
getRandomColor(); // '#4c2fd7'

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1982362.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何提高企业在 EcoVadis 审核中的得分?

要提高企业在 EcoVadis 审核中的得分,可以考虑以下几个方面: 建立完善的企业社会责任管理体系 制定明确的 CSR 政策和目标,并将其融入企业的战略规划。 设立专门的 CSR 管理团队或岗位,负责统筹和推进相关工作。 环境方面 制定并…

C语言进阶(1)·

1.数据类型 (1)整形类型有 char 向内存申请1个字节空间,反映char能访问的权限是一个字节,char分为 unsigned char和signed char两种类型在无特殊声明的情况下默认是那种类型取决于编译器(VS是signed char),由于cha…

sqli靶场复现(1-7关)

1.sqli-labs第一关(字符型注入) 1.1判断是否存在sql注入 1.提示你输入数字值的ID作为参数,我们输入?id1 2.在数据库可以查看到users下的对应内容 1.2联合注入 1.首先知道表格有几列,如果报错就是超过列数,如果显示正…

C语言 | Leetcode C语言题解之第319题灯泡开关

题目: 题解: int bulbSwitch(int n) {return sqrt(n 0.5); }

Imatest测试gamma时,不跳出文件保存页面

1.问题背景: 用工具测试灰阶卡gamma时,点击计算后,保存文件的这个页面跳不出来。 2.问题排查: 根据imatest的使用教程检查步骤设置,发现这个红框地方被勾选中: 给它勾掉,然后拉bar选择“20 p…

如何确保精益转型的成果得到长期保持?

近年来,企业纷纷踏上精益转型之路,以求通过优化流程、提升效率、增强竞争力,实现可持续发展。然而,转型易,守成难。如何在精益转型后,确保这些宝贵的成果能够长期保持并持续增值,成为众多企业关…

Python数值计算(20)——自然三次样条曲线

前面介绍到紧固三次样条曲线,这次介绍一下自然三次样条曲线。 1. 数学知识 这个在前面已经做过介绍,这里再次重复说明一遍,它对我们算法实现具有很大的帮助: 同样的,就是各分段起点的函数值,通过上述方程…

Goland Debug大全

记录goland debug过程中遇到的所有问题,有一些是其他博主的总结 1. Debug模式功能 2. 去掉GoLand中的所有断点 调试时点击下图箭标所指的按钮 选中需要删除的断点,点击左上角的减号,然后保存

Java中使用OpenCV生成灰度图

一、下载OpenCV、 下载链接:Releases - OpenCV 下载到指定目录后双击即可安装(正常下载过程)。 二、查看文件目录 1、找到opencv-4100.jar 找到opencv-4100.jar,这个是我们需要加载的包。 opencv-460.jar是给java操作openvc的程序…

Java所需要的环境以及jdk安装

jvm和跨平台 jvm(java虚拟机):java运行程序的假想计算机,主要用来运行java程序的 跨平台:java代码可以在不同的操作系统上运行(一次编写,到处运行) 跨:跨越 平台:操作系统 -> windows linux mac os 关系:java程序想要在不同的操作系统上运行,实现跨平台,就需要安装不同版本…

C# Unity 面向对象补全计划 七大原则 之 开闭原则(OCP) 难度:☆ 总结:已经写好的就别动它了,多用继承

本文仅作学习笔记与交流,不作任何商业用途,作者能力有限,如有不足还请斧正 本系列作为七大原则和设计模式的进阶知识,看不懂没关系 请看专栏:http://t.csdnimg.cn/mIitr,查漏补缺 1.开闭原则(OC…

【Python】成功处理`load_boston` has been removed from scikit-learn since version 1.2.

【Python】成功处理load_boston has been removed from scikit-learn since version 1.2. 下滑即可查看博客内容 🌈 欢迎莅临我的个人主页 👈这里是我静心耕耘深度学习领域、真诚分享知识与智慧的小天地!🎇 🎓 博主…

文件夹提示无法访问:深入解析与高效恢复策略

在数字化时代,文件夹作为我们存储、整理和保护重要数据的关键容器,其稳定性和可访问性对于个人工作、学习乃至企业运营都至关重要。然而,当您试图访问某个文件夹时,却遭遇“无法访问”的提示,这无疑会给您带来不小的困…

浅谈线程组插件之jp@gc - Stepping Thread Group

浅谈线程组插件之jpgc - Stepping Thread Group jpgc - Stepping Thread Group 是一个高级线程组插件,专为Apache JMeter设计。相较于JMeter自带的基本线程组,此插件提供了更灵活、更精细的用户模拟方式,特别适合于模拟真实用户逐步增加的场…

开关电源之电压的影响因素和指标

开关电源并不是一个简单的小盒子,它相当于有源器件的心脏,不断地为元件提供能量。电源质量的好坏直接影响到元器件的性能。开关电源的设计、制造和质量管理需要精密的电子仪器来模拟电源的实际工作特性(即各种规格),经…

5_现有网络模型的使用

教程:现有网络模型的使用及修改_哔哩哔哩_bilibili 官方网址:https://pytorch.org/vision/stable/models.html#classification 初识网络模型 pytorch为我们提供了许多已经构造好的网络模型,我们只要将它们加载进来,就可以直接使…

【CONDA】库冲突解决办法

如今,使用PYTHON作为开发语言时,或多或少都会使用到conda。安装Annaconda时一般都会选择在启动终端时进入conda的base环境。该操作,实际上是在~/.bashrc中添加如下脚本: # >>> conda initialize >>> # !! Cont…

python:YOLO格式数据集图片和标注信息查看器

作者:CSDN _养乐多_ 本文将介绍如何实现一个可视化图片和标签信息的查看器,代码使用python实现。点击下一张和上一张可以切换图片。 文章目录 一、脚本界面二、完整代码 一、脚本界面 界面如下图所示, 二、完整代码 使用代码时&#xff0…

无线WiFi破解原理(超详细)

大家应该都有过这样的经历,就是感觉自己家的无线网怎么感觉好像变慢了,"是不是有人蹭我家网?""还有的时候咱们出门也想试图蹭一下别人家的网",这里"蹭网"的前提是要破解对方的"无线密码"…

SQL注入复现1-18关

一、联合查询(1-4关) 首先打开第一关查看源代码,他的闭合方式为 找到闭合方式后,我们就可以使用order by来确定列数 我们可以看到使用order by 4--回车时报错,使用order by 3--时显示,所以我们就得到他得列…