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

小程序开发 网站建设电子政务门户网站建设方案

小程序开发 网站建设,电子政务门户网站建设方案,网站推广营销策略,信盈达嵌入式培训多少钱目录一、隐式类型转换条件二、 的隐式类型转换三、 的隐式类型转换四、object 的隐式类型转换探讨 object 的隐式转换执行顺序探讨 Symbol.toPrimitive 属性如何将对象转换为原始值在前端js这门动态弱类型语言中#xff0c;不仅存在着显示类型转换#xff0c;还存在许多隐式类… 目录一、隐式类型转换条件二、 的隐式类型转换三、 的隐式类型转换四、object 的隐式类型转换探讨 object 的隐式转换执行顺序探讨 Symbol.toPrimitive 属性如何将对象转换为原始值在前端js这门动态弱类型语言中不仅存在着显示类型转换还存在许多隐式类型转换让人头大。为了减少小伙伴们的踩坑今天总结了一些常见的隐式类型转换规则让我们来看看有哪些。 一、隐式类型转换条件 逻辑运算符、||、运算符、-、*、/关系操作符、、、相等运行算符if / while 条件 二、 的隐式类型转换 类型相同则无需进行类型转换。如果其中一个操作数是 null 或者 undefined 那么另一个操作数必须是 null 或者 undefined 才会返回 true 否则返回 false 。如果其中一个操作数是 Symbol 那么返回 false。如果两个操作数都为 string 和 number 类型那就就将字符串转换为 number。如果一个操作数是 boolean 类型那么转换成 number。如果一个操作数为 object 且另一方为 string、number、或者 Symbol 就会把object 转换为原始类型再进行判断。 测试 null undefined; // true null 0; // falsenull; // false0; // true 123 123; // true 0 false; // true 1 true; // truevar a {value: 0,valueOf: function(){this.value;return this.value;} } console.log(a1 a2 a3); // true // 对象隐式转换为原始类型调用对象的valueOf方法返回值此对象的valueOf()返回一个自定义自增方法每调用一次增加1最后结果为3. // a1时a.valueOf()返回1所以11为true此时a.value1 // a2时a.valueOf()返回2所以22为true此时a.value2 // a3时a.valueOf()返回3所以33为true此时a.value3// 这时如果再判断a1a2a3则返回false因为此时的a已经为4了 console.log(a1 a2 a3); // false三、 的隐式类型转换 号操作符不仅可以用作数字相加还可以用作字符串拼接。 如果其中一个操作数是 string另外一个操作数是 undefined、null 或者 boolean则调用 toString() 方法进行字符串拼接。如果是纯对象、数组、正则等则默认调用对象的转换方法会存在优先级然后再进行拼接。如果其中有一个是 number 另外一个是 undefined、null、boolean、number则会将其转换为数字进行加法运算对象的情况参考上一条规则。如果其中一个是 string 一个是 number则按照字符串规则进行拼接。 测试 1 2; // 3 1 2; // 12 1 3; // 13 字符串拼接1 undefined; // 1undefined 1 null; // 1null 1 true; // 1true 1 1n; // 11 字符串和BigInt相加BigInt转换为字符串1 undefined; // NaN undefined转换为NaN 1 null; // 1 null转换为0 1 true; // 2 true转换为1 1 1n; // TypeError: Cannot mix BigInt and other types, use explicit conversion 无法混合BigInt和其他类型请使用显式转换四、object 的隐式类型转换 如果部署了 [Symbol.toPrimitive] 方法优先调用再返回若不存在 [Symbol.toPrimitive] 方法则调用 valueOf 方法如果返回基础数据类型则执行结束否则调用 toString 方法如果转换为基础数据类型则返回最后如果都没有返回基础数据类型则报错。 测试 var obj {value: 1,valueOf(){console.log(valueOf, 2);return 2;},toString(){console.log(toString, 3);return 3;},[Symbol.toPrimitive](){console.log([Symbol.toPrimitive], 4);return 4;} } console.log(obj 1); // 5 // 调用[Symbol.toPrimitive]方法获取返回值441510 {}; // 10[object Object] // {}调用valueOf方法返回自身然后继续调用toString方法返回字符串[object Object]10与其相加得 10[object Object][1, 2, undefined, 4, 5] 10; // 1,2,,4,510 // 数组调用valueOf方法返回数组本身然后调用toString方法转换为字符串1,2,,4,5与10相加得 1,2,,4,510探讨 object 的隐式转换执行顺序 1、有 [Symbol.toPrimitive] 方法执行方法后获取原始值返回执行结束若返回不是原始值则报错。 var obj {value: 1,valueOf(){console.log(valueOf, 2);return 2;},toString(){console.log(toString, 3);return 3;},[Symbol.toPrimitive](){console.log([Symbol.toPrimitive], 4);return 4;} } console.log(obj 1); // 52、valueOf方法返回值不为原始值时则继续寻找toString方法执行获取返回值执行结束。 var obj {value: 1,valueOf(){console.log(valueOf, 2);return {};},toString(){console.log(toString, 3);return 3;}, } console.log(obj 1); // 43、若valueOf方法返回值为原始值时执行结束。 var obj {value: 1,valueOf(){console.log(valueOf, 2);return 2;},toString(){console.log(toString, 3);return 3;} } console.log(obj 1); // 34、若无 Symbol.toPrimitive 方法并且最终获取不到原始值时报错。 var obj {value: 1,valueOf(){console.log(valueOf {});return {};},toString(){console.log(toString {});return {};} } console.log(obj 1); // ncaught TypeError: Cannot convert object to primitive value探讨 Symbol.toPrimitive 属性如何将对象转换为原始值 Symbol.toPrimitive 指将被调用的指定函数值的属性转换为相对应的原始值。 在 Symbol.toPrimitive属性(用作函数值)的帮助下一个对象可被转换为原始值。该函数由字符串参数 hint 调用目的是指定原始值转换结果的首选类型。 hint 参数可以是number、“string” 和 “default” 中的一种。 // An object without Symbol.toPrimitive property. 对象中不存在Symbol.toPrimitive属性 var obj1 {}; console.log(obj1); // NaN console.log(${obj1}); // [object Object] console.log(obj1 ); // [object Object]// An object with Symbol.toPrimitive property. 对象中存在Symbol.toPrimitive属性 var obj2 {[Symbol.toPrimitive](hint) {if (hint number) {return 10;}if (hint string) {return hello;}return true;} }; console.log(obj2); // 10 -- hint is number console.log(${obj2}); // hello -- hint is string console.log(obj2 ); // true -- hint is default超强测试题 {} ; // 0 // 代码执行顺序为从左到右此处的{}被认为是代码块而非对象所以不进行类型转换仅剩余 被转换number类型{} ; // NaN // 此处先执行{}转换为number类型NaN与空字符串相加得NaN {}; // [object Object] // 此处的号前面空字符串为string类型按照代码执行顺序以及字符串拼接规则 // 需将{}转换为string类型与其相加调用toString方法获得[object Object]
http://www.hkea.cn/news/14516798/

相关文章:

  • 上饶网站建设seo人员招聘
  • 专业网站建设网站价格网站后台加密
  • 网站建设和后台空间管理关系网站里添加斗鱼直播的视频怎么做
  • 企业网站推广哪个公司好网站怎样优化关键词好
  • 网站运营是什么为什么博客需要wordpress
  • 营销网站制作信ls15227想给公司做个网站
  • 网站建立的意义做vi的图有网站吗
  • 青县建设银行网站哈尔滨网站建设的公司哪家好
  • 茶网站开发方案那个网站专门做二手衣服的
  • wordpress获取当前分类id南通网站推广优化公司
  • 网站建设p2p太原网站建设外包价格
  • 深圳广告网站设计制作河南华盛建设集团网站
  • 网页小游戏在线玩儿重庆seo推广外包
  • 南宁网站设计方法胶南网络推广
  • 1688精品货源网站入口wordpress 调用tag标签
  • 学做网站能赚多少钱实战直播
  • 耐克电子商务网站建设做平面设计的网站
  • 家教网站开发公司南通大型网站建设
  • 上海市网站制作济南腾飞网络网站建设
  • 做网站公司有什么出路it外包企业排名
  • 静态网站开发文章网站添加搜索
  • 网站开发站点的文件夹推广平台排行榜有哪些
  • 郑州营销网站公司地址制作企业网站的新闻显示
  • 制作网站商城网站后台修改不了
  • phpstudy做正式网站邢台网站制作公司
  • 建筑方案的网站南宁手机做网站公司
  • 建网站需要多少钱免费网址申请
  • 在线设计网名生成器seo优化前景
  • 电子商务网站建设可行性分析郑州企业排名
  • 温州专业做网站网站的推广方式有哪些