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

建设论坛网站步骤百度开发者

建设论坛网站步骤,百度开发者,中国搜索引擎市场份额,个人网站建设规划目录一、概述二、显示转换Number()parseInt()String()Boolean()三、隐式转换自动转换成字符串自动转换成数值四、 和 区别1、等于操作符2、全等操作符3、区别小结一、概述 我们知道#xff0c;JS中有六种简单数据类型#xff1a;undefined、null、boolean、string、number、… 目录一、概述二、显示转换Number()parseInt()String()Boolean()三、隐式转换自动转换成字符串自动转换成数值四、 和 区别1、等于操作符2、全等操作符3、区别小结一、概述 我们知道JS中有六种简单数据类型undefined、null、boolean、string、number、symbol以及引用类型object 但是我们在声明的时候只有一种数据类型只有到运行期间才会确定当前类型 let x y ? 1 : a;上面代码中x的值在编译阶段是无法获取的只有等到程序运行时才能知道 虽然变量的数据类型是不确定的但是各种运算符对数据类型是有要求的如果运算子的类型与预期不符合就会触发类型转换机制 常见的类型转换有 强制转换显示转换自动转换隐式转换 二、显示转换 显示转换即我们很清楚可以看到这里发生了类型的转变常见的方法有 Number()parseInt()String()Boolean() Number() 将任意类型的值转化为数值先给出类型转换规则 实践一下 Number(324) // 324// 字符串如果可以被解析为数值则转换为相应的数值 Number(324) // 324// 字符串如果不可以被解析为数值返回 NaN Number(324abc) // NaN// 空字符串转为0 Number() // 0// 布尔值true 转成 1false 转成 0 Number(true) // 1 Number(false) // 0// undefined转成 NaN Number(undefined) // NaN// null转成0 Number(null) // 0// 对象通常转换成NaN(除了只包含单个数值的数组) Number({a: 1}) // NaN Number([1, 2, 3]) // NaN Number([5]) // 5从上面可以看到Number转换的时候是很严格的只要有一个字符无法转成数值整个字符串就会被转为NaN parseInt() parseInt相比Number就没那么严格了parseInt函数逐个解析字符遇到不能转换的字符就停下来 parseInt(32a3) //32String() 可以将任意类型的值转化成字符串给出转换规则图 实践一下 // 数值转为相应的字符串 String(1) // 1//字符串转换后还是原来的值 String(a) // a//布尔值true转为字符串truefalse转为字符串false String(true) // true//undefined转为字符串undefined String(undefined) // undefined//null转为字符串null String(null) // null//对象 String({a: 1}) // [object Object] String([1, 2, 3]) // 1,2,3Boolean() 可以将任意类型的值转为布尔值转换规则如下 实践一下 Boolean(undefined) // false Boolean(null) // false Boolean(0) // false Boolean(NaN) // false Boolean() // false Boolean({}) // true Boolean([]) // true Boolean(new Boolean(false)) // true三、隐式转换 在隐式转换中我们可能最大的疑惑是 何时发生隐式转换 我们这里可以归纳为两种情况发生隐式转换的场景 比较运算 、!、、、if、while 需要布尔值地方算术运算 、-、*、/、% 除了上面的场景还要求运算符两边的操作数不是同一类型 #自动转换为布尔值 在需要布尔值的地方就会将非布尔值的参数自动转为布尔值系统内部会调用Boolean函数 可以得出个小结 undefinednullfalse0-0NaN“” 除了上面几种会被转化成false其他都换被转化成true 自动转换成字符串 遇到预期为字符串的地方就会将非字符串的值自动转为字符串 具体规则是先将复合类型的值转为原始类型的值再将原始类型的值转为字符串 常发生在运算中一旦存在字符串则会进行字符串拼接操作 5 1 // 51 5 true // 5true 5 false // 5false 5 {} // 5[object Object] 5 [] // 5 5 function (){} // 5function (){} 5 undefined // 5undefined 5 null // 5null自动转换成数值 除了有可能把运算子转为字符串其他运算符都会把运算子自动转成数值 5 - 2 // 3 5 * 2 // 10 true - 1 // 0 false - 1 // -1 1 - 1 // 0 5 * [] // 0 false / 5 // 0 abc - 1 // NaN null 1 // 1 undefined 1 // NaNnull转为数值时值为0 。undefined转为数值时值为NaN 四、 和 区别 1、等于操作符 等于操作符用两个等于号 表示如果操作数相等则会返回 true 前面文章我们提到在JavaScript中存在隐式转换。等于操作符在比较中会先进行类型转换再确定操作数是否相等 遵循以下规则 如果任一操作数是布尔值则将其转换为数值再比较是否相等 let result1 (true 1); // true如果一个操作数是字符串另一个操作数是数值则尝试将字符串转换为数值再比较是否相等 let result1 (55 55); // true如果一个操作数是对象另一个操作数不是则调用对象的 valueOf()方法取得其原始值再根据前面的规则进行比较 let obj {valueOf:function(){return 1}} let result1 (obj 1); // truenull和undefined相等 let result1 (null undefined ); // true如果有任一操作数是 NaN 则相等操作符返回 false let result1 (NaN NaN ); // false如果两个操作数都是对象则比较它们是不是同一个对象。如果两个操作数都指向同一个对象则相等操作符返回true let obj1 {name:xxx} let obj2 {name:xxx} let result1 (obj1 obj2 ); // false下面进一步做个小结 两个都为简单类型字符串和布尔值都会转换成数值再比较 简单类型与引用类型比较对象转化成其原始类型的值再比较 两个都为引用类型则比较它们是否指向同一个对象 null 和 undefined 相等 存在 NaN 则返回 false 2、全等操作符 全等操作符由 3 个等于号 表示只有两个操作数在不转换的前提下相等才返回 true。即类型相同值也需相同 let result1 (55 55); // false不相等因为数据类型不同 let result2 (55 55); // true相等因为数据类型相同值也相同undefined 和 null 与自身严格相等 let result1 (null null) //true let result2 (undefined undefined) //true3、区别 相等操作符会做类型转换再进行值的比较全等运算符不会做类型转换 let result1 (55 55); // false不相等因为数据类型不同 let result2 (55 55); // true相等因为数据类型相同值也相同null 和 undefined 比较相等操作符为true全等为false let result1 (null undefined ); // true let result2 (null undefined); // false小结 相等运算符隐藏的类型转换会带来一些违反直觉的结果 0 // false 0 // true 0 0 // truefalse false // false false 0 // truefalse undefined // false false null // false null undefined // true \t\r\n 0 // true但在比较null的情况的时候我们一般使用相等操作符 const obj {};if(obj.x null){console.log(1); //执行 }等同于下面写法 if(obj.x null || obj.x undefined) {... }使用相等操作符的写法明显更加简洁了 所以除了在比较对象属性为null或者undefined的情况下我们可以使用相等操作符“其他情况建议一律使用全等操作符” 参考 https://vue3js.cn/interview/JavaScript/%20_.html#%E4%B8%80%E3%80%81%E7%AD%89%E4%BA%8E%E6%93%8D%E4%BD%9C%E7%AC%A6https://vue3js.cn/interview/JavaScript/type_conversion.html#%E4%B8%80%E3%80%81%E6%A6%82%E8%BF%B0
http://www.hkea.cn/news/14392129/

相关文章:

  • 微网站如何做微信支付宝支付宝支付宝在设计赚钱的网站
  • 设计制作个人网站地产网站建设方案
  • 公司网站怎么做网站备案珠海建设局网站首页
  • 手机网站怎么搜索引擎网站开发视频会议插件
  • 廊坊哪里有做网站的seo网站优化推广教程
  • 临沂百度网站推广做网站专业公司
  • 大型网站建设网站推广汽车网站排行榜前十名
  • 成都哪家网站建设强电商网站设计的原则
  • 网站开发著作权微信公众号怎么做网站链接
  • 科技公司建设网站百度推广建设网站是不是合发
  • 一流的南昌网站建设wordpress模板手机
  • 建设一个网站需要什么技术指标qq音乐插件 wordpress
  • 网站开发与管理心得体会山西住房建设厅官方网站
  • 北京低价网站建设怎么样用ps做网站
  • 网站建设的案例沈阳建设网站服务公司
  • 网站建设教程网北京网站设计公司哪儿济南兴田德润简介
  • 网站开发怎么对接客户app开发公司介绍
  • 合肥平台网站建设网站建设简介电话
  • 外贸网站 源怎么查网站是用什么语言做的
  • 网站下载工具天津网站建设论坛
  • 建筑工程网站监理答案广告设计好学吗难不难
  • 深圳极速网站建设费用百度全静态生成技术
  • 保险网站有哪些平台公司网站开发的核心技术
  • 萧山做网站公司山东网站建设运行工资
  • 上海网站开发定制泉州网站优化
  • 旅游建设投资公司中网站福州搜索排名提升
  • wordpress头像网站建设银行信用卡官方网站
  • 怎么给网站做访问量安贞街道网站建设
  • 做网站需要学数据库吗哪个网站可以做创意短视频
  • 如何鉴别网站有没有做301重定向网站模块图