一、数据类型的转换

  1. 数据类型的转换方法

    • 强制转换(显示转换,主动转换)

      • 字符转数值

        • parseInt(要转换的数值或变量)

          • 转整数
          • 从左向右依次转换,遇到第一个非数字的字符,停止转换
          • 忽略小数点后的内容,其实是将小数点识别成了非数字,所以没有四舍五入
          • 如果第一位就是非数字,直接 NaN
            • NaN:not a number
            • 不是一个数字的数值型数据,非法的数值运算结果
        • parseFloat(要转换的数值或变量)

          • 转小数
          • 从左向右依次转换,遇到第一个非数字的字符,停止转换
          • 可以识别小数点
          • 如果第一位就是非数字,直接 NaN
            • NaN:not a number
            • 不是一个数字的数值型数据,非法的数值运算结果
        • Math.round(要转换的数值或变量)

          • 四舍五入
          • Math.round()不是专门做字符转数值的,专门做取整
          • 严格转换,只要出现非数字就是NaN
          • 取最近的整数
        • Number(要转换的数值或变量)

          • 直接转
          • Number()不是专门做字符转数值的,专门做系统内置的构造函数,用来创建数值对象
          • 严格转换,只要出现非数字就是NaN
          • 直接转换,不分小数整数
      • 数值转字符

        • 数值变量.toString()

          • 直接转换,相当于加个引号
        • 数值变量.toFixed(n)

          • 保留n位小数 直接转换,相当于加个引号
      • 其他类型转换

        • 其他转布尔
        • 布尔转数值
        • 其他转字符
    • 隐式转换(被动转换)

      • 情况和规则:
        1. 算数运算

          • +两边只要出现字符,结果必然为字符
          • -*/%结果必然是数值(字符转数值)
        2. 关系运算
          • ><>=<=两边那只要出现数值,那么另一边也会转为数值,进行比较

二、数据的运算符

  1. 算数运算符

    • + 加号、加法

      • +在js中不是单纯的加法:

        • 当加号两边都是数值型数据时,是加法运算
        • 两边任意一边出现字符就变成了拼接就不是加法,+已经不是单纯的加法了,变成了拼接,拼接就是将两个数组,直接组合起来
    • -*/%
      • 就是正常的数学运算
      • 就算两边不是数值,也会默认转成数值,进行运算
      • 如果某个数据不能转成数值,就会得到NaN
  2. 关系运算符 - 结果是布尔值

    • ><>=<=

      • 只要又一边出现数值,都是数值的比较规则
      • 如果都是字符,才是字符的比较规则:逐位比较,得到结果,就停止
    • !===
      • 会发生隐式类型转换,只比较大小,不比较类型
    • !=====
      • 不会发生隐式类型转换,不仅比较大小,还比较类型
  3. 逻辑运算符 - 主要操作布尔值

    • 或 ||

      • 或的规则:两边只要出现true,结果就是true,必须都为false,结果踩死false
    • 且 &&
      • 且的规则:两边只要出现false,结果就是false,必须都为true,结果踩死true
    • 非 !
      • 取反
  4. 赋值运算符

    • =,+=,-=,*=,/=,%=
    • 先计算,再赋值 c1 = c1 + 10; c1 += 10;
  5. 一元运算符

    • ++自增

    • 增加1

    • 前后之分

      • 前自增++n:先计算,后使用
      • 后自增n++:先使用,后计算
    • --自减

    • 减少1

    • 前后之分

      • 前自增--n:先计算,后使用
      • 后自增n--:先使用,后计算

JS数据类型转换问题的更多相关文章

  1. JS 数据类型转换

    JS 数据类型转换 方法主要有三种 转换函数.强制类型转换.利用js变量弱类型转换. 1. 转换函数: js提供了parseInt()和parseFloat()两个转换函数.前者把值转换成整数,后者把 ...

  2. JS数据类型转换

    JS 数据类型转换 方法主要有三种 转换函数.强制类型转换.利用js变量弱类型转换. 1. 转换函数: js提供了parseInt()和parseFloat()两个转换函数.前者把值转换成整数,后者把 ...

  3. js笔记——js数据类型转换

    以下内容摘录自阮一峰的<语法概述 -- JavaScript 标准参考教程(alpha)>章节『数据类型转换』,以做备忘.更多内容请查看原文. JavaScript是一种动态类型语言,变量 ...

  4. {}+[] = ? 和 []+{} = ? 浅谈JS数据类型转换

    参加公司技术嘉年华第一季(前端.服务端)的间隙,陈导问了我一个问题:{}+[] 和 []+{}两个表达式的值分别是什么?根据我的理解我觉得结果应该都是"[object Object]&quo ...

  5. JS 数据类型转换以其他

    JavaScript 是一种弱类型的语言,也就是没有类型限制,变量可以随时被赋予任意值. 同时,在程序运行过程中,类型会被自动确认的.因此,这就是涉及到数据的类型转换.在 JS 的世界中,数据类型转换 ...

  6. js数据类型转换 ----流程控制

    数据类型转换: //number转换成str // var str=a+''; // console.log(str); // console.log(typeof str); //转换成字符串了 v ...

  7. JS 数据类型转换-转换函数、强制类型转换、利用js变量弱类型转换

    1. 转换函数: js提供了parseInt()和parseFloat()两个转换函数.前者把值转换成整数,后者把值转换成浮点数.只有对String类型调用这些方法,这两个函数才能正确运行:对其他类型 ...

  8. JS的数据类型转换

    JS 数据类型转换 方法主要有三种 转换函数.强制类型转换.利用js变量弱类型转换. 1. 转换函数: js提供了parseInt()和parseFloat()两个转换函数.前者把值转换成整数,后者把 ...

  9. 数据类型转换,JS操作HTML

    数据类型转换 1.自动转换(在某种运算环境下) Number环境 String环境 Boolean环境 2.强制类型转换 Number() 字符串:纯数字和空字符转为正常数字,其他NaN 布尔值:tu ...

随机推荐

  1. css 样式设定

    阴影: --可以同时设定多个阴影.用逗号隔开 http://www.fly63.com/article/detial/4726 div { box-shadow: 10px 10px 5px #888 ...

  2. python+selenium之浏览器滚动条操作

    from selenium import webdriver import time #访问百度 driver=webdriver.Ie() driver.get("http://www.b ...

  3. CF708E-Student‘s Camp【数学期望,dp】

    正题 题目链接:https://www.luogu.com.cn/problem/CF708E 题目大意 有\(n*m\)的矩形网格,然后每次每行最左边和最右边的格子各有\(p=\frac{c}{d} ...

  4. Idea进行java应用的远程调试Remote debugging

    本文可以解决如下两个问题: 1.如何处理和调试那些只发生在生产环境(或其他远程环境)而本地开发环境可能没办法重现的"问题". 2.只有一个可以部署的war/jar包,只有class ...

  5. Git学习笔记02-配置

    安装好Git之后,做的就是需要配置Git了 第一步,配置自己的名称和邮箱 打开Git Bash 输入命令 git config --global user.name "用户名" g ...

  6. exe图标消失的解决方案

    步骤 win + r组合键打开运行窗口 输入cmd,回车 在终端窗口右键粘贴即可 taskkill /im explorer.exe /f cd /d %userprofile%\appdata\lo ...

  7. netty系列之:让TLS支持http2

    目录 简介 TLS的扩展协议NPN和ALPN SslProvider ApplicationProtocolConfig 构建SslContext ProtocolNegotiationHandler ...

  8. C++ 与 Visual Studio 2019 和 WSL

    Visual Studio 使用 C++ 的 Linux 开发(WSL) https://devblogs.microsoft.com/cppblog/c-with-visual-studio-201 ...

  9. Go 语言实现 gRPC 的发布订阅模式,REST 接口和超时控制

    原文链接: 测试小姐姐问我 gRPC 怎么用,我直接把这篇文章甩给了她 上篇文章 gRPC,爆赞 直接爆了,内容主要包括:简单的 gRPC 服务,流处理模式,验证器,Token 认证和证书认证. 在多 ...

  10. 移动端 h5 uniapp 读,写,删本地文件或sd文件

    移动端 h5 uniapp 读,写,删本地文件或sd文件 应用场景: 当我们需要做离线应用或者是加载本地文件时使用到此方法.(本篇文章给大家分享访问app私有文件目录,系统公共目录,sd外置存储的文件 ...