JS 静态属性与静态方法

什么是静态属性。

    function Web(url) {
        this.url = url;
    }
    let hd = new Web("newJoker");
    console.log(hd);
    Web.url = "Joker";
    console.dir(Web)

第一种打印的url是为我们每一个构造函数实例化出来的对象创建的属性,因此我们把它称为对象属性

第二种直接使用Web.url的方式是为我们构造函数添加的属性,我们把这种属性称为静态属性

当我们明白了函数的静态属性之后,再来看看class(类)的静态属性的定义方式。

class User {
        title = "Joker";
        static title="User的Joker"  //静态属性
    }
let obj = new User();
console.log(obj);
console.dir(User)

如果我们想给class添加静态属性,只需要在class中定义个属性,并在前面加上static,那这个属性就是为这个class创建的属性。

tips:当我们的属性是提供给所有的实例化对象使用的,我们就可以把这个属性设置为静态属性,能节省内存占用。

什么是静态方法。

    function User() {}

    User.prototype.show = function () {
        console.log('show')
    };
    User.show = function () {
        console.log("static.show");
    };
    let obj = new User();
    console.log(obj);
    console.dir(User)

首先大家应该都知道,函数扮演着多个角色,如果函数扮演者构造函数创建出实例化对象的时候,那他调用的就是prototype上的方法。如果函数作为对象被使用的时候,那么它用的就是__proto__上的方法。因此,上述代码中为函数的实例化对象添加的show方法就称为普通方法,而为User本身添加的方法,就称为静态方法。

当我们明白了函数中的静态方法之后,再来看看class中的静态方法的使用。

class User {
        show() {
            //给User的实例化对象添加的方法称为普通方法
            console.log("prototype.show");
        }
        static show(){
            //给User本身添加的方法称为静态方法
            console.log("static.show")
        }
    }
    let hd = new User();
    console.log(hd);
    User.show();

  • 10
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值