数据类型

JavaScript 和 Java 一样,也是有基本数据类型的。但也是有区别的。

JavaScript中的数据类型

简单(基本、值)数据类型
  • number
  • string
  • boolean
  • undefined、null
复杂(引用)数据类型
  • Object、Array、Date 等
查看当前变量的数据类型
  • typeof name
  • typeof (name)

数值字面量

字面量

固定的值,让你从“字面上”理解含义

数值字面量

var age = 18; //数值字面量,18为字面量

number类型

十进制

十六进制

var num = 0xA

八进制

浮点数

var n = 5e-324;

浮点数值的最高精确度是17位小数,在进行算术计算时,其精确度远远不如整数。

var result = 0.1+0.2 //结果不是0.3 而是0.300000000000000004

0.1+0.2 == 0.3 //false
0.1+0.3 == 0.4 //true 0.07 * 100 ;7.00000000000000001

想比较的话只能 0.1 * 10 ,然后 parseInt 转换,然后再相加比较。

永远不要测试某个特定的浮点数值是否相等。

数值范围

内存限制,ES无法保存世界上所有的数值

  • 最小值:Number.MIN_VALUE,5e-324
  • 最大值:Number.MAX_VALUE,1.7976931348623157e+308
  • 无穷大:Infinity
  • 无穷小:-Infinity

数值检测

NaN: not a number. 非数值

isNaN(); //是数字返回false;

console.log(parseInt("abc"));//NaN

console.log(parseInt("abc"/10));//NaN

var num = prompt("请输入一个数字")
if(isNaN(num)){
console.log("不是一个数字");
}else{
console.log("是一个数字"); }

String 类型

字符串字面量

 var name = "zhangsan"; // "zhangsan"是字面量

字符串用引号引起,单引号和双引号是一样的。

获取字符的长度用length

var name="hukj"; alert(name.length); //4

转移符

console.log("\"Ancona\"");

\n 换行

\t 制表符

\b 空格

\r 回车

\f 进纸

\ 斜杠

' 单引号

" 双引号

字符串的不可变

var str ="hello";
str = str+"world";
console.log(str);

当执行第二行代码时,会在内存空间中开辟新的栈,然后通过垃圾回收机制来清理原来的str。这就是所谓的字符串不可变。

字符串拼接

var a ='100';
var b =100; //b中的 number:100 会自动转型为str
console.log(a+b); //100100
console.log(a-b); //0

Boolean 类型

Boolean 类型有两个字面量:true 和 false;

var result = Boolean("a");

console.log(result); //true

Boolean 当为空字符串,0,NaN,null,undefined 时,为false;

Undefined 类型

undefined 是 Undefined 的字面量;表示变量未赋值。

var message;
console.log(message);// undefined var a; //undefined
if(a){ //false
alert('有值')
}else{
alert('无值') //显示
}

a未赋值为undefined,undefined在Boolean中转换为false;

javascript_03-数据类型的更多相关文章

  1. JavaScript 中的数据类型

    Javascript中的数据类型有以下几种情况: 基本类型:string,number,boolean 特殊类型:undefined,null 引用类型:Object,Function,Date,Ar ...

  2. JS 判断数据类型的三种方法

    说到数据类型,我们先理一下JavaScript中常见的几种数据类型: 基本类型:string,number,boolean 特殊类型:undefined,null 引用类型:Object,Functi ...

  3. Python高手之路【二】python基本数据类型

    一:数字 int int(整型): 在32位机器上,整数的位数为32位,取值范围为-2**31-2**31-1,即-2147483648-2147483647 在64位系统上,整数的位数为64位,取值 ...

  4. UniqueIdentifier 数据类型 和 GUID 生成函数

    UniqueIdentifier 数据类型用于存储GUID的值,占用16Byte. SQL Server将UniqueIdentifier存储为16字节的二进制数值,Binary(16),按照特定的格 ...

  5. SQL Server常见数据类型介绍

    数据表是由多个列组成,创建表时必须明确每个列的数据类型,以下列举SQL Server常见数据类型的使用规则,方便查阅. 1.整数类型 int 存储范围是-2,147,483,648到2,147,483 ...

  6. 由js apply与call方法想到的js数据类型(原始类型和引用类型)

    原文地址:由js apply与call方法想到的js数据类型(原始类型和引用类型) js的call方法与apply方法的区别在于第二个参数的不同,他们都有2个参数,第一个为对象(即需要用对象a继承b, ...

  7. python 数据类型 ----字典

    字典由一对key:value 组成的 python中常用且重量级的数据类型 1. key , keys, values 字典由一对key:value 组成的 python中常用且重量级的数据类型 1. ...

  8. SQL数据类型

    1.Character 字符串: 数据类型 描述 存储 char(n) 固定长度的字符串.最多8,000个字符. n varchar(n) 可变长度的字符串.最多8,000个字符.   varchar ...

  9. 跟着老男孩教育学Python开发【第二篇】:Python基本数据类型

    运算符 设定:a=10,b=20 . 算数运算 2.比较运算 3.赋值运算 4.逻辑运算 5.成员运算 基本数据类型 1.数字 int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**3 ...

  10. 我的MYSQL学习心得(二) 数据类型宽度

    我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...

随机推荐

  1. 【微信开发】微信小程序通过经纬度计算两地距离php代码实现

    需求: 要求做个根据用户当前位置获取周围商家地址,并且按照由近到远排序, 方法一: 代码层实现 封装方法: /** * @desc 根据两点间的经纬度计算距离 * @param float $lat ...

  2. Flink assignAscendingTimestamps 生成水印的三个重载方法

    先简单介绍一下Timestamp 和Watermark 的概念: 1. Timestamp和Watermark都是基于事件的时间字段生成的 2. Timestamp和Watermark是两个不同的东西 ...

  3. 【JS新手教程】LODOP打印复选框选中的内容

    在html中,复选框是常见的使用之一,本文介绍如何获取选中的复选框的值,并用LODOP打印.给需要为一组的复选框,复选框的checkbox设置相同的name属性,设置不同的id,然后设置需要的valu ...

  4. LODOP插件的IE浏览器的安全设置

    LodopFuncs.js里的判断默认是混合部署,IE等支持np插件的浏览器会走lodop插件方式,但是IE的安全设置可能会阻挡lodop插件,可点击允许或修改IE浏览器的安全设置让Lodop每次都能 ...

  5. 第07组 Alpha冲刺(3/4)

    队名:秃头小队 组长博客 作业博客 组长徐俊杰 过去两天完成的任务:完成人员分配,初步学习Android开发 Github签入记录 接下来的计划:继续完成Android开发的学习,带领团队进行前后端开 ...

  6. Uncaught Error: `setOption` should not be called during main process.

    主要是自己记笔记用,大佬些莫怪! 使用 echart 出现 :Uncaught Error: `setOption` should not be called during main process. ...

  7. 伸缩布局 Flex

    其中在webkit内核的浏览器中使用时,必须加上-webkit-前缀,采用Flex布局的元素,称为Flex容器(flex container),简称”容器”.它的所有子元素自动成为容器成员,称为Fle ...

  8. Deepin Linux下为Wine创建文件关联

    在Deepin Linux下,默认地,使用apt安装的Wine并没有创建文件关联,这使得在文件管理器中双击exe等Windows可执行文件时,不能直接运行.为此,必须手动在桌面环境中创建文件关联. 文 ...

  9. jupyter notebook选择conda环境

    需要安装: conda install ipykernel 使用:首先激活对应的conda环境 source activate 环境名称 将环境写入notebook的kernel中 python -m ...

  10. [转帖]单集群10万节点 走进腾讯云分布式调度系统VStation

    单集群10万节点 走进腾讯云分布式调度系统VStation https://www.sohu.com/a/227223696_355140 2018-04-04 08:18 云计算并非无中生有的概念, ...