前言:感觉这本书只有第二章 第三章有点看头

基本类型和引用类型

  • 基本类型:字符串 数字 布尔值 null(待确定) undifined
  • 引用类型:对象 数组
引用传递 保存的只是对象的地址
var obj = {};
var obj1 = obj;
obj.name="hey";
obj.name === obj1.name
自修改对象
var items = [1,2,3];
var items1 = items;
items.push(4);
items.length === items1.length
更改对象的引用
//将items设置为字符串数组(对象)
var items = ["one","two","three"];
var items1 = items;
items = ["new","array"];
//现在items items1指向不同的对象
//items指向 new array
//items1指向 one two three
修改对象生成一个全新对象而非自修改对象

var item="test";

var itemstr = item;
items+='ing';
console.log(item!=itemstr)

作用域

var foo = 'test';
if (true) {
var foo = 'new test';
}
console.log(foo === 'new test'); function test() {
var foo = 'old test';
}
test();
console.log(foo === 'new test');
function test() {
foo = 'test';
}
test();
console.log(window.foo === 'test');

上下文

function setFoo(fooInput) {
this.foo = fooInput
} var foo = 5;
console.log('foo at the window level is set to'+foo);
var obj = {
foo:10
}
console.log('foo at the obj is set to'+obj.foo) setFoo(15);
console.log('now foo at the window level is set to'+foo);
obj.setFoo = setFoo;
obj.setFoo(20);
console.log('foo at the obj is now set to'+foo)
更改函数上下文

function changeColor(color) {
this.style.color = color;
}
changeColor("white");
window对象没有style对象 var main = document.createElement('div');
changeColor.call(main,"black");
console.log(main.style.color) function setBodyColor() {
changeColor.apply(document.body,arguments); } setBodyColor('black');

闭包

var obj = document.getElementById("main");
obj.style.border = '1px solid red';
setTimeout(function() {
obj.style.display="none"
},1000) function delayedAlert(msg,time) {
setTimeout(function({
console.log(msg)
),time)
}
柯里化
function addGenerator(num) {
return function(toAdd) {
num+toAdd
}
} var addFive = addGenerato(5);
console.log(addFive(4)==9)
ID为main的元素
var obj = document.getElementById("main");
要绑定的数组
var items = ['click','keypress'];
迭代数组中的每一项
for (var i =0;i<items.length;i++) {
利用自执行的匿名函数生成作用域
(function() {
记住这一作用域中的值
在该作用域中每个items的值都是唯一的,不依赖父上下文中所创建的变量
var item = items[i];
为元素绑定时间 obj['on'+item] = function() {
item指向处于for循环上下文的父变量
console.log('thanks for your' +item)
}
}) ()
}

函数重载



function sendMessage(msg,obj) {
if(arguments.length=2) {
obj.log(msg)
}else{
console.log(msg)
}
}

修改对象

如今javascript有三种方式控制某个对象能否修改,我们将按照严格程度从最低到最高一次讲解

  1. Object.preventExtensions()

    阻止新的属性添加到对象中,当前的属性可以照用不误
创建一个新对象
var obj = {};
使用preventExtensions创建一个新对象
var obj2 = Object.preventExtensions(obj)
报错
Object.defineProperty(obj2,'greeting',{value:'hello'})
  1. Object.seal()

    使用Object.seal()能够限制对象的能力,这类似Object.preventExtensions

    不过和之前的例子不同的是属性不能删除,也不能转换成存取器(accessor,getter方法)

    删除或添加属性同样会报错,已有的可写属性是例外
var obj={};
obj.greeting = 'welcome';
Object,seal(obj);
更新已有的可写属性
无法将已有属性转换为存储器
obj.greeting = 'hello'
Object.defineProperty(obj,'greeting',{get:function() {
return 'hello world'
}) 无法删除属性
delete.obj.greeting;
  1. Object.freeze()

    三种方法中最为严格的方法,一旦使用对象就被默认为不可改变的了。无法再添加删除更新属性。如果本身是一个对象的话,那该对象可以更新称为浅冻结。想生成一个不可改变的对象,所有值是对象的属性必须要冻结
var obj = {
greeting:'welcome';
innerObj:{}
} Object.freeze(obj)
报错
obj.greeting = 'hello';
innerObj可更新
obj.innerObj.greeting="hello" 无法将已有属性转换为存取器
Object.defineProperty(obj,'greeting',{get:function(} {
return 'hello world'
}) 试图删除属性
delete.obj.greeting
冻结内部对象
Object.freeze(obj.innerObj)
报错
obj.innerObj.greeting = 'dfsfsf';

精通JavaScipt第二版笔记——特性、函数和对象的更多相关文章

  1. python核心编程第二版笔记

    python核心编程第二版笔记由网友提供:open168 python核心编程--笔记(很详细,建议收藏) 解释器options:1.1 –d   提供调试输出1.2 –O   生成优化的字节码(生成 ...

  2. C++标准库第二版笔记 2.1

    C++标准库第二版笔记 2.1 1 Range-Based for 循环 for ( decl : coll ) { statements; } // collaborate 类似C# foreach ...

  3. C++标准库第二版笔记 3 和异常的理解 1

    C++标准库第二版笔记 3 和异常的理解 1 差错和异常(error and exception)的处理 标准异常类(exception class) 定义于 分为: 1.语言本身支持的异常 2.标准 ...

  4. 《LabVIEW 虚拟仪器程序设计从入门到精通(第二版)》一1.3 小结

    本节书摘来自异步社区<LabVIEW 虚拟仪器程序设计从入门到精通(第二版)>一书中的第1章,第1.3节,作者 林静 , 林振宇 , 郑福仁,更多章节内容可以访问云栖社区"异步社 ...

  5. C++标准库第二版笔记 2

    C++标准库第二版笔记 2 微小但重要的语法提升 template表达式内的空格: vector< list<int> >; // OK in each C++ version ...

  6. C++标准库第二版笔记 1

    C++标准库第二版笔记 1 C++ std历史 第一份标准化文档: C++98 & C++03 & TR1 TR1 Information Technology- Programmin ...

  7. Oracle12c从入门到精通(第二版) PDF 下载

    一:下载地址: 二:本书图样 三本书目录 前言 第一章 Oracle数据库概述 第二章 Oracle在Windows 8上的安装与配置 第三章 SQL基础 第四章 Oracle PL/SQL及编程 第 ...

  8. Backbone.js入门教程第二版笔记(1)

    1.模块 集合 视图 和事件的一个综合例子 <!DOCTYPE html> <html> <head> <meta charset="UTF-8&q ...

  9. Head Html Css 第二版笔记

    一. 引用 <blockquote>ago aog aogag </blockquote> 则是引用一大段文字并独立显示 二. <a> 创建目的地 <h2&g ...

随机推荐

  1. 小米Adnroid默认禁止悬浮框的使用,导致开发的悬浮框无法接收事件

    比如你建了一个悬浮框: WindowManager windowManager = getWindowManager(context); int screenWidth = windowManager ...

  2. TP5.0 PHPExcel 数据表格导出(原)

    今天看的是PHPExcel这个扩展库,Comporse 下载不下来,最后只能自己去github里面手动下载,但有一个问题就是下载下来的PHPExcel没有命名空间,所以框架里面的use根本引入不进去, ...

  3. N维法向量与N维超平面的关系的简单证明(日志二)

    虽然按照上面的方式证明出来,但感觉之中,似乎依旧是不严密的, 如下: 如果直线是2x+2y+1=0 那么(-1,1)也是其平行向量 ,.那么(1,1)依旧是法向量 此时,直线经过(0,-1/2)这个点 ...

  4. OC—不可变字符串NSString

  5. 如何应对苹果app 的ipv6 时代?腾讯专家教您进行环境改造

    WeTest 导读 WWDC2015苹果宣布在ios9支持纯IPv6的网络服务,并且要求2016年提交到app store的应用必须兼容纯IPv6的网络,要求适配的系统版本是ios9以上(包括ios9 ...

  6. hdu1507 Uncle Tom's Inherited Land* 二分匹配

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1507 将i+j为奇数的构成x集合中 将i+j为偶数的构成y集合中 然后就是构建二部图 关键就是构图 然 ...

  7. Java (PO,VO,DAO,BO,POJO,DTO) 几种对象解释

    1. PO:persistant object 持久对象 可以看成是与数据库中的表相映射的java对象.最简单的PO就是对应数据库中某个表中的一条记录,多个记录可以用PO的集合.PO中应该不包含任何对 ...

  8. OOP 三大特点:继承性,封装性,多态性

    1.继承性:代码重用 2.封装性:  使相似数据和操作进行封装,保持代码安全 3.多态性:  PHP不支持多态

  9. JSP中include指令和include动作区别

    首先 <%@ include file=” ”%>:为指令元素 <jsp:include page=” ” flush=”true”/>:为 动作元素 先说指令元素: incl ...

  10. 3.Java 加解密技术系列之 SHA

    Java 加解密技术系列之 SHA 序 背景 正文 SHA-1 与 MD5 的比较 代码实现 结束语 序 上一篇文章中介绍了基本的单向加密算法 — — MD5,也大致的说了说它实现的原理.这篇文章继续 ...