const students=[39;张三','李四','王五','陈六']//数组长度console.log(students.length)//第一个元素console.log(students[0])//第二个元素console.log(students[1])//末了一个元素console.log(students[students.length-1])
4.修正数组元素
数组里面的元素是可以改变的,将数据赋值给对应的数组下标后值会变为新授予的值
const number=[1,2,3,4,5]//第一个值改成10number[0]=10//末了一个值改成50number[number.length-1]=50console.log('number',number)
5.数组常见方法布局器方法 用于创建数组
//长度8没有元素的数组const eigthEmptyArry=Array(8)console.log(eigthEmptyArry)
fill方法 数组进行添补固定的值 (可以再加两个参数,分别表示添补的起始和结束下标,但不添补结束下标该位置的值)
const eightValueArray=Array(8).fill("x")console.log(eightValueArray)//['x', 'x', 'x', 'x', 'x', 'x', 'x', 'x']const fillArray=['a','b','c','d','e']//b,c,d更换为xfillArray.fill('x',1,4)console.log(fillArray)
concat方法 连接两个或多个数组 天生一个新数组 不改变原来的数组
const a1=['a','b','c']const a2=['d','e','f']// 连接两个数组let c=a1.concat(a2)console.log(c)const a3=['g','h']//连接多个数组let c2=a1.concat(a2,a3)console.log(c2)
indexOf 方法 查看元素是否在数组内,在的话返回下标,不在返回-1
const colors=['red','yellow','orange']console.log(colors.indexOf('yellow'))//1console.log(colors.indexOf('blue'))//-1
lastIndexOf方法 查找元素数组末了涌现的下标,没有返回-1
const ages = [20, 14, 30, 20, 50, 26]console.log(ages.lastIndexOf(20))//3console.log(ages.lastIndexOf(70))//-1
includes方法 数组是否包含某个元素 包含返回true 不包含返回false
const fruits = ['banana', 'apple', 'pear']console.log(fruits.includes('apple'))//trueconsole.log(fruits.includes('pineapple'))//false
isArray方法 判断某个工具是否是数组 是返回true 不是返回false
const ar = [100, 200]console.log(Array.isArray(ar))//trueconst str = 'haha'console.log(Array.isArray(str))//false
toString方法 数组转为字符串
const ns = [1, 2, 3, 4]console.log(ns.toString())//1,2,3,4
join方法 将数组拼接后以字符串返回,默认,(英文逗号)拼接
const teachers = ['李老师', '苍老师', '刘老师']console.log(teachers.join()) //李老师,苍老师,刘老师console.log(teachers.join("|")) //李老师|苍老师|刘老师console.log(teachers.join(" $ ")) //李老师 $ 苍老师 $ 刘老师
slice方法 返回数组中的begin到end(不含end)位置元素组成的新数组 原数组不改变
const m = [1, 2, 3, 4, 5]console.log(m.slice()) //[1,2,3,4,5]console.log(m.slice(0)) //[1,2,3,4,5]console.log(m.slice(0, m.length)) //[1,2,3,4,5]console.log(m.slice(1, 4))//[2,3,4]
splice方法 删除数组元素并可以添加元向来修正原数组 会改变原数组 参数 1-删除元素的起始位置 2-删除的数量 3..-从删除的地方开始添加的元素
const n = [1, 2, 3, 4, 5]n.splice(0, 1, 6, 6)console.log(n) //[6, 6, 2, 3, 4, 5]let spliceArr = [1, 2, 3, 4, 5]spliceArr.splice(3, 3, "一", "二", "三")console.log(spliceArr) //[1, 2, 3, '一', '二', '三']
push 从数组末端添加元素 pop 从数组末端移出元素
//pushconst arr = ['张飞', '刘备']arr.push('关羽')console.log(arr) //['张飞', '刘备', '关羽']//popconsole.log(arr.pop()) //关羽console.log(arr) //['张飞','刘备']
unshift 从数组开头添加元素 shift 从数组开头移出元素
//shift unshiftconst p = [1, 2, 3, 4, 5]console.log(p.shift()) //1console.log(p) // [2, 3, 4, 5]p.unshift(1)console.log(p)//[1, 2, 3, 4, 5]
reverse 翻转数组 会改变原数组
//reverseconst a = [2, 4, 6, 8, 10]a.reverse()console.log(a)// [10, 8, 6, 4, 2]
sort 数组排序 默认会把元素转为字符串进行排序 可以传入比较的函数自定义排序规则 会改变原数组
//sortconst webTec = ['html', 'javascript', 'css']webTec.sort()console.log(webTec) //['css', 'html', 'javascript']
二维数组 数组中的元素也可以是数组
const girls = ['lily', 'nami']const boys = ['张三', '李四']const all = [girls, boys]console.log(all.length) //2console.log(all[0]) // ['lily', 'nami']console.log(all[1]) //['张三', '李四']