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 ...
随机推荐
- Spring c3p0连接池配置
数据库连接池 数据库连接池的基本思想就是为数据库连接建立一个“缓冲池”.预先在缓冲池中放入一定数量的连接,当需要建立数据库连接时,只需从“缓冲池”中取出一个,使用完毕之后再放回去.我们可以通过设定连接 ...
- 【bzoj2115】[Wc2011] Xor DFS树+高斯消元求线性基
题目描述 输入 第一行包含两个整数N和 M, 表示该无向图中点的数目与边的数目. 接下来M 行描述 M 条边,每行三个整数Si,Ti ,Di,表示 Si 与Ti之间存在 一条权值为 Di的无向边. 图 ...
- 马士兵hadoop第三课:java开发hdfs(转)
马士兵hadoop第一课:虚拟机搭建和安装hadoop及启动 马士兵hadoop第二课:hdfs集群集中管理和hadoop文件操作 马士兵hadoop第三课:java开发hdfs 马士兵hadoop第 ...
- poj 2079 Triangle
Triangle Time Limit: 3000MS Memory Limit: 30000K Total Submissions: 9835 Accepted: 2951 Descript ...
- kswapd0 进程 设置 swap
kswapd0是虚拟内存管理中,负责换页,说白了就是你的物理内存不够用了 现在的服务器,一般内存都很高,所有很少使用 swap 分区了 这时候考虑的两种处理办法 加大物理内存 或者 增加swap分 ...
- HOJ - 2715最小费用流
国庆八天乐,刷题也快乐. HOJ崩了,但是VJ可以把题目挂出来. 题目链接:https://vjudge.net/contest/188441#problem/A 涉及到矩阵里面的网络流,化为图来做. ...
- jquery鼠标点击窗口或浮动层以外关闭层【阻止冒泡事件】
$(".up-list a.th1").click(function(){ $(this).next("ul#up-list-ul").show(); }); ...
- BZOJ3751 NOIP2014 解方程(Hash)
题目链接 BZOJ3751 这道题的关键就是选取取模的质数. 我选了4个大概几万的质数,这样刚好不会T 然后统计答案的时候如果对于当前质数,产生了一个解. 那么对于那些对这个质数取模结果为这个数的数 ...
- 某考试 T2 bomb
轰炸(bomb)[题目描述]有n座城市,城市之间建立了m条有向的地下通道.你需要发起若干轮轰炸,每轮可以轰炸任意多个城市.但每次轰炸的城市中,不能存在两个不同的城市i,j满足可以通过地道从城市i到达城 ...
- upper_bound——自己的实现
int BSearch() { int ln(1),rn(n+1); while(ln+1<rn) { int mid=(ln+rn)>>1; if (Check(mid)) { l ...