对象进阶
1.this
构造函数里面的this,用于给类定义成员(属性和方法)
方法里面的this,指向方法的调用者
箭头函数中没有this,如果在箭头函数中使用了this,会向外层寻找this的指向
如果所有的外层都没有this,最终会指向window对象
注意:用于var定义的成员(变量和方法)都会成为window对象的成员
解决this指向问题:
方式一:备份this
方式二:使用箭头函数
2.call apply bind
call apply bind 更改方法里面this的指向
使用call()改变方法里面,this的指向
call()方法的第一个参数必须是指定的对象,方法的原有参数,挨个放在后面
使用apply(),也可以改变方法里面this的指向,第一个参是指定的对象,方法的原有参数,统一放到第二个数组参数中。
使用bind(),也可以改变方法里面this的指向,用法给call()一样
call()是直接运行方法,bind()是返回新的方法,然后再重新调用。
3.将一个对象转为字符串
获取对象的属性值,有两种方式:
对象名.属性名
对象名["属性名"]
//定义一个手机对象letphone={name:"小米10",color:'红色',size:'1000*200*500',price:'2999'}//转成下面的字符串//"name=小米10&color=红色&size=1000*200*500&price=2999"
for in 循环,可以循环出对象里面的所有的key,(key就是属性名)
在ES6中新增了获取对象所有key的方法 -> ECMAScript2015 其实就是最新版本的javascript标准
Object.keys(指定的对象),该方法可以获取指定对象的所有key,返回值是一个数组
Object.values(指定的对象),该方法可以获取指定对象的所有的value,返回值是一个数组
4.将字符串转为对象
//定义一个字符串letstr="name=小米10&color=红色&size=1000*200*500&price=2999"//转成一个对象{name:"小米10",color:'红色',size:'1000*200*500',price:'2999'}