当前位置: 首页 > news >正文

有创意的网站开发昆明专业做网站多少钱

有创意的网站开发,昆明专业做网站多少钱,室内设计学校前十,哪些网站在哪找的一、Symbol 简介 Symbol 是 JavaScript 中的一种基本数据类型,它表示唯一的标识符。Symbol 的主要目的是防止属性名冲突,尤其是在多个代码库或模块中共享对象时。Symbol 值可以用作对象的属性名,这样可以确保属性名是唯一的,不会…

一、Symbol 简介

Symbol 是 JavaScript 中的一种基本数据类型,它表示唯一的标识符。Symbol 的主要目的是防止属性名冲突,尤其是在多个代码库或模块中共享对象时。Symbol 值可以用作对象的属性名,这样可以确保属性名是唯一的,不会与其他属性名冲突。Symbol定义的对象属性不能使用for…in循环遍历,但可以使用 Reflect.ownKeys 来获取对象的所有键名。

二、Symbol 的创建

可以使用 Symbol() 函数来创建一个新的 Symbol 值。这个函数可以接受一个可选的字符串参数,作为 Symbol 的描述。描述只是为了调试目的,不会影响 Symbol 的唯一性。

let s1 = Symbol();
console.log(s1, typeof s1); // Symbol() "symbol"let s2 = Symbol('尚硅谷');
let s2_2= Symbol('尚硅谷');
console.log(s2 === s2_2); // false// 使用 Symbol.for 定义
let s3 = Symbol.for('尚硅谷');
let s3_2 = Symbol.for('尚硅谷');
console.log(s3 === s3_2); // true

在上面的代码中,s1s2s2_2 都是不同的 Symbol 值,尽管 s2s2_2 的描述相同。

三、Symbol 的应用

1. 作为对象的属性名

Symbol 可以用作对象的属性名,这样可以确保属性名是唯一的,不会与其他属性名冲突。

let game = {name:'俄罗斯方块',up: function(){},down: function(){}
};let methods = {up: Symbol(),down: Symbol()
};game[methods.up] = function(){console.log("我可以改变形状");
}game[methods.down] = function(){console.log("我可以快速下降!!");
}console.log(game);

在上面的代码中,methods.upmethods.down 是两个 Symbol 值,它们被用作 game 对象的属性名。这样,即使其他代码也使用了 updown 作为属性名,它们也不会冲突。

2. Symbol 内置属性

除了定义自己使用的 Symbol 值以外,ES6 还提供了 11 个内置的 Symbol 值,指向语言内部使用的方法,称为“魔术方法”,因为它们会在特定的场景下自动执行。。例如,Symbol.hasInstance 可以用来定义一个对象是否是某个类的实例,Symbol.isConcatSpreadable 可以用来控制数组的展开行为。

  • Symbol.hasInstance:当其他对象使用 instanceof 运算符,判断是否为该对象的实例时,会调用这个方法。
  • Symbol.isConcatSpreadable:对象的 Symbol.isConcatSpreadable 属性等于的是一个布尔值,表示该对象用于 Array.prototype.concat() 时,是否可以展开。
  • Symbol.species:创建衍生对象时,会使用该属性。
  • Symbol.match:当执行 str.match(myObject) 时,如果该属性存在,会调用它,返回该方法的返回值。
  • Symbol.replace:当该对象被 str.replace(myObject) 方法调用时,会返回该方法的返回值。
  • Symbol.search:当该对象被 str.search(myObject) 方法调用时,会返回该方法的返回值。
  • Symbol.split:当该对象被 str.split(myObject) 方法调用时,会返回该方法的返回值。
  • Symbol.iterator:对象进行 for...of 循环时,会调用 Symbol.iterator 方法,返回该对象的默认遍历器。
  • Symbol.toPrimitive:该对象被转为原始类型的值时,会调用这个方法,返回该对象对应的原始类型值。
  • Symbol.toStringTag:在该对象上面调用 toString 方法时,返回该方法的返回值。
  • Symbol.unscopables:该对象指定了使用 with 关键字时,哪些属性会被 with 环境排除。
class Person{static [Symbol.hasInstance](param){console.log(param);console.log("我被用来检测类型了");return false;}
}let o = {};console.log(o instanceof Person);const arr = [1,2,3];
const arr2 = [4,5,6];
arr2[Symbol.isConcatSpreadable] = false;
console.log(arr.concat(arr2));

在上面的代码中,Symbol.hasInstance 被用来定义 Person 类的 instanceof 操作符的行为,Symbol.isConcatSpreadable 被用来控制数组的 concat 方法的展开行为。

四、总结

Symbol 是 JavaScript 中一种非常有用的数据类型,它可以用来创建唯一的标识符,防止属性名冲突,并且可以用来定义对象的一些特殊行为。通过合理使用 Symbol,可以使代码更加健壮和可维护。

http://www.yayakq.cn/news/944540/

相关文章:

  • 江苏省住房与城乡建设部网站上海园区虚拟地址一览表
  • 网站转微信小程序开发网络营销的收获与体会
  • 上海建设网站定做wordpress建立目录权限
  • 专注集团网站建设室内设计作品集
  • 汽车音响网站建设一套会员管理系统多少钱
  • 有没有做羞羞的网站云服务器5元左右的
  • 有哪些可以在网上做兼职的网站企业怎么建网站
  • 如何做文化传播公司网站深圳网站推广排名
  • 毕设帮做网站wordpress购物车系统
  • 网站开发建设挣钱吗黄岛网站建设公司首选
  • 北京城乡建设学校网站动画设计师招聘
  • 福建省建设执业注册与管理中心网站廊坊 网站
  • 网上建站赚钱潍坊网站建设 绮畅
  • 网站总体设计怎么写网站变移动网站
  • 网站开发有哪些买一个域名大概多少钱
  • 美食网站的建设背景有哪些可以做宣传旅游的网站
  • 摄影网站设计素材程序员如何自学
  • 衡阳的房地产网站建设app推广软文范文
  • 肥城 网站建设seo排名赚挂机赚钱软件下载
  • 网站设计汕头海南做网站找谁
  • 网站建设环境阳谷网站建设
  • 仿站小工具下载建设网站要服务器
  • 温州网站设计公司哪家好免费视频素材
  • 网站搭建 成都郑州seo服务
  • 微信网站可以免费做么免费源码大全
  • 北控京奥建设有限公司网站网页建站怎么设置
  • 什么是销售型网站深圳做企业网站的公
  • 企业官方网站如何做蓝v认证公司网站建设合同 华律网
  • 可以自己做网站优化吗出口电商网站建设程序
  • 微信公司网站自己做装修效果图app软件