《编写高质量代码改善JavaScript程序的188个建议》读书笔记
- 逗号运算符比较怪异。如 var a =(1,2,3,4);alert(a);// 4 var a = 1,2,3,4;//报错
- 注意a++和++a的差别,变量在参与运算中不断地变化。var a; a = (a++) + (++a) - (a++) - (a++);
- 在if语句中禁止使用function语句,虽然大多数的浏览器都允许在if语句中使用function,但它们在解析function语句的处理各不相同,因此造成了可移植性方面的问题。一个语句不能以一个函数表达式开头(?)。
- 基于函数的迭代要比基于循环的迭代慢一些。因为每个数组项要关联额外的函数调用时造成速度慢的主要原因。
- 当条件体增加时,if性能负担增加的程度比switch更大。
- 在JavaScript提供的4中循环类型中,只有for in 循环执行速度比其他循环明显要慢,因为除了要查找对象上的属性外,还要查找原型链上的属性,增加性能开销。(in 运算符的运算机制?)
- 回溯是影响正则整体性能的唯一因素。
- 使用function语句和函数直接量定义的函数构造总会被里提取出来优先执行。只有在函数被解析和执行完毕之后,才会按顺序执行其他代码行。但是使用new Function构造函数定义的函数并非提前运行,而是运行时动态地被执行,这也是Function构造函数定义的函数具有顶级作用域的根本原因。
- 通过new运算符可以复制函数的结构,从而实现函数实例化的目的。
- 惰性载入函数主要解决的问题也是兼容性,原理跟分支函数类似。
- 函数绑定是为了改变函数执行上下文,特别是当函数中有this关键字时。
- 高阶函数至少满足以下条件之一:□接收函数作为输入;□输出一个函数
- 借助prototype属性,可以访问原型对象内部成员。当构造函数实例化后,所有实例对象都可以访问构造函数的原型成员。
- 本地属性会覆盖原型属性,如果使用delete运算符删除本地属性,那么原型属性依然会显示出来。
- 使用原型的几种用途:1)使用原型设置默认值;2)使用原型实现数据备份;3)使用原型设置只读属性;4)使用原型进行批量复制
- “||”运算符为对象属性设置默认值,当对象属性值未定义时,以默认值进行传递。
- 使用hasOwnProperty方法。如果对象拥有独有的属性,那么调用该方法将返回true,也就是说hasOwnProperty不会检查原型链。
- 构造函数是一个特殊结构的函数,它没有返回值,通过this关键字来初始化实例对象。
- JavaScript核心对象中的Math和Global都是静态对象,不需要实例化就可以直接访问。
- 类的静态成员包括私有和公共两种类型,不管是公共成员还是私有成员,它们在系统中只有一份副本,不会被分成多份传递给不同的对象,而是通过函数指针进行引用,这与闭包截然不同。
- 如果构造函数有返回值,并且返回值是引用类型,那么经过new运算符计算后,返回的不再是构造偶函数自身对应的实例对象,而是构造函数包含的返回值(即引用类型值)。
- 浏览器渲染操作的顺序如下:1)解析HTML结构;2)加载外部脚本和样式文件;3)解析并执行脚本代码;4)构造HTML DOM模型;5)加载图片等外部文件;6)页面加载完毕
- createElement和innerHTML两者性能基本相近,不过在几乎所有的浏览器中innerHTML速度更快一些,但最新的基于WebKit的浏览器(Chrome和Safari)除外。
- 警惕文档遍历中的空格bug。在遍历DOM文档元素时,空格的存在很容易造成误解,因为DOM把空格也作为一个节点进行解析(包括换行符)。
- 在大多数浏览器上,克隆节点更有效率,但提高得不太多。用克隆节点的办法创建1000行表格,只创建一次单元格,然后重复执行复制操作,只有会更快一点。
- 当DOM改变影响到元素的几何属性(宽和高)时,如改变边框属性或在段落中添加文字将发生一系列后续动作:浏览器需要重新计算元素的几何属性,而且其他元素的几何属性和位置也会因此改变并受到影响。浏览器使渲染树上受到影响的部分失效,然后重构渲染树,这个过程称作重排版(reflow)。
- 对于浏览器窗口来说,通过获取html标签的clientWidth和clientHeight属性就可以得到浏览器窗口的可视宽度和高度,document.documentElement.clientWidth。但是ie一下版本的浏览器中,body是最顶层的可视元素,因此需要写成document.body.clientWidth。
- 在JavaScript中,不只是with表达式人为地改变运行期上下文的作用域链,try catch表达式的catch子句也具有相同效果。
- DOM元素中有一些特殊的测量属性的访问和方法的调用,也会触发reflow,比较典型的就是offsetWidth和getComputedStyle。
- 为了提高DOM访问效率,推荐使用XPath查找元素。很多浏览器已支持该功能。
- 每个浏览器对长时间运行脚本检查方法上略有不同:IE)500万条语句以内;FF)默认限制为10s;Safari)默认限制为5s,且不可改变但能关闭;Chrome)没有长时间运行脚本限制,代之以依赖它的通用崩溃检测系统来处理此类实例;Opera)没有时间限制。
《编写高质量代码改善JavaScript程序的188个建议》读书笔记的更多相关文章
- csapp读书笔记-并发编程
这是基础,理解不能有偏差 如果线程/进程的逻辑控制流在时间上重叠,那么就是并发的.我们可以将并发看成是一种os内核用来运行多个应用程序的实例,但是并发不仅在内核,在应用程序中的角色也很重要. 在应用级 ...
- CSAPP 读书笔记 - 2.31练习题
根据等式(2-14) 假如w = 4 数值范围在-8 ~ 7之间 2^w = 16 x = 5, y = 4的情况下面 x + y = 9 >=2 ^(w-1) 属于第一种情况 sum = x ...
- CSAPP读书笔记--第八章 异常控制流
第八章 异常控制流 2017-11-14 概述 控制转移序列叫做控制流.目前为止,我们学过两种改变控制流的方式: 1)跳转和分支: 2)调用和返回. 但是上面的方法只能控制程序本身,发生以下系统状态的 ...
- CSAPP 并发编程读书笔记
CSAPP 并发编程笔记 并发和并行 并发:Concurrency,只要时间上重叠就算并发,可以是单处理器交替处理 并行:Parallel,属于并发的一种特殊情况(真子集),多核/多 CPU 同时处理 ...
- 读书笔记汇总 - SQL必知必会(第4版)
本系列记录并分享学习SQL的过程,主要内容为SQL的基础概念及练习过程. 书目信息 中文名:<SQL必知必会(第4版)> 英文名:<Sams Teach Yourself SQL i ...
- 读书笔记--SQL必知必会18--视图
读书笔记--SQL必知必会18--视图 18.1 视图 视图是虚拟的表,只包含使用时动态检索数据的查询. 也就是说作为视图,它不包含任何列和数据,包含的是一个查询. 18.1.1 为什么使用视图 重用 ...
- 《C#本质论》读书笔记(18)多线程处理
.NET Framework 4.0 看(本质论第3版) .NET Framework 4.5 看(本质论第4版) .NET 4.0为多线程引入了两组新API:TPL(Task Parallel Li ...
- C#温故知新:《C#图解教程》读书笔记系列
一.此书到底何方神圣? 本书是广受赞誉C#图解教程的最新版本.作者在本书中创造了一种全新的可视化叙述方式,以图文并茂的形式.朴实简洁的文字,并辅之以大量表格和代码示例,全面.直观地阐述了C#语言的各种 ...
- C#刨根究底:《你必须知道的.NET》读书笔记系列
一.此书到底何方神圣? <你必须知道的.NET>来自于微软MVP—王涛(网名:AnyTao,博客园大牛之一,其博客地址为:http://anytao.cnblogs.com/)的最新技术心 ...
- Web高级征程:《大型网站技术架构》读书笔记系列
一.此书到底何方神圣? <大型网站技术架构:核心原理与案例分析>通过梳理大型网站技术发展历程,剖析大型网站技术架构模式,深入讲述大型互联网架构设计的核心原理,并通过一组典型网站技术架构设计 ...
随机推荐
- 菜鸟vimer成长记——第2.1章、normal模式
目的 掌握normal模式下常用操作的语法和概念,这些操作对应的应用场景以及实用技巧. 通过normal模式举一反三掌握cmd-line和visual的常用文本操作. 简介 文本操作的理想状态为:一个 ...
- asp.net core 发布到docker 极简步骤
1.使用dotnet命令发布项目 2.把发布成功的文件通过scp等工具发布到linux服务器上,在当前目录下新建一个dockerfile 3.使用asp.net core镜像为底包构建一个新的镜像 4 ...
- stringObject.substring(start,stop)
用于提取字符串中 介于两个指定下标之间的字符. start 必需.一个非负的整数 stop 可选.一个非负的整数
- 关于selenium的智能等待页面加载的问题
我们经常会碰到用selenium操作页面上某个元素的时候,需要等待页面加载完成后,才能操作, 否则页面上的元素不存在,会抛出异常. 或者碰到AJAX异步加载,我们需要等待元素加载完成后,才能操作. 首 ...
- apache-日志-记录post数据
apache access.log日志只能打印出相关的头部信息,例如:Referer, User-agent.但是我希望看到body中的data. 目前找到解决方案是使用apache的扩展module ...
- 小强版之无码理解C语言指针
1. 先从普通变量开始 2. 撸完变量撸指针 3. 故事情节进一步发展,此处少儿不宜 4. 奶茶妹妹捉奸,小强死定了 5. 源码欣赏 #include <stdio.h> ...
- hadoop之定制自己的Partitioner
partitioner负责shuffle过程的分组部分,目的是让map出来的数据均匀分布在reducer上,当然,如果我们不需要数据均匀,那么这个时候可以自己定制符合要求的partitioner. 下 ...
- Less 的用法
1. node.js node.js是一个前端的框架 自带一个包管理工具npm node.js 的安装 官网:http://nodejs.cn/ 在命令行检验是否安装成功 切换到项目目录,初始化了一个 ...
- 20181023-11 Alpha发布
此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2283 文案: Learning by Playing 界面清爽明快,UI ...
- 20162328蔡文琛 week11 大二
20162328 2017-2018-1 <程序设计与数据结构>第十一周学习总结 教材学习内容总结 在无向图中,表示边的顶点对是无序的. 如果图中的两个顶点之间有边链接,则称它们是领接的. ...