JS中的静态属性及实例属性

JavaScript022

JS中的静态属性及实例属性,第1张

在回忆怎么判断一个对象是一个数组的方法时,想到了Array.isArray()这个方法,突然有点不理解,这是什么意思,isArray()怎么可以通过Array直接调用,这样的情况很多,比如Object上的方法。

看了几篇文章,简单理解是:JS中有“静态属性”和实例属性。

定义在构造函数上的属性。只能通过构造函数名来调用。

那么就是说,上面的setName方法可以通过Person来调用,不能通过实例调用。因为setName是其内部方法。 举个例子:

通过打印p,可以看到:

可以发现,myName和getAge属性并没有被实例所继承。

我的理解是: 定义在构造函数原型上的属性及在构造函数内部绑定到this上的属性。这些属性可以通过实例对象直接调用。

这个时候,p可以调用name,age,getName这些属性。

可以通过Object.getOwnpropertyNames()等此类方法查看有哪些属性。

arguments对象:函数内部对象,传入函数中所有参数的集合,类数组对象

属性:callee 指针,指向拥有这个arguments对象的函数 作用:解耦

例子:迭代

function factorial(num) {

if(num<=1){

return 1

}else{

return ( num*arguments.callee(num-1))

}

}

console.log(factorial(4))//24

this对象:函数内部对象,引用的是函数执行的环境对象 在全局作用域执行函数时this为全局对象(window)

window.color='red'

var o={color:'blue',}

function sayColor(){alert(this.color)}

sayColor()//red

o.sayColor=sayColor

0.sayColor()//blue 看this引用的谁

caller属性:指向调用当前函数的函数保存着调用当前函数的函数的引用

function a(){

b()

}

function b(){

alert(b.caller)

}

b()//输出a函数体

apply()和call(): 作用:修改函数this的指向(修改上下文),拓展函数的作用域,对象与方法解耦 区别:传参 apply(要修改的指向,参数数组/arguments对象)

call(要求改成的指向,arg1,arg2...)

例子:哑巴说话

function PersonWei() {

}

PersonWei.prototype={

country:'Wei',

sayCountry:function () {

console.log('I am form '+this.country)

},

}

var xuShu={

country:'Shu',

}

var caoCao=new PersonWei()

caoCao.sayCountry()// I am form Wei

caoCao.sayCountry.call(xuShu)//I am form Shu

不知道这样做合不合理,定义了一个表示魏国人的构造函数PersonWei(),它具有属性:country和方法sayCountry(),然后实例了一个caoCao(曹操),我们想要帮xuShu(徐庶)说出自己的国家:caoCao.sayCountry.call(xuShu)让caoCao的this指向变为xuShu(借尸还魂?脑洞大开,应该就是鬼上身,借用你的身体来实现他的行为),这时候this.conutry 中的this指向的就是xuShu对象了,因此结果是 I am form Shu

js定义函数时,函数名是可选的,如果一个函数不需要用名称进行引用,则不需要对它进行命名。

命名一个函数时,该名称在整个函数声明范围内是有效的。如果一个命名函数声明在顶层,则 window对象上的同名属性 会引用到该函数。

所有的函数都有一个 name 属性,该属性保存的是该函数名称的字符串。

这个属性早就被浏览器广泛支持,但是直到 ES6,才将其写入了标准。但是ES6 对这个属性的一些行为做出了一些修改。分以下四种情况: