一、数据类型的转换

  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. java 工具类 验证码

    第一步: 引入工具类 工具类一: import java.awt.Color; import java.awt.Font; import java.awt.Graphics2D; import jav ...

  2. Oracle基本入门

    一.数据的存储 1.java 程序中的对象:数组.集合保存.当运行的程序结束的时候,里面的数据就消亡. 2.文件存储系统: 存在的缺陷: 2.1)没有明确的数据类型划分. 2.2)没有用户身份验证机制 ...

  3. CF1039D-You Are Given a Tree【根号分治,贪心】

    正题 题目链接:https://www.luogu.com.cn/problem/CF1039D 题目大意 给出\(n\)个点的一棵树,然后对于\(k\in[1,n]\)求每次使用一条长度为\(k\) ...

  4. JavaScript 实现Sleep方法(多个setTimeout同步执行)

    前言 JavaScript是单线程的,如果所有操作都是同步,必将线程堵塞,页面失去响应.因此JavaScript采用了事件驱动机制,在单线程模型下,使用异步回调函数的方式来实现非阻塞的IO操作.因此也 ...

  5. node ***.js或npm run scripts的脚本命令出现Cannot find module 'react-dev-utils/getPublicUrlOrPath'报错的解决办法

    出现类似Cannot find module 'react-dev-utils/getPublicUrlOrPath'一般是项目中没有下载报错中提到的模块(可以在项目中package.json文件de ...

  6. 分片利器 AutoTable:为用户带来「管家式」分片配置体验

    在<DistSQL:像数据库一样使用 Apache ShardingSphere>一文中,Committer 孟浩然为大家介绍了 DistSQL 的设计初衷和语法体系,并通过实战操作展示了 ...

  7. 题解 [PA2019]Trzy kule

    link Description 对于两个长度为 \(n\) 的 \(01\) 串 \(a_1,a_2,\dots,a_n\) 和 \(b_1,b_2,\dots,b_n\),定义它们的距离 \(d( ...

  8. 破解安装pyhotn

    1.网址 https://www.jetbrains.com/pycharm/download/#section=windows,打开页面,点击下载专业版 2.这是下载好的文件,双击运行即可. //详 ...

  9. Java读取属性配置文件-properties

    在项目开发中,我们难免将一些可变的参数放在程序以外,作为一个单独的文件,即配置文件,这样方便项目在不同的使用环境部署时.或者说需要不同时,可以通过简单配置这些程序以外的文件来修改程序里的变量. 常用的 ...

  10. javascript-原生-结构

    1.获取用户输入内容的方法 window.prompt("提示信息","默认值"); 获取用户输入内容(字符串类型),返回用户输入内容. 2.顺序结构:所有语句 ...