你过去的种种经历,就像人生的一颗颗珍珠,在未来的某一天,你找到了那根线,你就会把她们串联起来,变成美丽的项链。

第八章 客户端 JavaScript 与 HTML

1. 浏览器渲染页面的步骤

2.  JS 性能优化

1). 在 body 标签结束前写 <script> 标签。( 不要操作 body 标签, 因为是在 body 标签结束前写 script的, 若想操作 body 可以用 onload 或 DOMContentLoaded )。

2). 把 JS 文件分离至外部文件 ( 好处:首先,浏览器能够缓存 JS 文件了。第二次就不需要在加载了。 )

3). onload: 能够在页面读取完成后再对其执行。( 包括图片 )

4). DOMContentLoaded: 是在完成 HTML 解析后发生的事件。比 onload 快一点。

5) . 动态载入

6). 执行流程小结:

DOMContentLoaded: 是最恰当的选择。

3. 调试

1). alert

2). console ( IE 不支持可以采用以下虚拟 console )

4. 跨浏览器支持

1). 基于用户代理的跨浏览器支持策略

5. Window 对象

6. DOM 的定义

1).  根据依赖关系,分别有父节点、子节点、兄弟节点、祖先节点、子孙节点等类型。

2). DOM 可以分为 Level1 ~ 3 这几层。

3). DOM Level 1 模块

4).  DOM Level 2

5).  DOM Level 3

6). DOM 元素、节点

7.  DOM 操作,选择、创建、更改与删除。

1). 选择

1. 通过 id 检索

var element = document.getElementById('foo');

2).  通过标签名检索

语法: Element.getElementsByTagName();

Element.getElementsByTagName();   所能取得的对象是一个 NodeList 对象,而不是单纯的 Node 对象的数组。而 NodeList 对象的一大特征是它是一个 Live 对象。

3). 通过名称检索

语法:HTMLDocument.getElementsByName() , 只能在 form 标签或 input 标签中使用 name 属性,所以与 getElementById() 相比,它的使用频率较低。

4). 通过类名检索

语法:HTMLElement.getElementsByClassName() 方法,是 HTML5 规定的功能。

8. 父节点、子节点、兄弟节点

9. 使用 XPath 方式

10. Selector API 方式

1). querySelector(): 返回第一个与条件符合的元素

2). querySelectorAll():  返回所有条件符合的元素

3). 最重要的一点是:querySelectorAll() ,( getElementsByTagName() 是 NodeList )  取得的事一个 StaticNodeList 对象( 与 NodeList 相反 )。( 也就是说向文档添加元素,文档不会做出反应 )

11. 节点的创建与新增

1). 可以通过 Document.createElement() 方法或 Document.createTextNode() 方法来创建节点。

2). 如果要将节点新增为某一节点的最后一个子元素,则可以使用 Node.appendChild() 方法。

3). 如果要将节点插入至某一元素所在的位置,则需要使用 Node.insertBefore() 方法。

12. 节点的内容更改

13. 节点的删除

14. innerHTML/textContent

1). innerHTML 属性并不是一种在 DOM 标准中被定义的功能,而是一种在 HTML5 中被定义的属性。

15. DOM 操作的性能

1). DOM 内容的改写,若显示上发生变化,浏览器自然要重绘画面。重绘是需要花费开销的。所以避免重新绘制画面。

避免重绘的理解:比如你要买 10 个西瓜,你是一个一个往家拿,还是一次把 10 个西瓜一起拿回家呢?

16. 事件

1). JS 是通过事件驱动程序设计的方式来实现功能的。( 哈哈哈,让我想到了寻龙诀里面的女神墓,貌似古墓里面都是以机关来驱动古墓的。多个机关构成了一个古墓。biu biu biu~~~ )。

2). 注册事件( 添加一个事件 ),就像声明了一个函数,只有调用的时候才触发。( 也就像我挖好一个陷阱等人掉进来,嘻嘻嘻。。。 )。

3).  指定为 HTML 元素的属性,直接写在 HTML 元素上。( 比喻成台灯把,开关就在台灯的身上,优点大大的,简单。 )

4). 指定为 DOM 元素的属性

5). 通过 EventTarget.addEventListener() 进行指定

6). 事件的传播

事件的处理会分别经过 3 个阶段 捕获阶段、目标阶段、事件冒泡阶段。

事件取消: Event.stopPropagation() 方法取消传播

取消默认处理: Event.preventDefault() 方法来取消浏览器中默认实现的处理操作。

17. Event 接口

18. DOM Level2 定义的事件

19. DOM Level3 定义的事件

20. 自定义事件

1). 通过 createEvent() 创建一个事件对象, 并通过目标节点的 dispatch() 方法来分发这一事件对象。

第十一章 客户端 JS 实践

1. 样式变更方法

使用 className

s使用 classList

操作 Style

2. 位置

1). 屏幕坐标:ScreenX,ScreenY: 以计算机显示器左上角为原点。

2). 窗口坐标:clientX,clientY: 屏幕坐标以浏览器的显示范围的左上角为原点。

3). 文档坐标:pageX,pageY: 文档坐标是一种以文档页面的左上角为原点的。

3. 动画

1). 如果要实现移动的动画效果,则可以对被设定的 position: absolute 元素的 left 属性进行渐变。

2). 如果要实现淡入淡出的效果,则可以逐渐改变元素的透明度的值。

4. form 表单

1). 可用于验证的事件有:

submit ( 表单提交 ),

focus, blur ( 获取焦点, 失去焦点 )

change ( input 元素的值发生变化时该事件将被触发 )

keydown, keyup ( 键盘按下, 释放按下键 ), keypress ( 键盘被按下且输入了字符时触发 )

input ( HTML5, 当 input 元素发生了输入行为时将触发 input 事件 和 change 相同 )

第十二章 库

1. 为什么使用 jQ

1. 体积小

2. 链式语法

3. 支持插件, 扩展性高

4. 通过 CSS3 选择器及自定义选择获取元素。

2. 事件专用的事件侦听器的注册方法

3. jQuery 插件模板

           (function($){
$.fn.myplugin = function (method) {
var methods = {
init: function (options) {
this.myplugin.settings = $.extend({}, this.myplugin.defaults, options);
return this.each(function(){
// 初始化处理
});
},
someMethod: function () {
// 插件专有的函数
}
} if (methods[method]) {
return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
} else if (typeof method === 'object' || !method) {
return methods.init.apply(this, arguments);
} else {
$.error('Method "' + method + '" does not exsit in myplugin plugin!');
}
} $.fn.myplugin.defaults = {
foo: 'bar'
} $.fn.myplugin.settings = {}
})(jQuery);

ing!!!

小技巧

1. DOM

1. DOM 只要理解他的操作  选择、创建、更改与删除。接着在想想需要在什么地方去操作他们,接下来就会有节点的概念,父节点、子节点、兄弟节点、祖先节点、子孙节点,理解这些就够了,大多数基本的流程是可以走通的。

2). 避免重绘的理解:比如你要买 10 个西瓜,你是一个一个往家拿,还是一次把 10 个西瓜一起拿回家呢?

3). 事件表

4). 三元表达式切换样式

foo.onclick = function toggleStyle() {
this.className = (this.className === 'foo-before') ? 'foo-after' : 'foo-before';
};

【2】JavaScript编程全解笔记(二)的更多相关文章

  1. 【1】JavaScript编程全解笔记(一)

    1.概述 本书涵盖了 JavaScript 各个方面的主题,从客户端以及服务端 JavaScript 等基础内容,主要讲了  HTML5.Web API.Node.js 与 WebSocket 等技术 ...

  2. 【3】JavaScript编程全解笔记(三)

    减少重复劳动,抓住核心. 第 4 部分 HTML5 1. HTML 技术分类 与 API 2. ApplicationCache 缓存 第 15 章 与桌面应用的协作 第 17 章 WebSocket ...

  3. Java IO编程全解(二)——传统的BIO编程

    前面讲到:Java IO编程全解(一)——Java的I/O演进之路 网络编程的基本模型是Client/Server模型,也就是两个进程之间进行相互通信,其中服务端提供位置信息(绑定的IP地址和监听端口 ...

  4. Java IO编程全解(一)——Java的I/O演进之路

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7419117.html JDK1.4之前的早期版本,Java对I/O的支持并不完善,开发人员在开发高性能I/O ...

  5. Java IO编程全解(三)——伪异步IO编程

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7723174.html 前面讲到:Java IO编程全解(二)--传统的BIO编程 为了解决同步阻塞I/O面临 ...

  6. Java IO编程全解(五)——AIO编程

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7794151.html 前面讲到:Java IO编程全解(四)--NIO编程 NIO2.0引入了新的异步通道的 ...

  7. Java IO编程全解(四)——NIO编程

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/7793964.html 前面讲到:Java IO编程全解(三)——伪异步IO编程 NIO,即New I/O,这 ...

  8. 【HANA系列】【第二篇】SAP HANA XS使用JavaScript编程详解

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[HANA系列][第二篇]SAP HANA XS ...

  9. [顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功)

    原文:[顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功) [顶]ORACLE PL/SQL编程详解之二: PL/SQL块结构和组成元素(为山九仞,岂一日 ...

随机推荐

  1. [转]Converting a C library to gyp

    Source:http://n8.io/converting-a-c-library-to-gyp/ Converting a C library to gyp Published: 2012.10. ...

  2. [转]Hooked on DTrace

    source link: 1.http://blog.bignerdranch.com/1907-hooked-on-dtrace-part-1/ 2.http://blog.bignerdranch ...

  3. FlexPaper+SWFTool+操作类=在线预览PDF(转)

    引言 由于客户有在线预览PDF格式的需求,在网上找了一下解决方案,觉得FlexPaper用起来还是挺方便的,flexpaper是将pdf转换为swf格式的文件预览的,所以flexpaper一般和swf ...

  4. 哞哞快的 C# 高斯模糊实现

    冲动来自于 bing best 这个小工具,非常短小精干,里边的设置界面非常精美而且背景是一张模糊效果的图片,十分养眼,遂想,收集一下实现方式放到类库里以后肯定用得上.一通百度.谷歌.博客园,换了好多 ...

  5. 由ASP.NET所谓前台调用后台、后台调用前台想到HTTP

    由ASP.NET所谓前台调用后台.后台调用前台想到HTTP 在由ASP.NET所谓前台调用后台.后台调用前台想到HTTP——理论篇中描述了一下ASP.NET新手的三个问题及相关的HTTP协议内容,在由 ...

  6. Prolog学习:基本概念 and Asp.net与Dojo交互:仪器仪表实现

    Asp.net与Dojo交互:仪器仪表实现 项目中需要用到仪器仪表的界面来显示实时的采集信息值,于是便遍地寻找,参考了fusionchart和anychart之后,发现都是收费的,破解的又没有这些功能 ...

  7. ASP.NET Web API 2.0新特性:Attribute Routing1

    ASP.NET Web API 2.0新特性:Attribute Routing[上篇] 对于一个针对ASP.NET Web API的调用请求来说,请求的URL和对应的HTTP方法的组合最终决定了目标 ...

  8. OSGI原形(.NET)

    OSGI原形(.NET) 目前只做了基础的功能,比如: 各个模块单独的AppDomain容器 Activator激活 导出的服务检查 不过,虽说这样,但目前的这个版本已经能实现模块分离.互相依赖调用等 ...

  9. 编译linux内核时出错

    在编译linux内核的时候使用make menuconfig 可能出现下面的错误 *** Unable to find the ncurses libraries or the*** required ...

  10. 合约广告系统-Hadoop

    Hadoop Hadoop 概况 Hadoop 由 Apache Software Foundation 公司于 2005 年秋天作为Lucene的子项目 Nutch的一部分正式引入.它受到最先由 G ...