您现在的位置是:网站首页> 编程资料编程资料
如何使用JavaScript快速创建一个1到100的数组_javascript技巧_
2023-05-24
436人已围观
简介 如何使用JavaScript快速创建一个1到100的数组_javascript技巧_
代码示例:
let arr = [] // push方法 for(let i = 1,len=100;i<=100;i++){arr.push(i)} // or //循环赋值 for(let i = 1,len=100;i<=100;i++){arr[i-1]=i} // Array.from()方法 后面会有一点点的优化 Array.from({length:101}, (v,k) => k)// or Array.from(Array(101), (v,k) =>k); Array.from(Array(101).keys()) arr.splice(0,1) // 使用递归实现 // 当前值 // 最大长度 let arr = [] function setArray(current,maxLength,arr){ if(arr.lengthi)// 去除假值 empty } } setArray(1,100,arr) // 暂且不知道有没有性能问题 // 在网上看到一些方法,也蛮好玩的,但是不知道来源 // 1 let arr = Array(100).toString().split(',').map((item,index)=>index)// 0-> 99 // 2 let i = 0; let timer = setInterval(function(){ arr[i] = i++; if(i>=100){ clearInterval(timer); console.log(arr); } },1); // 0-> 99 // 3 Object.keys(Array.apply(null, {length:100})).map(item=>+item);// 0-> 99 // 4 [...Array(100).keys()]// 0-> 99 [...Array.from({length:100}).keys()]// 0-> 99 // mdn 看见的 序列生成器(指定范围) const range = (start, stop, step) => Array.from({ length: (stop - start) / step + 1}, (_, i) => + (i * step)); range(1,100,1)// 1-> 100 //优化我上面写的 Array.from({length:100},(_, i)=>1+(i)) // 1-> 100 我觉得看起来最舒服的是: Array.from({length:100},(_, i)=>1+(i))
前提知识:
Array.from()
Array.from(arrayLike[, mapFn[, thisArg]])
arrayLike想要转换成数组的伪数组对象或可迭代对象。
mapFn可选如果指定了该参数,新数组中的每个元素会执行该回调函数。
thisArg可选可选参数,执行回调函数
mapFn时this对象。返回值
一个新的
数组实例。
用法:
- String 生成 数组
- Set 生成 数组
- Map 生成 数组
- 类数组 生成 数组
示例:从Map生成数组
const map = new Map([[1, 2], [2, 4], [4, 8]]); Array.from(map); // [[1, 2], [2, 4], [4, 8]] const mapper = new Map([['1', 'a'], ['2', 'b']]); Array.from(mapper.values()); // ['a', 'b']; Array.from(mapper.keys()); // ['1', '2'];
其他:
Array.from({length: 100}) or Array.from(Array(100)) // 都会生成 (100) [undefined,..., undefined] 数组实例方法keys()
keys()是ES6中新增的对键名的遍历,返回一个遍历器对象
apply(thisArg, [argsArray])
apply(thisArg, [argsArray])
参数
thisArg必选的。在
func函数运行时使用的this值。请注意,this可能不是该方法看到的实际值:如果这个函数处于非严格模式下,则指定为null或undefined时会自动替换为指向全局对象,原始值会被包装。
argsArray可选的。一个数组或者类数组对象,其中的数组元素将作为单独的参数传给
func函数。如果该参数的值为null或undefined,则表示不需要传入任何参数。从ECMAScript 5 开始可以使用类数组对象。返回值
调用有指定
this值和参数的函数的结果。
补充:js中实现随机获取1-100的不重复的数组
总结
到此这篇关于如何使用JavaScript快速创建一个1到100数组的文章就介绍到这了,更多相关JS快速创建1到100数组内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关内容
- vue中三种调用接口的方法_vue.js_
- vue 如何引入本地某个文件 require_vue.js_
- pm2与Verdaccio搭建私有npm库过程详解_node.js_
- Vue2和Vue3的10种组件通信方式梳理_vue.js_
- 微信小程序使用this.setData()遇到的问题及解决方案详解_javascript技巧_
- EasyUI使用DataGrid实现动态列数据绑定_jquery_
- 一文详解Pinia和Vuex与两个Vue状态管理模式_vue.js_
- rollup打包引发对JS模块循环引用思考_JavaScript_
- Vue3中插槽(slot)的全部使用方法_vue.js_
- vue原生input输入框原理剖析_vue.js_
