JavaScript变量转换
JavaScript变量转换
目录
一、自动转换
"=="的自动转换
自动转换优先级:number>boolean>String,越小越先转换
(1)Number与Boolean:
console.log(0==false); //true
console.log(1==true); //true
console.log(2==true); //flase
//这个过程其实是Boolean类型转换为数字的过程
(2)Number与String:
console.log(""==0); //true
console.log("12"==12); //true
console.log("12a"==12); //false
//String自动转换时只能转换纯数字的字符串
(3)String与Boolean
console.log(""==false); //true
console.log("s"==true); //true
//字符串转换为boolean均为true
(4)null的自动转换
null的本质是空对象,自动转换时会处理空对象的引用地址,转换为数字与其他对象的处理
console.log(null==0); //false
//地址是数字,且肯定不是0
console.log(null==false); //false
console.log(null==true); //false
//地址是数字,比较时会将boolean转换为数字
console.log(null=="null"); //false
console.log(null==""); //false
//地址为数字,比较时会将String转换为数字
(5)undefined的自动转换
undefined表示未定义,不带任何东西,大家可以理解为老顽固(偷笑)
console.log(undefined==0); //false
//无法自动转换数字
console.log(undefined==false); //false
console.log(undefined==true); //false
//无法自动转换boolean
console.log(undefined==""); //false
console.log(undefined=="undefined"); //false
//无法自动转换为String
console.log(undefined==null); //true
console.log(undefined===null); //false
//null是空对象,会被认为是undefined,但严格的来说两者是不相等的
二、强制转换
1、运算强制转换
"+"会尝试将两端的值尝试转换为字符串或数字。优先级:String>Number
(1)Number与Boolean:
console.log(1+false); //1
console.log(1+true); //2
(2)Number与String:
console.log(""+1); //"1"
console.log("1"+1); //"11"
//运算时,String优先级大于Number,Number转换为String
(3)String与Boolean
console.log(""+false); //false
console.log(""+true); //true
console.log(typeof(""+true)); //String
//按照优先级,会将boolean转换为String
(4)null
console.log(null+1); //1
//null的本质是空对象,强制转换会转换为0
(5)undefined
console.log(undefined+0); //NaN
//强制转换数字时为NaN
console.log(Boolean(undefined)); //false
2、类型强制转换
(1)Number
String:
这里说下String()和toString()的区别
toString()可以将除了null、undefined以外的一切对象转换为String,且toString()可以接收第二个参数,将字符串的进制进行改变
String()可以将任何对象转换为String,String只有一个传参
Boolean:
console.log(Boolean(0)); //false
console.log(Boolean(1)); //true
console.log(Boolean(2)); //true
console.log(Boolean(-2)); //true
//除0以外均为true
(2)String
Number:
console.log(Number("1")); //1
console.log(Number("1a")); //NaN
console.log(parseInt("1a")); //1
console.log(parseInt("a1")); //NaN
//使用Number进行转换时必须是纯数字字符串,否则为NaN
//使用parseInt转换时,头部必须有数字,否则为NaN
//parseInt是全局函数,不属于Number,与Number强制转换有区别
Boolean:
console.log(Boolean("")); //false
console.log(Boolean("true")); //true
console.log(Boolean("false")); //true
//String为空是flase,其他均为true
(3)Boolean
Number:
console.log(Number(false)); //0
console.log(Number(true)); //1
String:
输出对应的字符串
(4)null
Number:
console.log(Number(null)); //0
String:
输出对应的字符串
Boolean:
console.log(Boolean(null)); //false
(5)undefined
Number:
console.log(Number(undefined)); //NaN
//此种方式强制转换依旧为非数字
String:
输出对应的字符串
Boolean:
console.log(Boolean(undefined)); //false
码字不易,后面还会放出各种文章,喜欢的关注一下我吖,你们的关注是我最大的动力
github:github.com/hn-failte
个人博客:hn-failte.github.io
JavaScript变量转换的更多相关文章
- 六天玩转javascript:javascript变量与表达式(1)
说明 本系列属于进阶系列,语常用语法等不在本系列介绍范围之内. 在我刚开始做一个程序员并开发项目的时候,我总是喜欢使用开发语言的各种特性,每次m$发布新版C#的时候我总是会把开发者预览版下好,亲自体验 ...
- JavaScript 变量、类型与计算
变量类型 变量计算 变量 题目: JavaScript 中使用typeof能得到的有哪些类型? ``` 1.1 变量类型 (1).js中的数据类型:字符串.数字.布尔.数组.对象.Null.Undef ...
- JavaScript 基础(一) - JavaScript的引入方式,JavaScript 变量命名规则,JS 的五种基本数据类型,ECMAScript 算数运算符,逻辑运算符
JavaScript的引入方式 直接编写 <!DOCTYPE html> <html lang="en"> <head> <meta ch ...
- javascript变量的作用域
javascript变量的作用域 基本类型和引用类型 基本类型值指的是简单的数据段,而引用类型值指的是那个可能由多个值组成的对象 讲一个值赋值给变量时,javascript解析器首先要确定是基本类型 ...
- JavaScript 变量声明提前
<JavaScript权威指南>中指出:JavaScript变量在声明之前已经可用,JavaScript的这个特性被非正式的称为声明提前(hoisting),即JavaScript函数中声 ...
- JavaScript 变量
一,JavaScript 变量(存储信息的容器) 与代数一样,JavaScript 变量可用于存放值(比如 x=2)和表达式(比如 z=x+y). 变量可以使用短名称(比如 x 和 y),也可以使用描 ...
- javascript变量声明 及作用域
javascript变量声明提升(hoisting) http://openwares.net/js/javascript_declaration_hoisting.html 可能要FQ一下 java ...
- JavaScript 变量作用域
一. 变量声明 变量用var关键字来声明,如下所示: 变量在未声明的情况下被初始化,会被添加到全局环境. JavaScript执行代码时,会创建一个上下文执行环境,全局环境是最外围的环境.每个函数在被 ...
- 【转】javascript变量声明 及作用域
javascript变量声明提升(hoisting) javascript的变量声明具有hoisting机制,JavaScript引擎在执行的时候,会把所有变量的声明都提升到当前作用域的最前面. 先看 ...
随机推荐
- MWeb for Mac使用教程-如何在文档库中快速搜索
使用MWeb for Mac专业的 Markdown 编辑写作软件,可以让你随时记录自己的想法,灵感,创意,为您的工作节省宝贵的时间.本篇文章带来的是MWeb for Mac如何在文档库中快速搜索使用 ...
- zz-人生感悟
1. 社交感想 首先来看一下聪明人和普通人的区别是什么? 普通人思考问题都是一步一步的来,由A推理出B,B推导到C,再推导出D,最后得出E,然而聪明人却可以由A直接推算到E. 这就像开车,普通人的是手 ...
- 博客七----tensorflow-gpu安装满满填坑
具体内容见我的开源中国教程:https://my.oschina.net/u/3770644/blog/3043073 因为编写习惯原因,我的大多数详细教程在开源中国中.有兴趣的大家打开连接就好 强调 ...
- python 常忘代码查询 和autohotkey补括号脚本和一些笔记和面试常见问题
笔试一些注意点: --,23点43 今天做的京东笔试题目: 编程题目一定要先写变量取None的情况.今天就是因为没有写这个边界条件所以程序一直不对.以后要注意!!!!!!!!!!!!!!!!!!!!! ...
- C#下载Url文件到本地
protected void Page_Load(object sender, EventArgs e) { string filePath = Request.Params["FilePa ...
- 上传文件,经过Zuul,中文文件名乱码
问题描述: 在学习<SpingCloud与Docker微服务架构实战>8.7节 使用Zuul上传文件,测试通过Zuul上传中文文件时出现,文件名.目录名或卷标语法不正确异常:但是直接通过上 ...
- ----regular expression in js----
正则表达式:Regular Expression,在代码中常简写为regex.regexp或RE)使用单个字符串来描述.匹配一系列符合某个句法规则的字符串搜索模式. 搜索模式可用于文本搜索和文本替换. ...
- 口试Linq题
LINQ to SQL与IQueryable 理解IQueryable的最简单方式就是,把它看作一个查询,在执行的时候,将会生成结果序列. LINQ to Object和LINQ to SQL有何区别 ...
- C++标准库第二版笔记 3 和异常的理解 1
C++标准库第二版笔记 3 和异常的理解 1 差错和异常(error and exception)的处理 标准异常类(exception class) 定义于 分为: 1.语言本身支持的异常 2.标准 ...
- Hibernate中的实体规则、对象状态和进阶-一级缓存
一.hibernate中的实体规则 1.实体类创建的注意事项 2.主键类型 3.主键生成策略 (1)代理主键 (2)自然主键 二.hibernate中的对象状态 1.对象分为三种状态 2.三种状态的转 ...