9个JavaScript日常开发小技巧
2024-10-09 20:19:31
1.生成指定范围的数字
在某些情况下,我们会创建一个处在两个数之间的数组。假设我们要判断某人的生日是否在某个范围的年份内,那么下面是实现它的一个很简单的方法
1
2
3
4
5
6
|
let start = 1900, end = 2000; [... new Array(end + 1).keys()].slice(start); // [ 1900, 1901, ..., 2000] // 还有这种方式,但对于很的范围就不太稳定 Array.from({ length: end - start + 1 }, (_, i) => start + i); |
2.使用值数组作为函数的参数
在某些情况下,我们需要将值收集到数组中,然后将其作为函数的参数传递。 使用 ES6,可以使用扩展运算符(...)并从[arg1, arg2] > (arg1, arg2)中提取数组:
1
2
3
4
5
6
7
|
const parts = { first: [0, 2], second: [1, 3], } [ "Hello" , "World" , "JS" , "Tricks" ].slice(...parts.second) // ["World", "JS"] |
3.将值用作 Math 方法的参数
当我们需要在数组中使用Math.max或Math.min来找到最大或者最小值时,我们可以像下面这样进行操作:
1
2
3
4
5
6
7
8
9
|
const elementsHeight = [...document.body.children].map( el => el.getBoundingClientRect().y ); Math.max(...elementsHeight); // 474 const numbers = [100, 100, -1000, 2000, -3000, 40000]; Math.min(...numbers); // -3000 |
4.合并/展平数组中的数组
Array 有一个很好的方法,称为Array.flat,它是需要一个depth参数,表示数组嵌套的深度,默认值为1。 但是,如果我们不知道深度怎么办,则需要将其全部展平,只需将Infinity作为参数即可
最新文章
- linux几种快速清空文件内容的方法
- [转]响应式WEB设计学习(1)—判断屏幕尺寸及百分比的使用
- ASP.NET MVC ActionFilterAttribute的执行顺序
- View、ViewGroup (转)
- python:用json把字典序列化到文件中
- C++语言中cin cin.getline cin.get getline gets getchar 的用法实例
- Android四大组件之BroadcastReceiver
- group by java实现
- [HNOI2012] 矿场搭建
- linux命令-查看当前目录下所有文件的大小:“ll -h”
- 棋盘上的距离 - Grids1657
- JUnit之断言assert
- 【Android Developers Training】 82. 序言:传输数据时减少对电池寿命的影响
- 【转】python XML 操作总结(创建、保存和删除,支持utf-8和gb2312)
- error_reporting
- SQL随记(二)
- [maven] dependency标签理解
- Element-table-formatter格式化数据
- Tensorflow函数:tf.zeros
- vim窗口切换
热门文章
- 【题解】[JSOI2007]字符加密
- Flutter沉浸式状态栏/AppBar导航栏/仿咸鱼底部凸起导航
- nginx完美支持thinkphp3.2.2(需配置URL_MODEL=>;1 pathinfo模式)
- 17.JAVA-常用总结
- C&C++代码单元集成测试培训
- MeteoInfoLab脚本示例:合并数组
- github 上传与删除项目
- 安装ipython
- 【转载】动态规划—各种 DP 优化
- 【KM算法】UVA 11383 Golden Tiger Claw