JS Symbol的使用

Symbol:ES6新增的数据类型 - 基本类型

值是由Symbol函数调用产生的。

var s1 = Symbol();
var s2 = Symbol();
var s3 = Symbol('miaov');
var s4 = Symbol('miaov');

console.log(s1, s2);
console.log(s3 == s4);

结果为:

Symbol() Symbol()
false

Symbol的值都是唯一的。

属性私有化 - 数据保护

function Person(name, gender) {
    this.name = name;
    this.gender = gender;
}
  
var p1 = new Person('浅殇', '女');
console.log(p1.gender)

结果为:

另一个匿名函数例子:

var Person = (function () {
    var _gender = '';
  
    function P(name, gender) {
        this.name = name;
        _gender = gender;
    };
  
    P.prototype.getGender = function () {
        return _gender;
    }
    return P;
})();

var p1 = new Person('浅殇', '女');
console.log(p1)
console.log(p1.getGender())

结果为:

P {name: "浅殇"}

函数外无法直接调用函数内的_gender,但是可以通过getGender函数return。

var Person = (function () {
    let _gender = Symbol('gender');

    function P(name, gender) {
        this.name = name;
        this[_gender] = gender;
    };
    return P;
})();

var p1 = new Person('浅殇', '女');
console.log(p1)
console.log(p1[Symbol('gender')])

结果为:

P {name: "浅殇", Symbol(gender): "男"}
undefined

Symbol的值只有唯一一个就算样子一样也不是原来的那一个Symbol,无法调用。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值