首页 > 其他分享 >兼收并蓄 TypeScript - 基础: symbol

兼收并蓄 TypeScript - 基础: symbol

时间:2024-09-20 12:16:35浏览次数:11  
标签:TypeScript const symbol 兼收并蓄 webabcd key obj Symbol

源码 https://github.com/webabcd/TypeScriptDemo
作者 webabcd

兼收并蓄 TypeScript - 基础: symbol

示例如下:

basic\symbol.ts

{
    // Symbol() 是一个全局函数,返回一个唯一的 Symbol 值
    const a = Symbol();
    const b = Symbol(); // b 与 a 不同
    const c = Symbol("description");
    const d = Symbol("description"); // d 与 c 不同
    
    
    // Symbol.for() - 获取指定 key 的 Symbol 值,如果没有就创建一个
    const e = Symbol.for("key")
    const f = Symbol.for("key") // f 与 e 相同
    // Symbol.keyFor() - 获取指定的由 Symbol.for() 返回的 Symbol 值的 key
    let g = Symbol.keyFor(e);
    console.log(g); // key
    
    
    // Symbol 的应用场景
    // Symbol 主要用于解决 JavaScript 中对象属性名可能冲突的问题,保证属性名的唯一性
    // 不用 Symbol 的话当多个模块尝试在同一个对象上添加相同名称的属性时,后者会覆盖前者,Symbol 的引入解决了这一问题,因为每个 Symbol 值都是独一无二的
}

{
    const uniqueKey = Symbol("unique");  
    const obj = {  
        [uniqueKey]: "abc", // 使用 Symbol 作为属性名
    };  
    console.log(obj[uniqueKey]); // abc

    // 遍历 Symbol 类型的属性  
    const symbols = Object.getOwnPropertySymbols(obj);  
    for (const symbol of symbols) {  
        console.log(symbol, (obj as any)[symbol]); // Symbol(unique) abc
    }
}

源码 https://github.com/webabcd/TypeScriptDemo
作者 webabcd

标签:TypeScript,const,symbol,兼收并蓄,webabcd,key,obj,Symbol
From: https://www.cnblogs.com/webabcd/p/18422239/typescript_basic_symbol

相关文章

  • 兼收并蓄 TypeScript - 基础: array
    源码https://github.com/webabcd/TypeScriptDemo作者webabcd兼收并蓄TypeScript-基础:array示例如下:basic\array.ts{//array-数组//创建数组letarray1:number[]=[1,2,3];letarray2:Array<number>=[1,2,3];letarray3:Ar......
  • 兼收并蓄 TypeScript - 基础: set
    源码https://github.com/webabcd/TypeScriptDemo作者webabcd兼收并蓄TypeScript-基础:set示例如下:basic\set.ts{//set是一个集合,先进先出,不会插入重复数据,数据支持类型的多样性//常规操作有add(),delete(),has(),clear(),size等letmySet=......
  • 兼收并蓄 TypeScript - 基础: map
    源码https://github.com/webabcd/TypeScriptDemo作者webabcd兼收并蓄TypeScript-基础:map示例如下:basic\map.ts{//map是一个key/value集合,先进先出,遇到重复键值则后面的会覆盖前面的,key和value都支持类型的多样性//常规操作有set(),get(),dele......
  • 兼收并蓄 TypeScript - 基础: tuple
    源码https://github.com/webabcd/TypeScriptDemo作者webabcd兼收并蓄TypeScript-基础:tuple示例如下:basic\tuple.ts{//tuple-元组leta:[string,number]=['webabcd',22];a[0]='wanglei';a[1]=44;console.log(a,a[0......
  • 兼收并蓄 TypeScript - 类: enum
    源码https://github.com/webabcd/TypeScriptDemo作者webabcd兼收并蓄TypeScript-类:enum示例如下:class\enum.ts{//简单枚举enumStatus{ok,error};console.log(Status["ok"],Status["error"]);//01console.log(Status[0],Status......
  • 兼收并蓄 TypeScript - 类: function
    源码https://github.com/webabcd/TypeScriptDemo作者webabcd兼收并蓄TypeScript-类:function示例如下:class\function.ts{//定义函数时要指定参数的类型和返回值的类型,无返回值时可以用void表示functionf1(x:number,y:number):number{retur......
  • 兼收并蓄 TypeScript - 类: interface
    源码https://github.com/webabcd/TypeScriptDemo作者webabcd兼收并蓄TypeScript-类:interface示例如下:class\interface.ts{//接口用于定义对象的形状,这个是TypeScript的功能(JavaScript中没有)interfacePerson{readonlyid:number;//只读......
  • 兼收并蓄 TypeScript - 基础: 基础
    源码https://github.com/webabcd/TypeScriptDemo作者webabcd兼收并蓄TypeScript-基础:基础示例如下:basic\basic.ts{//基础//try/catch/finally的用法functionf1(str:string):number|null{try{letnum=Number(str......
  • 兼收并蓄 TypeScript - 基础: var, let, const
    源码https://github.com/webabcd/TypeScriptDemo作者webabcd兼收并蓄TypeScript-基础:var,let,const示例如下:basic\var_let_const.ts//var声明的变量是全局作用域,块外也可用{vara=10;}console.log(a);//let声明的变量是块作用域,仅块内可用{......
  • 兼收并蓄 TypeScript - 基础: 数据类型
    源码https://github.com/webabcd/TypeScriptDemo作者webabcd兼收并蓄TypeScript-基础:数据类型示例如下:basic\dataType.ts{//基本数据类型boolean,number,string,symbolleta:boolean=true;letb:number=10;letc:string="abc";......