读《JavaScript面向对象编程指南》(一)
第二章 基础
通常认为在JavaScript中主要包括五种基本数据类型:
数字、字符串、布尔值、undefined、null。
任何不属于上述五种基本类型的值都被认为是一个对象。
null和undefined:通常认为null是它自有类型Null的唯一一个成员,undefined是预定义的全局变量(与null不同,它不是关键字),只读,它也是这个类型的唯一成员,如果试图访问某个不存在的或者未经赋值的变量时,就会得到一个undefined值。
有时候执行某种算术运算时,null和undefined的结果会截然不同。
另:typeof (null) 返回 object,被公认为是历史遗留错误。
关于NULL:
以前只知道在C/C++中代表指针指向空的含义,发现在JS中居然是一种primitive type,有点吃惊,再一搜,发现在Java中也提到这是一种类型,只不过没有name,以前
没有注意到。
在C/C++中只是一个简单的宏定义,注意C++11倡导用 nullptr 代替NULL。
而在Java和JS中,我觉得还是直接看文档吧,把文档贴在这里(虽然文档的描述读起来很别扭):


其实 Java和 JS中的 null 本质上还是代表空指针而已,只不过在高级语言中封装一下,甚至把它单独作为一个类型列出来。
绝大部分值在转换为布尔类型时都为true,但以下6种falsy值除外:
"" null undefined 0 NaN false
一点联想:Java和C++中都有引用的概念,当然它们本质上都是指针,但是侧重点不太一样,C++中的是Type* const型的指针,侧重“引用即别名”,而 Java 中
侧重“对象的引用”(数组可看成一种特殊的对象),Java中的引用更类似于C++中的指针,尤其它们都与 new 连用。实际上,我好像记得轮子哥说过,引用其实就是
C++中的语法糖。
所以可以说Java中的指针(引用)只能指向对象,而不是像C++中可以指向primitive type,JS中自然也是如此。所以在上面的JS文档中:
The value
nullrepresents the intentional absence of any object value.
此外,像传值或者传引用这类老掉牙的问题我早就懂了,另:一切传引用本质上也是传值。
又一点联想:C++中的NULL和Java中的null有何区别?参考:Stackoverflow。

Note:
(1)NaN == NaN false
(2)惰性求值:true || "some" true;
true && "some" "some";
typeof会返回一个代表数据类型的字符串,它的值包括:"number","string","boolean","undefined","object"和"function"。
第三章 函数
函数也是数据。
匿名函数,回调函数,自调函数,内部函数,返回函数的函数,能重写自己的函数。
例子:
var a = function() {
function someSetup(){
var setup = 'done';
}
function actualwork(){
alert('Worky-worky');
}
someSetup();
return actualwork;
}();
闭包:
function f(){
var b = "b";
return function(){
return b;
}
}
var n = f(); n();
var n;
function f(){
var b = 'b';
n = function(){
return b;
}
}
function f(arg){
var n = function(){
return arg;
}
arg++;
return n;
}
var m = f(123);
m();
循环中的闭包:
function f(){
var a = [];
for(var i = 0;i < 3;i++){
a[i] = function(){
return i;
}
}
return a;
}
var m = f();
m[0]();
m[1]();
m[2]();
function f(){
var a = [];
for (var i = 0; i < 3; i++) {
a[i] = (function(x){
return function(){
return x;
}
})(i);
}
return a;
}
function f(){
var a = [];
for(var i = 0; i < 3; i++){
(function(arg){
a[i] = function(){
return arg;
}
})(i);
}
}
fucntion f(){
function makeClosure(x){
return function(){
return x;
}
}
var a = [];
for(var i = 0; i < 3; i++){
a[i] = makeClosure(i);
}
return a;
}
Getter和Setter:
var getValue, setValue;
(function(){
var serect = 0;
getValue = function(){
return serect;
};
setValue = function(v){
serect = v;
};
})()
迭代器:
function setup(x){
var i = 0;
return function(){
return x[i++];
}
}
var next = setup(['a', 'b', 'c']);
第四章:对象

构造器函数
function Hero(name){
this.name = name;
this.occupation = 'Ninja';
this.whoAreYou = function(){
return "I'm" + this.name + " and I'm a " + this.occupation;
}
}
var h1 = new Hero('lyrecxn');
h1.whoAreYou();
全局对象
构造器属性(constructor property)
instanceof操作符 测试一个对象是否由某个指定的构造器函数所创建的。
function C2(){this.a = 1; return {b : 2};}
var c2 = new C2();
内建对象:
数据封装类对象——包括Object、Array、Bollean、Number和String。这些对象代表着JavaScript不同的数据类型,并且都拥有各自不同的typeof返回值,以及undefined 和 null 状态。
工具类对象——包括Math、Date、RegExp等用于提供便利的对象。
错误类对象——包括一般性错误对象以及其他各种更特殊的错误类对象。
Object:
toString()方法、valueOf()方法、constructor属性
Array:
相当于属性名从 0 开始递增,并自动生成数值。
length属性
sort()方法、join()方法、slice()方法等
Function:
三种定义函数的方式,
属性:constructor、caller、prototype
方法:call()、apply()
重新认识arguments对象,function.argument
Boolean、Number、Math、Date:
String:
toUpperCase()与toLowerCase()、charAt、indexOf()。
slice()与substring()(对待负值的方式不同)
split()、concat()
RegExp:
属性:global,ignoreCase,multiline,lastIndex,source.前三个可以用regex修饰符来表示:gim。
方法:test(),exec().
以正则表达式为参数的字符串方法:match()、search()、replace()、split()
例子:
var email = "stoyan@phpied.com";
var username = email.replace(/(.*)@.*/ , "$1");
>>>username;
"stoyan"
回调式替换:
//回调式替换
var s = new String("HelloJavaScript")
function replaceCallback(match){
return "_" + match.toLowerCase();
}
s.replace(/[A-Z]/g, replaceCallback);
Error:
try catch throw finally
读《JavaScript面向对象编程指南》(一)的更多相关文章
- 读《Java并发编程的艺术》(一)
离开博客园很久了,自从找到工作,到现在基本没有再写过博客了.在大学培养起来的写博客的习惯在慢慢的消失殆尽,感觉汗颜.所以现在要开始重新培养起这个习惯,定期写博客不仅是对自己学习知识的一种沉淀,更是在督 ...
- 那些年读过的书《Java并发编程实战》和《Java并发编程的艺术》三、任务执行框架—Executor框架小结
<Java并发编程实战>和<Java并发编程的艺术> Executor框架小结 1.在线程中如何执行任务 (1)任务执行目标: 在正常负载情况下,服务器应用 ...
- 读《Java并发编程的艺术》学习笔记(一)
接下来一个系列,是关于<Java并发编程的艺术>这本书的读书笔记以及相关知识点,主要是为了方便日后多次复习和防止忘记.废话不多说,直接步入主题: 第1章 并发编程的挑战 并发编程的目的是 ...
- Java并发编程的艺术读书笔记(2)-并发编程模型
title: Java并发编程的艺术读书笔记(2)-并发编程模型 date: 2017-05-05 23:37:20 tags: ['多线程','并发'] categories: 读书笔记 --- 1 ...
- Java并发编程的艺术(六)——线程间的通信
多条线程之间有时需要数据交互,下面介绍五种线程间数据交互的方式,他们的使用场景各有不同. 1. volatile.synchronized关键字 PS:关于volatile的详细介绍请移步至:Java ...
- Java并发编程的艺术(三)——volatile
1. 并发编程的两个关键问题 并发是让多个线程同时执行,若线程之间是独立的,那并发实现起来很简单,各自执行各自的就行:但往往多条线程之间需要共享数据,此时在并发编程过程中就不可避免要考虑两个问题:通信 ...
- 《Java并发编程的艺术》留给自己以后看的笔记
<Java并发编程的艺术>这本书特别好,和<深入了解JAVA虚拟机>有一拼,建议做java的都看看,下面全部都是复制书中的部分内容,主要目的是做个笔记,方便以后遇到问题能找到. ...
- 读书笔记之《Java 并发编程的艺术》
一.多线程语义 即使是单核处理器也支持多线程执行代码,CPU 通过给每个线程分配 CPU 时间片来执行任务,当前任务执行一个时间片后会切换到下一个任务,所以 CPU 通过不停的切换线程执行. 并发执行 ...
- 《Java并发编程的艺术》读书笔记:二、Java并发机制的底层实现原理
二.Java并发机制底层实现原理 这里是我的<Java并发编程的艺术>读书笔记的第二篇,对前文有兴趣的朋友可以去这里看第一篇:一.并发编程的目的与挑战 有兴趣讨论的朋友可以给我留言! 1. ...
- Java并发编程的艺术读书笔记(1)-并发编程的挑战
title: Java并发编程的艺术读书笔记(1)-并发编程的挑战 date: 2017-05-03 23:28:45 tags: ['多线程','并发'] categories: 读书笔记 --- ...
随机推荐
- Initializer for conditional binding must have Optional type, not 'String'
今天看到问Swift问题: Initializer for conditional binding must have Optional type, not 'String' 以前没遇到过这个问题, ...
- Document、HTMLDocument关系的探究
首先贴上代码: console.log(Object.getPrototypeOf(document)); console.log(Object.getPrototypeOf(Object.getPr ...
- freetye2使用
使用环境和版本:qt ubuntu 16.04 freetype-2.10.0 1.下载 https://sourceforge.net/projects/freetype/files/freet ...
- 利用nginx做反向代理解决前端跨域问题
最近朋友再群里提了一个问题,他们公司给他提供了一个获取数据的接口,在浏览器访问这个接口能获取到json数据,但是放在项目里使用ajax就产生了跨域问题,一般这个需要提供接口的后台方面需要做跨域处理,但 ...
- win10相机打不开,显示错误代码0xA00F4246(0x800706D9)
有时我们在不知道什么情况下电脑便会变成这个样子,当我们以为是驱动问题的时候,或许我们可以使用下面的办法解决这个问题 方法: 1.WIN键+R打开命令端,输入regedit运行 2.进入 计算机\HKE ...
- hbase的架构组成+hbase在create报错 -hue - mvn
0.hbase的组件 架构 参考:https://cloud.tencent.com/developer/article/1084209 各个组件的功能 参考:https://zhuanlan.zhi ...
- ideal中运行manven常用操作
ideal中对项目打包,输入命令如下图所示: clean install -Dmaven.test.skip=true
- 第1章 Java开发入门
一.填空题 1.Java SE.Java EE.Java ME 2.JRE 3.javac 4.bin 5.path.-class path 二.判断题 1.√ 2.× JDK: java devel ...
- JavaScript刷新事件
1, Location reload() 方法 2,
- 网络信息统计netstat|ss|ip
1:netstate[弃用] netstat的作用: 需求 原命令 新命令 1:网络连接 netstat -a ss 2:路由表 netstat -r ip route 3:统计接口 netstat ...