1 Star 0 Fork 0

math.most/js_study

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
011.1for循环.js 1.26 KB
一键复制 编辑 原始数据 按行查看 历史
math.most 提交于 2021-11-08 07:44 +08:00 . 查漏补缺01
/**
* for循环优化
*/
var arr = [1, 2, 3, 4, 5, 6, 7, 8, 9]
// 性能优化
// 1. 原for循环
for(var i = 0; i < arr.length; i++) {
// doSomething
}
arr.forEach((item)=> {
console.log("forEarch:" + item);
})
// 2. 迭代器
let iter = arr.keys()
console.log(iter.next()); // { value: 0, done: false }
for (const iterator of arr) {
console.log(iterator); // 1, 2, 3, 4, 5, 6, 7, 8, 9
}
let {done, values} = arr.entries().next()
console.log(done); // false
console.log(values); // undefined
// 3. every:判断元素是否都为真
let sources = [
{name: "张三", js: 80},
{name: "李四", js: 100},
{name: "王五", js: 50},
]
const res = sources.every((value)=> {
if(value >= 60) {
return true
}
})
console.log(res?"全部同学及格":"有同学未及格")
// 4. some: 元素有一个为真则返回真
// 5. filter
const filterRes = sources.filter((value, index, arrList) => {
return value.js > 80;
})
console.log(filterRes)
// 优化点一:将固定变量先写到内存,避免每次遍历都要读取一次数组属性
for(var i = 0, len = arr.length; i < len; i++) {
// doSomething
}
// 优化点二:算法
// 找出arr数组中相加为11的元素以及它们对应的索引
// 11 - item = 6 ? item.indexOf(): null
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
JavaScript
1
https://gitee.com/mathmost/js_study.git
git@gitee.com:mathmost/js_study.git
mathmost
js_study
js_study
master

搜索帮助