基础类型 - 数字类型(Number)

1.最基本的数据类型

2.不区分整型数值和浮点型数值

3.所有数字采用64位浮点格式存储,相当于Java和C语言中double格式

4.能表示的最大值 +- 1.7976931348623157 * 10308

5.能表示的最小值为 +-5 * 10 -324

6.NAN (not a number)属于Number类型的一种

整数:

  在javascript中10禁止的整数由数字的序列组成

  精准表达的范围是-9007199254740992(-253) 到 9007199254740992(253)

  超出范围的整数,精准度将受影响

浮点数:

  使用小数点记录数据

  例如:

    3.4  5.6

  使用指数记录数据

  例如:

    4.3e23 = 4.3 * 1023

16进制和8进制数的表达

  16进制数据前面加上0x,八进制前面加0

  16进制数是由0-9,A-F等16个字符组成

  8进制数由0-7等8个数字组成

  16进制和8进制与2进制的换算

基础类型 - 字符串(String)

1.是由unicode字符、数字、标点符号组成的序列

2.字符串常量收尾单引号或双引号

3.Javascript中没有字符类型

4.常用特殊字符在字符串中的表达

5.字符串中部分特殊字符必须加上右划线

6.常用的转义符 \n:换行   \':单引号  \":双引号   \\:右划线

String 数据类型的使用

  特殊字符的使用方法和效果

  unicode的插入方法

<script>
var str="\u4f\nwecome\"js编程\"";
</script>

基础类型 - 布尔型(Boolean)

1.仅有两种值:(在js 中 true/false 都是小写)

  true 代表 1

  false 代表 0

实际运算中 true = 1 , false = 0

2.布尔值也可以看作on/off、1/0对应、1/0对应true/false

3.Boolean 值主要用于Javascript的控制语句:if else .

    <script>
if(1){
alert("OK")
}else {
alert("NO")
}
</script> //输出为 OK

基础类型 - Null & Undefined

Undefined类型

  只有一个值,即Undefined.

  1.当申明的变量未初始化时,该变量默认值为Undefined.

  2.当函数无明确返回值时,返回值为Undefined.

    <script>
var x;
document.write("<h1>"+x+"</h1>") //输出: undefined
</script>

NUll类型

  1.只有一个值,专用值null,undefined实际上也是从值null派生来的,因此ECMAscript定义它们的值相等

  2.尽管这两个值相等,单它们的含义不同,undefined是声明了变量单未对其初始化时赋予该变量的值,null则用于表示尚未存在的对象.

  3.如果函数或方法要返回的是对象,name找都不到该对象时,返回的通常是null

<script>
var x = null;
</script>

数据类型转换

1.js 属于松散类型的程序语言

2.变量在声明的时候并不需要指定数据类型

3.变量只在赋值的时候才会确定数据类型

4.表达式中包含不同类型数据则在计算过程中会强制类型转换

例:

  数字 + 字符串 => 数字转换为字符串

  数字 + 布尔值 => 数字

  字符串 + 布尔值 => 布尔值转为字符串的true或false

规则:

字符串碰到数字或者布尔值,都会将后者转换成字符串.

字符串 > 数字 or 字符串 >布尔值

布尔值 = 数字

   <script>
//数字+字符
console.log(1+"2")
console.log("2"+1)
//
// //数字+布尔值
console.log(1+true)
console.log(1+false)
//
// //字符+布尔值
console.log('1'+true)
console.log('1'+false)
//1true
//1false
</script>

强制类型转换函数

parseInt()强制转换为数字
parseFloat()强制转换为浮点
eval()将字符串强制转换为表达式返回结果
<script>
//parseInt()强制转换为数字
//parseFloat()强制转换为浮点
console.log(parseInt('hello'))
console.log(parseInt('11111'))
console.log(parseInt('111he'))
console.log(parseInt('he111'))
// NaN
//
//
// NaN var x = eval('1+2')
console.log(x)
//
var x = eval('1>2')
console.log(x)
//false
</script>

类型查询函数(typeof)

运算符来判断一个值是否在某中类型的范围内.可以用这种预算符判断一个值是否表示一种原始类型.

    <script>
//typeof
console.log(typeof('hello world'));
console.log(typeof(123));
console.log(typeof(true));
console.log(typeof(null));
console.log(typeof(undefined));
console.log(typeof(parseInt('hello'+1))); console.log(typeof([1,2,3])); //string
//number
//boolean
//object
//undefined
//number
//object
</script>

JavaScript学习 - 基础(二) - 基础类型/类型转换的更多相关文章

  1. JavaScript学习记录二

    title: JavaScript学习记录二 toc: true date: 2018-09-13 10:14:53 --<JavaScript高级程序设计(第2版)>学习笔记 要多查阅M ...

  2. C#学习笔记二: C#类型详解

    前言 这次分享的主要内容有五个, 分别是值类型和引用类型, 装箱与拆箱,常量与变量,运算符重载,static字段和static构造函数. 后期的分享会针对于C#2.0 3.0 4.0 等新特性进行. ...

  3. JavaScript学习笔记(二)——闭包、IIFE、apply、函数与对象

    一.闭包(Closure) 1.1.闭包相关的问题 请在页面中放10个div,每个div中放入字母a-j,当点击每一个div时显示索引号,如第1个div显示0,第10个显示9:方法:找到所有的div, ...

  4. JavaScript学习总结(二)——闭包、IIFE、apply、函数与对象

    一.闭包(Closure) 1.1.闭包相关的问题 请在页面中放10个div,每个div中放入字母a-j,当点击每一个div时显示索引号,如第1个div显示0,第10个显示9:方法:找到所有的div, ...

  5. Javascript学习笔记二——操作DOM

    Javascript学习笔记 DOM操作: 一.GetElementById() ID在HTML是唯一的,getElementById()可以定位唯一的一个DOM节点 二.querySelector( ...

  6. JavaScript 学习笔记: 扩充类型的功能

    JavaScript 是允许给基本类型扩充功能的.例如,可以通过对Object.prototype增加方法,可以让该方法对所有的对象都可用. 这样的方式对函数,数组,字符串,数字,正则表达式和布尔值同 ...

  7. MVC3+EF4.1学习系列(二)-------基础的增删改查和持久对象的生命周期变化

    上篇文章中 我们已经创建了EF4.1基于code first的例子  有了数据库 并初始化了一些数据  今天这里写基础的增删改查和持久对象的生命周期变化 学习下原文先把运行好的原图贴来上~~ 一.创建 ...

  8. https学习笔记二----基础密码学知识和python pycrypto库的介绍使用

    在更详细的学习HTTPS之前,我也觉得很有必要学习下HTTPS经常用到的加密编码技术的背景知识.密码学是对报文进行编解码的机制和技巧.可以用来加密数据,比如数据加密常用的AES/ECB/PKCS5Pa ...

  9. 1. JavaScript学习笔记——JS基础

    1. JavaScript基础 1.1 语法 严格区分大小写 标识符,第一个字符可以是 $,建议使用小驼峰法, 保留字.关键字.true.false.null不能作为标识符 JavaScript是用U ...

随机推荐

  1. git-stash用法小结

    [时间:2016-10] [状态:Open] [关键词:git,版本控制,版本管理,stash,git储藏] 缘起 今天在看一个bug,之前一个分支的版本是正常的,在新的分支上上加了很多日志没找到原因 ...

  2. BZOJ4828 AHOI/HNOI2017大佬(动态规划+bfs)

    注意到怼大佬的操作至多只能进行两次.我们逐步简化问题. 首先令f[i][j]表示第i天结束后自信值为j时至多有多少天可以进行非防御操作(即恢复自信值之外的操作).这个dp非常显然.由于最终只需要保证存 ...

  3. HS BDC HDU - 3472(混合欧拉路径)

    题意: 就是混合欧拉路径板题 解析: 欧拉路径加一条t_ ---> s_  的边就变成了欧拉回路,所以利用这一点,如果存在两个奇点,那么这两个奇点出度大的是s_,入度大的是t_,加一条t_ -- ...

  4. day14 装饰器模拟验证附加功能

    user_list=[ {'}, {'}, {'}, {'}, ] current_dic={'username':None,'login':False} def auth_func(func): d ...

  5. python测试webservice接口

    1.下载库:https://pypi.python.org/pypi/suds-jurko 2.解压后,进入到解压目录,安装库:python3 setup.py install 3.测试获取手机归属地 ...

  6. hdu3516 Tree Construction (区间dp+四边形优化)

    构造方法肯定是把相邻两个点连到一起,变成一个新点,然后再把新点和别的点连到一起.... 设f[i,j]为把第i到j个点都连到一起的代价,那么答案就是f[1,n] f[i,j]=min{f[i,k]+f ...

  7. Elasticsearch 常见问题的解决思路

    本文为es性能监控基础的扩展,大家可以先看下性能监控基础,熟悉下es的基本原理.为翻译性质文档,感谢原作者,原始文档地址 类似于汽车的运行方式,Elasticsearch旨在让用户快速上手和运行,而无 ...

  8. 使用React.cloneElement()给子组件传值

    React提供了一个克隆组件的API: React.cloneElement( element, [props], [...child] ) 可以利用该方法,给子组件传值,使用如下: class Pa ...

  9. kafka安装以及入门

    一.安装 下载最新版kafka,Apache Kafka,然后上传到Linux,我这里有三台机器,192.168.127.129,130,131 . 进入上传目录,解压到/usr/local目录下 - ...

  10. (JAVA保留小数问题,基础)Probability hdu2131

    Probability 链接:http://acm.hdu.edu.cn/showproblem.php?pid=2131 Time Limit: 3000/1000 MS (Java/Others) ...