JavaScript权威指南--第3章 类型、值和变量
在编程语言中,能够表示并操作的值(value)的类型称作数据类型(type).使用变量来储存值。JavaScript中数据类型有两种:原始类型(primitive type/基本数据类型)和对象类型(object type/引用数据类型)。
数字
整形直接量
十进制整数
十六进制值(0x为前缀)
严格模式下,不支持八进制(0为前缀)
浮点型直接量
整数+小数点( . ) + 小数部分: 3.14
指数计数法: 6.2e5 === 620000
JavaScript中的算数运算
基本运算符:加 +、减 -、乘 *、除 /、取余 %
复杂运算符:Math对象的属性定义函数和常量
溢出:Infinity,-Infinity(超过JavaScript所能表示的数字上限,基于其的运算结果还是无穷值)
下溢:0,-0 (运算结果无限接近于0)
0/2; // 0 2/0; // Infinity
-2/0; // -Infinity
0/0; // NaN
NaN与任何值都不相等包括他自己(判断一个变量是否为notanumber 使用x != x)
0 === -0; // true
1/0 == 1/-0; // false
二进制浮点数和四舍五入错误
使用二进制表示法可精确表示1/2,1/8,1/1024
0.3-0.2 == 0.2-0.1; // false
日期和时间
Date()
var before = new Date(2011, 0, 1); // 2011年1月1日
var after = new Date(2011, 0, 1, 10, 10, 30); // 2011年1月1日10点10分30秒
var now = new Date(); // 获取现在的日期和时间
var elapse = now - before; // 日期减法,计算时间间隔的毫秒数
after.getFullYear(); // 获取年 2011
after.getMonth(); // 获取月(从0开始计数) 0
after.getDate(); //获取日(从1开始计数) 1
after.getDay(); // 获取星期(0代表周日,5代表星期一) 6
after.getHours(); // 获取小时 10
after.getUTCHours(); //基于时区的小时 2
文本
字符串(string)是一组由16位值组成的不可变的有序序列。
字符串直接量
单引号(' ')或双引号(" ")
字符串拆行:每一行以反斜线(\)结束
转义 \(英文转义 today\'s)
转义字符
| 转义字符 | 含义 |
| \o | NULL字符(\u0000) |
| \b | 退格符(\u0008) |
| \t | 水平制表符(\u0009) |
| \n | 换行符(\u000A) |
| \v | 垂直制表符(\u000B) |
| \f | 换页符(\u000C) |
| \r | 回车符(\u000D) |
| \" | 双引号(\u0022) |
| \' | 撇号或单引号(\u0027) |
| \\ | 反斜线(\u005C) |
字符串的使用
字符串拼接 +
字符串长度 length
常用字符串调用方法:
var s = 'hello world';
s.charAt(3); // "l"
s.substring(1, 5); // "ello"
s.slice(1, 5); // "ello"
s.slice(-3); // "rld"
s.indexOf('l'); //
s.lastIndexOf('l'); //
s.indexOf('l', 3); //
s.split(' '); // ["hello", "world"]
s.replace('h', 'H'); // "Hello world"
s.toUpperCase(); // "HELLO WORLD"
模式匹配
RegExp()
var text = "testing: 1, 2, 3";
var pattern = /\d+/g; // 匹配所有包含一个或多个数字的实例
pattern.test(text); // true
text.search(pattern); //
text.match(pattern); // ["1", "2", "3"]
text.replace(pattern, '#'); // "testing: #, #, #"
text.split(/\D+/); // ["", "1", "2", "3"]
布尔值
true:
false:undefined,null,0,-0,NaN,“”(空字符串)
null和undefined
null == undefined; // true
null === undefined; // false
全局对象
包装对象
不可变的原始值和可变的对象引用
原始值(undefined,null,布尔值,数字和字符串)不可改变;
原始值的比较是值的比较:值相等时就相等,在字符串中,长度相等且每个索引的字符都相等时才相等
对象(object、array,function):值可修改,储存的是指向值的内存地址
对象的比较并非值的比较:
var o = {x:1}, q = {x:1}
o == q // false
o === q // false
var m = [], n = []
n == m // false
n === m // false
var a = [];
var b = a;
b[0] = 1;
a[0] //
a === b // true
类型转换
| 值(value) | 转换为字符串 | 转换为数字 | 转换为布尔值 | 转换为对象 |
| undefined | "undefined" | NaN | false | TypeError |
| null | "null" | 0 | false | TypeError |
| true | "true" | 1 | true | new Boolean(true) |
| false | "false" | 0 | false | new Boolean(false) |
| ""(空字符串) | "" | 0 | false | new String("") |
| "1.2"(非空,数字) | "1.2" | 1.2 | true | new String("1.2") |
| "abf"(非空,非数字) | "abf" | NaN | true | new String("abf") |
| 0 | "0" | false | new Number(0) | |
| -0 | "0" | false | new Number(-0) | |
| NaN | "NaN" | false | new Number(NaN) | |
| Infinity | "Infinity" | true | new Number(Infinity) | |
| -Infinity | "-Infinity" | true | new Number(-Infinity) | |
| 1(无穷大,非零) | "1" | true | new Number(1) | |
| {}(任意对象) | ① | ② | true | |
| [](任意数组) | "" | 0 | true | |
| [12](数字元素) | "12" | 12 | true | |
| ['as'](其他元素) | join() | NaN | true | |
| function(){}(任意函数) | ③ | NaN | true |
转换和相等性 ( == )
一个值转化为另一个值并不代表两个值相等。'=='运算符从不试图将其他操作数转化为布尔值。
null == undefined // true
"0" == 0 // true
0 == false // true
"0" == false // true
5 undefined == false // false
显示类型转化
Number()、String()、Boolean([ ])、Object()、toString()
x+ "" // 等价于String(x)
+x // 等价于Number(x)
!!x // 等价于Boolean(x)
parseInt():解析整数。若第一个非空字符不是数字直接量,将返回NaN
parseFloat():解析整数和浮点数。若第一个非空字符不是数字直接量,将返回NaN
对象转化为原始值
对象到布尔值:所有的对象都转化为true
对象到字符串和对象到数字:通过调用待转换的对象的一个方法来完成(本地对象。宿主对象)
toString()
valueOf():如果存在任意原始值,他就默认将对象转化为表示他的原始值。对象是复合值简单返回对象本身。
变量声明
var,let,const
使用var语句重复声明变量是合法且无害的。
变量作用域
全局作用域,局部作用域
定义全局作用域可以省略var
在函数体内,局部变量的优先级高于同名的全局变量
函数作用域和声明提前
变量作用域是指在函数内声明的所有变量在函数体内都是可见的。意味着函数里生命的所有变量(不涉及赋值)都被提前到函数体的顶部。
作为属性的变量
全局变量是全局对象的属性。
使用var声明的变量创建的属性是不可配置的
作用域链
作用域链是一个对象列表或链表。
JavaScript权威指南--第3章 类型、值和变量的更多相关文章
- 【笔记】javascript权威指南-第三章-类型,值和变量
javascript中的原始类型和对象类型(基本类型和引用类型) //本书是指:javascript权威指南 //以下内容摘记时间为:2013.7.27 计算机程序运行时需要对值(value ...
- JavaScript权威指南第03章 类型、值和变量(1)
版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/huangbin10025/article/details/27953481 类型.值和变量 数据类型 ...
- 【笔记】javascript权威指南-第六章-对象
对象 //本书是指:javascript权威指南 //以下内容摘记时间为:2013.7.28 对象的定义: 1.对象是一种复合值:将很多值(原始值或者对象)聚合在一起,可以通过名字访问这些值. ...
- javascript权威指南第11章 DOM扩展
//javascript 权威指南 第三版 第11章 DOM扩展 //取得body元素 var body = document.querySelector("body"); //取 ...
- javascript权威指南第20章 JSON
//20.1 语法 //JAVASCRIPT 是对JSON数据支持的. //JSON 可以申明三种类型的值 简单值("hello world") 对象({"name&qu ...
- javascript权威指南第16章 HTML5脚本编程
<!DOCTYPE html> <html> <head> <script type="text/javascript" src=&quo ...
- javascript权威指南第14章 表单脚本示例代码
HTML部分 <!DOCTYPE html> <html> <head> <title></title> </head> < ...
- javascript权威指南第13章 事件示例代码
html 部分 <!DOCTYPE html> <html> <head> <title>Event Bubling Example</title ...
- javascript权威指南第12章DOM2 DOM3 示例代码
<html xmlns="http://www.w3.org/1999/xhtml"> <head> <title> Example XHTML ...
随机推荐
- this应用详解-js原生
学习记录,以防遗忘,适合新手解惑.老鸟避让! 在微信H5的开发中,很多页面都是简单的一个模型item在加上很多很多数据组成起来的.例如微信朋友圈,仔细观察,他的一个基本模型就是 “头像图片 + 用户昵 ...
- node遍历文件夹并读取文件内容
var fs = require('fs'); var path = require('path');//解析需要遍历的文件夹 var filePath = path.resolve('./dist' ...
- flask 第五章 WebSocket GeventWebsocket 单聊群聊 握手 解密 加密
1.WebSocket 首先我们来回顾一下,我们之前用socket学习过的项目有: 1.django 2.flask 3.FTP - 文件服务 HTTP - TCP (特点): 1.一次请求,一次响应 ...
- django的ORM
在项目根目录下运行 python manage.py shell 即可进入django的交互shell界面 查询 from my_app.models import MyTestModel datas ...
- github同一账户+多个库
目标 我的情况是,既要向自己的public库提交代码,又要向别人的private库提交代码 网上搜到的情况一:github上有多个账号,都要向自己的库提交代码 网上搜到的情况二:多个git托管源(比如 ...
- css——letter spacing
letter spacing属性是用来设置字母的间距 实例: 设置h1和h2之间字母的间距 <html> <head> <style type="text/cs ...
- 远程桌面服务当前正忙,因此无法完成您尝试执行的任务-win2008R2
远程桌面服务当前正忙,因此无法完成您尝试执行的任务,近来我服务器出现这情况, 到达主机房看主机...不可以登陆,也没有登陆框.只能关机. 在微软找到的原因是:Csrss.exe 进程和某些应用程序 ( ...
- Legal or Not ,图的拓扑
ACM-DIY is a large QQ group where many excellent acmers get together. It is so harmonious that just ...
- oo第3次博客作业
一.规格化设计的发展历史 20世纪60年代,软件出现严重的危机Dijkstra提出了goto语句的危害,由此引发了软件界长达数年的论战,并产生了结构化的程序设计方法.随着计算机 技术的发展,结构设计化 ...
- C++入门程序作业2
程序在Dev-C++5.5.3版本运行 结构体的使用 给结构体赋值,打印出结构体中学生姓名,分数,平均分 #include <iostream>#include <cassert&g ...