javascript 高级编程系列 - 基本数据类型
javascript中的基本数据类型包括:
Undefined, Null, Boolean, Number, String 5种数据类型
1. Undefined 类型 (只有一个值 undefined, 常被用来表示未初始化的变量)
- 如果一个变量未进行初始化则它的初始值为undefined, 数据类型为Undefined
var myVar;
myVar === undefined // return true
typeof myVar === 'undefined' // return true
- 函数的参数列表中,未传入的实参的形参其值为undfined
function sum(a, b){
if(b === undefined) b = 0;
return a + b;
}
sum(1,2); // return 3
sum(1); // return 1, 其中第二个参数未传递值,则其值为undefined,
2. Null 类型 (只有一个值 null, 常被用来表示一个空对象指针)
- 由于用来表示空对象,所以 typeof null === 'object'
- 由于undefined 值派生自 null值,所以 null == undefined
3. Boolean 类型 (有两个值:true, false)
- 数据类型转换使用 Boolean()
String: Boolean('str'); // true
Boolean(''); // false
Number: Boolean(2); // true
Boolean(0); // false
Object: Boolean({}); // true
Null: Boolean(null); // false
Undefined: Boolean(undefined); // false;
4. String 类型
- 数据类型转换
var myVar = 5;
String(5); // return '5' 将任意类型转为字符串
myVar.toString(); // return '5', undefined 与 null 值没有此方法
myVar.toString(2); // return '101', 以二进制的形式返回
myVar += ''; // return '5', 利用数据自动转换
5. Number 类型
- 浮点型 由于计算舍入误差 最好不要用在条件测试中
- 整型 8进制在严格模式下无效
- 最大值 Number.MAX_VALUE, 最小值 Number.MIN_VALUE
- 正无穷大 Number.POSITIVE_INFINITY, 负无穷大 Number.NEGATIVE_INFINITY, 函数isFinite(value) 用于断定一个数值是否介于正无穷和负无穷之间
- NaN 表示一个不是数值的值, 函数isNaN(value) 用于判断一个值进行数据类型转换后是不是 '不是数值'
- 数据类型转换 Number() , parseInt(), parseFloat()
Number() : 可以转换任意类型的数据, 下面的表达式均返回true
Number(undefined) === NaN;
Number(null) === 0;
Number('34') === 34;
Number('34df') === NaN;
Number('') === 0;
Number(true) === 1;
Number(false) === 0;
Number({}) === NaN;
parseInt(): 主要用于将字符串转换为整型类型, 第二个参数可以指定进制
parseInt(' 12df') === 12
parseInt('2.4dd') === 2
parseInt('') === NaN
parseInt('10', 10) === 10
parseInt('10', 2) === 2
parseFloat(): 用于将字符串转为浮点型数据,规则与parseInt相似,但没有第二个参数但,只能转为10进制浮点数
javascript 高级编程系列 - 基本数据类型的更多相关文章
- javascript 高级编程系列 - 函数
一.函数创建 1. 函数声明 (出现在全局作用域,或局部作用域) function add (a, b) { return a + b; } function add(a, b) { return a ...
- javascript 高级编程系列 - 继承
1. 原型链继承 (缺点:子类继承父类的引用类型的属性值会在各个实例中共享,创建子类实例时无法向父类构造函数传递参数) // 定义父类构造函数 function SuperClass(father, ...
- javascript 高级编程系列 - 创建对象
1. 工厂模式 function createPerson(name, age) { var obj = {}; obj.name = name; obj.age = age; obj.getName ...
- javascript高级编程笔记01(基本概念)
1.在html中使用JavaScript 1. <script> 元素 <script>定义了下列6个属性: async:可选,异步下载外部脚本文件. charset:可选, ...
- JavaScript高级编程———JSON
JavaScript高级编程———JSON < script > /*JSON的语法可以表达一下三种类型的值 简单值:使用与javas相同的语法,可以在JSON中表达字符串.数值.布尔值和 ...
- JavaScript高级编程———基本包装类型String和单体内置对象Math
JavaScript高级编程———基本包装类型和单体内置对象 <script> var stringObject = new String("hello world") ...
- JavaScript高级编程——Date类型
JavaScript高级编程——Date类型 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml" ...
- JavaScript高级编程——Array数组迭代(every()、filter()、foreach()、map()、some(),归并(reduce() 和reduceRight() ))
JavaScript高级编程——Array数组迭代(every().filter().foreach().map().some(),归并(reduce() 和reduceRight() )) < ...
- JavaScript高级编程——引用类型、Array数组使用、栈方法
JavaScript高级编程——引用类型.Array数组使用.栈方法 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999 ...
随机推荐
- 利用ajax实现数据传输
AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML). AJAX 不是新的编程语言,而是一种使用现有标准的新方法. AJAX 是与服 ...
- 【bzoj1002】[FJOI2007]轮状病毒 矩阵树定理+高精度
题目描述 轮状病毒有很多变种,所有轮状病毒的变种都是从一个轮状基产生的.一个N轮状基由圆环上N个不同的基原子和圆心处一个核原子构成的,2个原子之间的边表示这2个原子之间的信息通道.如下图所示 N轮状病 ...
- 【Luogu】P3389高斯消元模板(矩阵高斯消元)
题目链接 高斯消元其实是个大模拟qwq 所以就着代码食用 首先我们读入 ;i<=n;++i) ;j<=n+;++j) scanf("%lf",&s[i][j]) ...
- poj 2492 A Bug's Life 二分图染色 || 种类并查集
题目链接 题意 有一种\(bug\),所有的交往只在异性间发生.现给出所有的交往列表,问是否有可疑的\(bug\)(进行同性交往). 思路 法一:种类并查集 参考:https://www.2cto.c ...
- hdu4635 有向图最多添加多少边使图仍非强连通
思路:先缩点成有向无环图,则必然含有出度为0的点/入度为0的点,因为要使添加的边尽量多,最多最多也就n*(n-1)条减去原来的m条边,这样是一个强连通图,问题转化为最少去掉几条,使图不强连通,原来图中 ...
- 在线扩展根分区 red hat 4.8.3-9
跑程序的时候发现报错,提示空间不足,仔细查看后发现是根分区已满 27G的空间只有20k剩余 考虑从/data分区压缩一点空间到/分区 切换到root用户 执行下面的命令 1. umount /data ...
- 焦作F Modular Production Line 费用流
题目链接 题解:这道题比赛的时候,学弟说是网络流,当时看N这么大,觉得网络流没法做,实际本题通过巧妙的建图,然后离散化. 先说下建图方式,首先每个覆盖区域,只有左右端点,如果我们只用左右端点的话,最多 ...
- Latex algorithm
方式一 需要包含的 \usepackage[noend]{algpseudocode} \usepackage{algorithmicx,algorithm} 源码 \begin{algorithm} ...
- Codechef Black Nodes in Subgraphs(树型背包)
题目链接 Black Nodes in Subgraphs 题目意思就是在一棵树中所有点标记为两种颜色(黑和白) 然后询问是否存在大小为X恰好有Y个黑点的连通块 这题我们可以用树型背包的方法 设$f[ ...
- KeyStore和TrustStore
笔者的这篇文章参考了http://docs.oracle.com/cd/E19509-01/820-3503/ggfgo/index.html KeyStore和TrustStore在很多HTTPS双 ...