A.数据类型强制转换

1、转换为数值类型

Number(参数) 把任何的类型转换为数值类型

A.如果是布尔值,false为0,true为1

  var a=false;alert(Number(a)); a=0

B.如果是数字,转换成为本身。将无意义的后导0去掉    

  var a=3.2;alert(Number(a)); a=3.2

C.如果Null转换为0

  var a=null;alert(Number(a)); a=0

D.如果是undefined 转换为NaN not a number

  var a;alert(Number(a)); a=NaN

E.如果对象则会先调用对象的 valueOf(),如果valueOf()返回的是NaN,然后再调用对象的toString()

  var a={toString:function(){return 3;},valueOf:function(){return"abc";}}; alert(Number(a)) a=3

F.如果是字符串

  1.如果字符串当中只有数字,转换为10进制(忽略前导0和后导0)

    var a="0123.0";alert(Number(a)); a=123

  2.如果是有效的规范的浮点型,转换为浮点值(忽略前导0和后导0)

    var a="023.110";alert(Number(a)); a=23.11

  3.如果是空字符串,则转换为0

    var a="";alert(Number(a)); a=0

  4.如果是其他的值,返回NaN

    var a="chen";alert(Number(a)); a=NaN

parseInt(string,radix)  将字符串转换为整数

string 必需。要被解析的字符串。

radix 可选。表示要解析的数字的基数。该值介于 2 ~ 36 之间。如果省略该参数或其值为 0,则数字将以 10 为基础来解析。如果它以 “0x” 或 “0X” 开头,将以 16 为基数。如果该参数小于 2 或者大于 36,则 parseInt() 将返回 NaN。

A.如果一个字符串只包含数字,则以10进制的方式转换为整型

  var a="12.2";alert(parseInt(a)); a=12

B.他会自动忽略字符串前面的空格,知道找到第一个非空的数值字符串,直到解析到第一个非数值的字符串结束。

  var a=" 2a2";alert(parseInt(a)); a=2

  var a=" 21a2";alert(parseInt(a)); a=21

  C.如果字符串的第一个字符不是空格、数字、-,那么返回NaN

    var a=" a21a2";alert(parseInt(a)); a=NaN

parseFloat() 将字符串转换为浮点数

A.字符串当中的.只有第一个有效,其他的都是无效的。

  var a="12.2";alert(parseInt(a)); a=12.2

B.如果字符串是一个有效的整数,他返回的是整数,不会返回浮点数。

  var a="12";alert(parseInt(a)); a=12

  var a="12.0";alert(parseInt(a)); a=12

2、转换为数值类型

1. String(参数):可以将任何的类型转换为字符串

  null 结果 null

  undefined 结果 undefined

  true 结果 true

  false 结果 false

  1 结果 1

  数值类型 结果 本身的字符串

2.toString()---调用的格式:对象.toString()。作用是将对象以字符串的方式来表示

  array.toString() 结果 由,分割的字符串

    var arr=[a,b,c];alert(arr.toString()); a,b,c

  Boolean.toString() 结果 两个值 true false

    var a=true;alert(arr.toString()); true

  String.toString() 结果 返回本身

    var a="陈";alert(arr.toString()); 陈

  Number.toString(radix) 结果 返回本身的字符串形式

    var a=12;alert(arr.toString()); 12

    radix 可选。规定表示数字的基数,使 2 ~ 36 之间的整数。若省略该参数,则使用基数 10。但是要注意,如果该参数是 10 以外的其他值,则 ECMAScript 标准允许实现返回任意值。

  注意:null和undefined没有toString()方法

3、转换为布尔类型:Boolean()可以将任何类型的值转换为布尔值

转换为假: ""、 0、 NaN 、undefined、 false

其他的全部都转换为真

B.数据类型隐式转换

1.函数类

a.isNaN()

  该函数会对参数进行隐式的Number()转换,如果转换不成功则返回true;

  var a='a23';alert(isNaN(a)); true

  var a='23';alert(isNaN(a)); false

b.alert()输出的内容隐式的转换为字符串

  var a='23';alert(isNaN(a)); 23

2.运算符类

a.算数运算符 (- * / %)

如果操作数不是数值, 将会隐式的调用Number()函数,按照这个函数的转换规则进行转换,如果转换不成功,整个表达式返回NaN

var a='a23';var b='b23';alert(a+b); a23b23

var a='23';var b='bc';alert(a*b); NaN

*********加号(+)***********

*.如果操作数都是数值,然后进行相加

var a='2';var b='3';alert(a*b); 5

*.任何数据类型和字符串相加,都会隐私的调用他们的toString()方法,然后返回他们拼接的结果。

var a='2b';var b='c3';alert(a*b); 2bc3

*.如果操作数都是布尔值,那么进行Number()转换,false为0,true为1,进行相加。

var a=true;var b=false;alert(a+b); 1

var a=true;var b=true;alert(a+b); 2

b.关系运算符

关系运算符的操作数可以是任何类型,如果操作数不是数值类型,将会隐式的转换

1.运算的结果都是布尔值(ture;false)

2.都是字符串的时候,会转换成ASCII码再比较;多个字符串只比较首个,首个相等再比较下一个。

  var a='abv';var b='aba';alert(a>b);结果ture.

  ASCII码:a=a; -> b=b; -> v>a;

3.都是数值正常比较

4.当一个是字符串,一个为数值的时候;会把字符串转化为数值类型,然后进行比较,如果不能转换为数值类型,则会返回NaN,返回false

5.unfinished null

6.如果两个都是数值型字符串,那么他们也只是比较第一个。

  var a='223';var b='31';alert(a>b); == false

7.一个数值和布尔值比较,会把布尔值转化为数值后再较。

  false=0;true=1

c.等性运算符 (== !=)

会对操作数隐式的转换后再比较值

(1)如果其中至少有一个是布尔值,那么会隐式的调用Number()进行转换,然后比较。

(2)如果一个为字符串。另一个为数值,那么会隐式的调用Number()对字符串进行转换,如果转换不成功,则返回false;

(3) undefined == null

  (a) 比较字符串的时候是比较他们的ASCII码是否相等

  (b) 比较两个数值的时候是比较他们的数值是否相等

  (c) 比较函数的时候,判断他们的位置是否相等。

d.逻辑运算符

A. 放在表达式里面用于判断。

B. 给变量赋值

  var a= b && c

  如果一个运算数是对象,另一个是隐式的调用Boolean()函数,返回该对象。

  如果两个运算数都是对象,返回第二个对象。

  如果某个运算数是 null,返回 null。

  如果某个运算数是 NaN,返回 NaN。

  如果某个运算数是 undefined,发生错误。

  var a=b ||c

  如果一个运算数是对象,并且该对象左边的运算数隐式的调用Boolean()函数 值为 false,则返回该对象。

  如果两个运算数都是对象,返回第一个对象。

  如果最后一个运算数是 null,并且其他运算数值均为 false,则返回 null。

  如果最后一个运算数是 NaN,并且其他运算数值均为 false,则返回 NaN。

  如果某个运算数是 undefined,发生错误。

3、语句类

if(表达式){}else{}

格式: var 变量= Boolean expression?真值:假值

while(){}

if语句和三元表达式里面的表达式会隐式的调用Boolean()函数,按照这个函数的转换规则,转换为相应的布尔值

javascript笔记整理(数据类型强制/隐式转换 )的更多相关文章

  1. JavaScript的六种数据类型与隐式转换

    一.六种数据类型 javascript的数据类型包括: (1)基本数据类型:number.string.boolean.null.undefined (2)对象:object object又包括Fun ...

  2. javascript深入浅出——学习笔记(六种数据类型和隐式转换)

    在慕课之前学过JS深入浅出,最近发现很多东西都记不太清楚了,再复习一遍好了,感觉这个课程真的超级棒的,做做笔记,再添加一些学习内容

  3. oracle数据类型及其隐式转换

    oracle有三种最基本的数据类型,即字符型.数值型.日期型. oracle提供的单行函数中,针对不同的数据类型,提供大量实用的函数,同时提供一系列数据类型转换函数,如下: 1)to_char     ...

  4. 数据类型,隐式转换以及json,对象,引用类型,预解析 视频教程

    随便看看,需要有一点一点基础. 链接:http://pan.baidu.com/s/1c20pcOC 密码:xq2x

  5. js中的数据类型隐式转换的三种情况

    js的数据类型隐式转换主要分为三种情况: 1. 转换为boolean类型 2. 转换为number类型 3. 转换为string类型 转换为boolean类型 数据在 逻辑判断 和 逻辑运算 之中会隐 ...

  6. SQL Server有意思的数据类型隐式转换问题

    写这篇文章的时候,还真不知道如何取名,也不知道这个该如何将其归类.这个是同事遇到的一个案例,案例比较复杂,这里抽丝剥茧,仅仅构造一个简单的案例来展现一下这个问题.我们先构造测试数据,如下所示: CRE ...

  7. JavaScript学习笔记——数据类型强制转换和隐式转换

    javascript数据类型强制转换 一.转换为数值类型 Number(参数) 把任何的类型转换为数值类型 A.如果是布尔值,false为0,true为1 B.如果是数字,转换成为本身.将无意义的后导 ...

  8. JavaScript复习之--javascript数据类型隐式转换

    JavaScript数据类型隐式转换.一,函数类    isNaN()    该函数会对参数进行隐式的Number()转换,如果转换不成功则返回true.    alert()    输出的内容隐式的 ...

  9. Web | JavaScript的引用数据类型强制转换类型

    我在这里主要的想提下的是JavaScript中的引用类型进行强制转换类型.因为对于基本数据类型的变换大多都是雷同的,很容易熟知,但是引用数据类型有一点小插曲. JavaScript的引用类型主要为对象 ...

随机推荐

  1. Python学习之路——迭代器、生成器、算法基础、正则

    一.迭代器: 迭代器是访问集合元素的一种方式. 迭代器对象是从集合的第一个元素开始访问,直到所有的元素被访问完结束. 迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退. 另外,迭代 ...

  2. 顺为资本CEO许达来:为什么说中国创业者很幸福?(附PPT)

    顺为资本创始合伙人许达来 编者按:许达来,顺为资本创始合伙人及CEO,代表性投资项目包括小米科技.丁香园.一起作业.加一联创.金山软件及兴达国际等. 本文为许达来在新浪创业举办的新创课活动上的内容分享 ...

  3. ListView.MultiChoiceModeListener

    参考:http://www.cnblogs.com/a284628487/p/3460400.html和http://blog.csdn.net/mayingcai1987/article/detai ...

  4. Flash中用AS3做的游戏,导出apk安装到手机上滤镜效果出不来为什么?

    主要原因是,导出apk文件时渲染模式设置成了GPU.改掉就行了.

  5. filter过滤器的使用

    从J2EE1.3开始,Servlet2.3规范中加入了对过滤器的支持.过滤器能够对目标资源的请求和响应进行截取.过滤器的工作方式分为四种,下面让我们分别来看看这四种过滤器的工作方式: 1.reques ...

  6. [Swust OJ 352]--合并果子(贪心+队列模拟)

    题目链接:http://acm.swust.edu.cn/problem/352/ Time limit(ms): 1000 Memory limit(kb): 65535   Description ...

  7. CentOS6.5 下在Nginx中添加SSL证书以支持HTTPS协议访问

    参考文献: 1. NginxV1.8.0安装与配置 2. CentOS下在Nginx中添加SSL证书以支持HTTPS协议访问 3. nginx配置ssl证书的方法 4.nginx强制使用https访问 ...

  8. 二维码类库--phpqrcode使用简介

    #载入类文件 include 'phpqrcode.php'; $value = '二维码内容'; $errorCorrectionLevel = 'L';//容错级别 L.M.Q.H $matrix ...

  9. 10个值得我们关注的python博客

    大家好,还记得我当时学习python的时候,我一直努力地寻找关于python的博客,但我发现它们的数量很少.这也是我建立这个博客的原因,向大家分享我自己学到的新知识.今天我向大家推荐10个值得我们关注 ...

  10. python读取EXCLE文件数据

    python读取EXCEL,利用 Google 搜索 Python Excel,点击第一条结果http://www.python-excel.org/ ,能够跨平台处理 Excel. 按照文档一步步去 ...