ES6中Array对象的方法和扩展、string的扩展方法、数组的遍历。(含例题)

简介: 学习ES6中Array对象的方法和扩展、string的扩展方法、数组的遍历。

目录


一、Array对象方法


1.Array.from():将伪数组或可遍历对象转换为真正的数组(字符串,对象,类数组,set,map等)


2.array.find():返回数组符合条件的第一个元素的值(数组与对象)


3.array.findindex():找出符合条件的成员的位置。


4.array.includes():找出某个数组是否包含给定的值。


二、Array扩展


1.array.map()  返回新数组


2. array.filter() 过滤


3.array.reduce() 缩减


4.array.fill() 填充


三、string扩展


1.模板字符串的用法


2.startsWith和endsWith用法


3.repeat字符串重复次数


四、数组的遍历


1.for of遍历数组的值


2.for in 遍历索引


3.for of 遍历对象


4.forEach的用法


五、例题


1.找到一组同学中考试分数及格的第一个同学并输出到页面上。


2.找出大于指定年龄(页面input框接收)的第一个人,并输出这个人的位置。


3.一组人员信息,输出到页面上显示。


4.输出一组人员信息,输出到页面信息如下(姓名,分数,是否及格60分)。


一、Array对象方法


1.Array.from():将伪数组或可遍历对象转换为真正的数组(字符串,对象,类数组,set,map等)

let str = '1234';
const arr1 =Array.from(str);
console.log(arr1);//(4) ['1', '2', '3', '4']
const Arr = {
      2:'a',
      3:'b',
      length:4,
}
console.log(Array.from(Arr));// (4) [undefined, undefined, 'a', 'b']


2.array.find():返回数组符合条件的第一个元素的值(数组与对象)

const arr = [1,2,3,4];//数组
let num = arr.find(item=>item==3);
console.log(num);//3
const arr1 = [    //对象
  {realname:"张三1",age:18},
  {realname:"张三2",age:17},
  {realname:"张三3",age:19},
  {realname:"张三4",age:17},
    ];
console.log(arr1.find(item=>item.age==17));//age: 17 realname: "张三2"


3.array.findindex():找出符合条件的成员的位置。

const arr = [1,2,3,4]; //数组
console.log(arr.findIndex(item=>item==4)); //3
const arrobj = [    //对象
  {realname:"张三1",age:18},
  {realname:"张三2",age:19},
  {realname:"张三3",age:15},
  {realname:"张三4",age:14},
    ]
console.log(arrobj.findIndex(item=>item.age==19)); //1


4.array.includes():找出某个数组是否包含给定的值。

const arr = [1,2,3,4];
console.log(arr.includes(10));//有就返回true 没有就返回false


二、Array扩展


1.array.map()  返回新数组

const arr = [1,2,3,4];
const newarr = arr.map(item=>item+2);
console.log(newarr); //从新输出一个数组,不是改变原的数组


2. array.filter() 过滤

const arr = [1,2,3,4,5,6,7];
const newarr = arr.filter(item=> item%2==0);
console.log(newarr);

3.array.reduce() 缩减

//total:即是初始值又是返回值
//currentValue:当前值
reduce第二个参数指定初始值
const arr = [1,2,3,4,5];
let sum = arr.reduce((total,currentValue)=>{
    return total + currentValue;
},10) //可以指定初始值
console.log(sum);


4.array.fill() 填充

let arr = [1,2,3,4,5,6,7];
  arr.fill('x',1,3);
  console.log(arr);//[1, 'x', 'x', 4, 5, 6, 7]


三、string扩展

1.模板字符串的用法

function demo(){
  return "end";
    }
let es6 = "es6!";
let str = `hello,${es6},${demo()}`;
console.log(str);//hello,es6,end


2.startsWith和endsWith用法

let str = "hello,es6!";
console.log(str.startsWith("hello"));//判断某个字符串前面是否包含hello 有就为true
console.log(str.endsWith("es6!"));//判断某个字符串后面是否包含es6 有就为true


3.repeat字符串重复次数

console.log("hello".repeat(4));//hellohellohellohello


四、数组的遍历


1.for of遍历数组的值

const arr = ["a","b","c","d"];
   for(v of arr){
        console.log(v); //a,b,c,d
}


2.for in 遍历索引

const arr = ["a","b","c","d"];
    for(let k in arr){
     console.log(k); //0,1,2,3
        }


3.for of 遍历对象

 

const Person={realname:'zs',age:20}
   const keys = Object.keys(Person);
   for(let k of keys){
   console.log(`k:${k}`,`v:${Person[k]}`)}; //k:realname v:zs k:age v:20


4.forEach的用法

let arr = [1,2,3,4];
  arr.forEach((item,index)=>{
  console.log(`v:${item},k:${index}`);  
    })  //v:1,k:0  v:2,k:1 v:3,k:2 v:4,k:3


五、例题

1.找到一组同学中考试分数及格的第一个同学并输出到页面上。

<ul class="score"></ul> 
    <hr>
    <h1 class="username"></h1>
    <script>
        let person=[
            {realname:'张三',score:'40'},
            {realname:'李四',score:'40'},
            {realname:'王五',score:'60'},
            {realname:'赵六',score:'90'}
        ]
        let str = '';
        let userName='';
        for(i=0;i<person.length;i++){
            str = str + `<li>姓名:${person[i].realname},分数:${person[i].score}</li>`
        }
        document.querySelector('.score').innerHTML=str;
        userName = person.find(item=>item.score>=60)
        document.querySelector('.username').innerHTML=`姓名:${userName.realname},分数:${userName.score}`
    </script>


2.找出大于指定年龄(页面input框接收)的第一个人,并输出这个人的位置。

<ul class="age"></ul>
    <hr>
    <input type="text" placeholder="请输入年龄" value="" class="mark">
    <input type="button" value="查询" class="btn">
    <h1></h1>
    <script>
        let person=[
            {realname:'张三',age:'15'},
            {realname:'李四',age:'18'},
            {realname:'王五',age:'19'},
            {realname:'赵六',age:'20'}
        ]
        let str = '';
        for(i=0;i<person.length;i++){
            str = str + `<li>姓名:${person[i].realname},分数:${person[i].age}</li>`
        }
        document.querySelector('.age').innerHTML=str;
        btn = document.querySelector('.btn')
        btn.onclick=function(){
            let num;
            input=document.querySelector('.mark').value;//获得输入的值
            num = person.findIndex(item=>item.age==input)//得到下标
            if(num==-1){
            document.querySelector('h1').innerHTML='查无此人';
            }else{
                num++;
            document.querySelector('h1').innerHTML=`位置是${num}`
            }
        }
    </script>


3.一组人员信息,输出到页面上显示。

let arr =[
            {realname:'zs',birthday:'2000 10-5'},
            {realname:'zs',birthday:'2009 10-5'},
            {realname:'zs',birthday:'2001 10-5'},
            {realname:'zs',birthday:'2005 10-5'}
        ]
        let newarr = arr.map((item)=>{
            let newyear = new Date().getFullYear();
            item[`age`]=newyear-item.birthday.slice(0,4)
            return item;
        })
        let newarr1 = arr.filter(item=>item.age>20)
        console.log(newarr);
        console.log(newarr1);


4.输出一组人员信息,输出到页面信息如下(姓名,分数,是否及格60分)。

const person=[
            {realname:'zs1',age:20,score:50},
            {realname:'zs2',age:20,score:70},
            {realname:'zs3',age:20,score:80},
            {realname:'zs4',age:20,score:90}
        ]
    // 使用 for of 将内容显示在网页上
    // let arr='';
    // for(let v of person){
    //      arr =arr+ `<li>姓名:${v.realname},年龄:${v.age}</li>`
    // }
    // document.querySelector('ul').innerHTML=arr;
    let mark='';
    let newarr = person.filter(item=>{
    let rer= item.score>60?'及格':'不及格'
    mark+=`<li>姓名:${item.realname},年龄:${item.age},分数:${item.score},${rer}</li>`
    })
      document.querySelector('ul').innerHTML=mark;


相关文章
|
1月前
|
Java
【编程基础知识】(讲解+示例实战)方法参数的传递机制(值传递及地址传递)以及String类的对象的不可变性
本文深入探讨了Java中方法参数的传递机制,包括值传递和引用传递的区别,以及String类对象的不可变性。通过详细讲解和示例代码,帮助读者理解参数传递的内部原理,并掌握在实际编程中正确处理参数传递的方法。关键词:Java, 方法参数传递, 值传递, 引用传递, String不可变性。
56 1
【编程基础知识】(讲解+示例实战)方法参数的传递机制(值传递及地址传递)以及String类的对象的不可变性
|
17天前
|
JavaScript 前端开发 开发者
|
1月前
|
存储 JavaScript 前端开发
JavaScript Array(数组) 对象
JavaScript Array(数组) 对象
27 3
|
1月前
|
存储 JavaScript 前端开发
JavaScript 字符串(String) 对象
JavaScript 字符串(String) 对象
43 3
|
3月前
|
JavaScript 算法 前端开发
JS算法必备之Array常用操作方法
这篇文章详细介绍了JavaScript中数组的创建、检测、转换、排序、操作方法以及迭代方法等,提供了数组操作的全面指南。
JS算法必备之Array常用操作方法
|
2月前
|
JavaScript 前端开发
JavaScript Array map() 方法
JavaScript Array map() 方法
|
3月前
|
存储 程序员 API
八股day05_API、String对象和集合
day05_API、String对象和集合
|
3月前
|
JavaScript 前端开发
JavaScript基础&实战(5)js中的数组、forEach遍历、Date对象、Math、String对象
这篇文章介绍了JavaScript中的数组、Date对象、Math对象以及包装类(String、Number、Boolean),并详细讲解了数组的创建、方法(如forEach、push、pop、unshift、slice、splice)和遍历操作,以及工厂方法创建对象和原型对象的概念。
JavaScript基础&实战(5)js中的数组、forEach遍历、Date对象、Math、String对象
|
3月前
|
存储 Java
构造String问题之在JDK 9及更高版本中,直接访问String对象的coder和value属性,如何实现
构造String问题之在JDK 9及更高版本中,直接访问String对象的coder和value属性,如何实现
|
4月前
|
索引

热门文章

最新文章

下一篇
无影云桌面