从零开始学习typescript——类型转换

类型转换

在开发中,你有没有遇见一种情况

javascript 复制代码
let obj={
  displayNum:""
}
obj.displayNum="123";
let num:number =123
console.log(num==obj.displayNum) //false

我们想要的结果,是结果为true;那么这时候就要用到类型转换

  • 将其他类型转换为布尔类型
javascript 复制代码
let m: string ='123'
let mb:boolean = Boolean(m) ;// true

Boolean()函数会判断传入的值是空值,还是非空值;除了5种情况,其余的返回的都是true

  1. undefined

  2. null

  3. NaN

  4. 0

  5. ""

javascript 复制代码
Boolean(undefined) //false
Boolean(123) //true
Boolean("") //false
  • 将其他类型转换为数值类型

    • parseInt()
      将字符串类型的值转换为整型数值
    javascript 复制代码
    parseInt("   1") //1
    parseInt("1") //1
    parseInt("3.14") //3
    parseInt("1zz") //1
    parseInt("z1") //NaN

    看上面的代码,可以知道,使用parseInt()函数时,需要注意的几点。

    在转换时会忽略前面的空格,会从第一个非空字符串开始解析,直到遇见非数字字符,会忽略非数字字符及之后的所有字符;

    在转换时会忽略小数点后的数值

    • pareseFloat()
      将字符串类型的值转换为浮点型数值
    javascript 复制代码
    pareseFloat("   1。1") //1.1
    pareseFloat("1.1") //1.1
    pareseFloat("3.14.15") //3.14
    pareseFloat("1zz") //1
    pareseFloat("z1") //NaN

    看上面的代码,可以知道,使用pareseFloat()函数时,需要注意的几点。

    在转换时会忽略前面的空格,会从第一个非空字符串开始解析,直到遇见非数字字符,会忽略非数字字符及之后的所有字符;

    在转换时会忽略第二个小数点后的数值

    • Number()
      将任意类型的值转换为数值类型的值;Number()的转换大致和parseInt()和 parseFloat()一样;但是对与转换的内容中包含 非数字,只会得到NaN;所以如果判断一个字符串是否时纯数字的时候 可以使用Number();

      javascript 复制代码

    Number(" 1。1") //1.1

    Number("1.1") //1.1

    Number("3.14.15") //3.14

    Number("1zz") //NaN

    Number("z1") //NaN

    复制代码
  • 将其他类型转换为字符串类型

    可以使用两种方式可以将其他类型的值转换为字符串类型

    • 通过String()构造函数产生新的字符串
      如果使用String()会产生新的字符串。
    • 通过调用其他类型的toString()方法来进行转换
相关推荐
2501_920931704 小时前
React Native鸿蒙跨平台采用ScrollView的horizontal属性实现横向滚动实现特色游戏轮播和分类导航
javascript·react native·react.js·游戏·ecmascript·harmonyos
东东5166 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino6 小时前
图片、文件的预览
前端·javascript
2501_920931708 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
AI老李8 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
方也_arkling8 小时前
Element Plus主题色定制
javascript·sass
2601_949809599 小时前
flutter_for_openharmony家庭相册app实战+我的Tab实现
java·javascript·flutter
Up九五小庞9 小时前
开源埋点分析平台 ClkLog 本地部署 + Web JS 埋点测试实战--九五小庞
前端·javascript·开源
摘星编程9 小时前
React Native + OpenHarmony:UniversalLink通用链接
javascript·react native·react.js