前两年迫于项目的需要,只是拿来JQuery用到项目中,并没有实质上理解javascript(貌似其他人也是这么干的)~

随着最近几年,得益于Nodejs, React, Vue等,javascript火的一塌糊涂。深知要想在某一方面走的长远,基础是免不了的,遂拿起这本书,用零散的时间看完了~

这本书中涉及的知识虽然简洁,但是是“授人以渔”。这里总结下里面的实用技巧,以备用。

1. 一个网站的代码结构,大体由html(页面),images,css,js构成,设计过程中遵循以下原则:

  (1) 结构层由html完成,包括页面布局,标签等;

  (2) 表示层由css完成,包括样式,版式等;

  (3) 行为层由js完成,包括事件,动画等。

三层分离

2. 通用函数

  (1) addLoadEvent

function addLoadEvent(func){
var oldonload = window.onload;
if(typeof window.onload != 'function'){
window.onload = func;
}else{
window.onload = function(){
oldonload();
func();
}
}
}

  (2) insertAfter

function insertAfter(newElement, targetElement){
var parent = targetElement.parentNode;
if(parent.lastChild == targetElement){
parent.appendChild(newElement);
}else{
parent.insertBefore(newElement,targetElement.nextSibling);
}
}

  (3) addClass

function addClass(element, value){
if(!element.className){
element.className = value;
}else{
var newClassName = element.className;
newClassName += ' ';
newClassName += value;
element.className = newClassName;
}
}

  (4) moveElement

function moveElement(elementID, final_x, final_y, interval){
if(!document.getElementById) return false;
if(!document.getElementById(elementID)) return false;
var elem = document.getElementById(elementID);
if(elem.movement){
clearTimeout(elem.movement);
}
if(!elem.style.left){
elem.style.left = '0px';
}
if(!elem.style.top){
elem.style.top = '0px';
}
var xpos = parseInt(elem.style.left);
var ypos = parseInt(elem.style.top);
if(xpos == final_x && ypos == final_y){
return true;
}
if(xpos < final_x){
var dist = Math.ceil((final_x-xpos)/10);
xpos = xpos + dist;
}
if(xpos > final_x){
var dist = Math.ceil((xpos - final_x)/10);
xpos = xpos - dist;
}
if(ypos < final_y){
var dist = Math.ceil((final_y-ypos)/10);
ypos = ypos + dist;
}
if(ypos > final_y){
var dist = Math.ceil((ypos - final_y)/10);
ypos = ypos - dist;
}
elem.style.left = xpos + 'px';
elem.style.top = ypos + 'px';
var repeat = 'moveElement("' + elementID + '", ' + final_x + ', ' + final_y + ', ' + interval + ')';
elem.movement = setTimeout(repeat,interval);
}

3. 获取当前页面的URL: window.location.href

4. 类似 dom.onclick = function(){}是为dom对象添加事件处理函数;类似 dom.click()是执行对应的事件函数

5. 类似如下情形,由于变量not_in_scope的作用域问题,当事件被触发时该变量实际上是undefined的

var not_in_scope = 'use dom attribute to contain value';
dom.onmouseover = function(){
alert(not_in_scope)
}

解决技巧:为dom对象添加(属性,值)

var not_in_scope = 'use dom attribute to contain value';
dom.not_in_scope = not_in_scope;
dom.onmouseover = function(){
alert(this.not_in_scope)
}

6. 循环为各个dom对象添加事件处理函数

如下有两种写法,但第二种方式更加简洁。

  var links = document.getElementsByTagName('a');
var linkurl;
for(var i=0; i<links.length; i++){
// 方式1
// linkurl = links[i].getAttribute('href');
// if(linkurl.indexOf('index.html') != -1){
// links[i].onmouseover = function(){
// moveElement('preview',0,0,5);
// }
// }
// if(linkurl.indexOf('about.html') != -1){
// links[i].onmouseover = function(){
// moveElement('preview',-150,0,5);
// }
// }
// if(linkurl.indexOf('photos.html') != -1){
// links[i].onmouseover = function(){
// moveElement('preview',-300,0,5);
// }
// }
// if(linkurl.indexOf('live.html') != -1){
// links[i].onmouseover = function(){
// moveElement('preview',-450,0,5);
// }
// }
// if(linkurl.indexOf('contact.html') != -1){
// links[i].onmouseover = function(){
// moveElement('preview', -600, 0,5);
// }
// } /**
* 方式二
* another way to add event to the similar dom objects
*/
links[i].onmouseover = function(){
var linkurl = this.getAttribute('href');
if(linkurl.indexOf('index.html') != -1){
moveElement('preview', 0,0,5);
}
if(linkurl.indexOf('about.html') != -1){
moveElement('preview', -150,0,5);
}
if(linkurl.indexOf('photos.html') != -1){
moveElement('preview', -300,0,5);
}
if(linkurl.indexOf('live.html') != -1){
moveElement('preview', -450,0,5);
}
if(linkurl.indexOf('contact.html') != -1){
moveElement('preview', -600,0,5);
}
}
}

7. 内部导航

<ul>
<li><a href="#jay">Jay Skript</a></li>
<li><a href="#domsters">The Domsters</a></li>
</ul>
<section id="jay">
<h2>Jay Skript</h2>
</section>
<section id="domsters">
<h2>The Domsters</h2>
</section>

8. 表单验证

客户端和服务器端均需要验证。

9. 表单提交

表单提交事件将由onsubmit事件处理函数拦截,

若返回true,则浏览器将重试提交表单;

若返回false,则中止表单提交

10. 其他:

  (1) document.body

  (2) z-index

  (3) display: inline - 垂直排列变水平排列

  (4) HTML DOM; CSS DOM

  (5) form对象,form.elements

  (6) label标签尽量定义for属性,并同input相关联

  (7) encodeURIComponent

  (8) js正则表达式:/<article>([\s\S]+)<\/article>/

Done!

JavaScript_DOM编程艺术第二版[阅]的更多相关文章

  1. 《JavaScript_DOM编程艺术第二版(中文)》整书笔记

    目录 第3章:DOM 第4章:案例研究 第5章:最佳实践 第6章:案例改进 第7章:动态创建标记 第8章:充实文档的内容 第9章:CSS-DOM 第3章:DOM 文档:DOM中的"D&quo ...

  2. JavaScript DOM编程艺术第二版学习(1/4)

    接下来项目需要网页相关知识,故在大牛的指引下前来阅读本书. 记录方式:本书分四部分阅读,完成阅读之后会多写一篇包括思维导图的算是阅读指南的东西,浏览的童鞋看着指南可以跳过一些不必要的坑~ 当前水平:H ...

  3. JavaScript DOM 编程艺术(第二版) 初读学习笔记

    这本书留给我的印象就是结构.表现和行为层的分离,以及书后面部分一直在强调的最佳实践原则:平稳退化,逐步增强,向后兼容以及性能考虑. 要注意这不是一本JavaScript入门书籍~ 2.1 准备工作 用 ...

  4. 【JavaScript DOM编程艺术(第二版)】笔记

    第1章 javascript简史 1.什么是DOM? 简单的说,DOM是一套对文档的内容进行抽象和概念化的方法.\         第2章 javascript语法 1.内建对象: 内建在javasc ...

  5. JavaScript DOM 编程艺术(第二版) 有待解决的问题

    原书 P181,var repeat = "moveElement('"+elementID+"', "+final_x+", "+fina ...

  6. JavaScript DOM 编程艺术(第二版) 常用JS小脚本

    function addLoadEvent(func) { var oldonload = window.onload; if (typeof window.onload != 'function') ...

  7. Learning ROS for Robotics Programming - Second Edition(《ROS机器人编程学习-第二版》)

    Learning ROS for Robotics Programming - Second Edition <ROS机器人编程学习-第二版> ----Your one-stop guid ...

  8. 《Javascript_Dom 编程艺术》(第2版)读书笔记

    第1章 Javascript 简史 Dom : 平稳退化.渐进增强,以用户为中心的设计 第2章 Javascript 语法 1.程序设计语言分为:解释性(javascript)和编译型(java,C+ ...

  9. 【Python千问 1】Python核心编程(第二版)导读

    第一章 欢迎来到Python世界 什么是Python Python的起源 Python的特点 下载Python 安装Python 运行Python Python文档 比较Python(与其它语言的比较 ...

随机推荐

  1. spoj - Grass Planting(树链剖分模板题)

    Grass Planting 题意 给出一棵树,树有边权.每次给出节点 (u, v) ,有两种操作:1. 把 u 到 v 路径上所有边的权值加 1.2. 查询 u 到 v 的权值之和. 分析 如果这些 ...

  2. [Contest20180418]物理竞赛

    题意:在一个三维空间中有一个轴,轴上有一个垂直于轴的半径为$R$的凸透镜(光心在轴上)和$n$个点光源,假设每个点光源发出的$1$单位光都刚好覆盖凸透镜,现在有一个半径为$r$的圆形光屏,问光屏最多能 ...

  3. 四. Java继承和多态2. Java super关键字

    super 关键字与 this 类似,this 用来表示当前类的实例,super 用来表示父类. super 可以用在子类中,通过点号(.)来获取父类的成员变量和方法.super 也可以用在子类的子类 ...

  4. linux之rpm指令

    rmp原本是Red Hat Linux发行版专门用来管理Linux各项套件的程序,由于它遵循GPL规则且功能强大方便,因而广受欢迎.逐渐受到其他发行版的采用.RPM套件管理方式的出现,让Linux易于 ...

  5. CURL简单使用

    学习地址:https://yq.aliyun.com/articles/33262 curl的简单使用步骤 要使用cURL来发送url请求,具体步骤大体分为以下四步: 1.初始化2.设置请求选项3.执 ...

  6. 16个Linux服务器监控命令

    在不同的Linux发行版中,会有不同的GUI程序可以显示各种系统信息,比如SUSE linux发行版中,就有非常棒的图形化的配置和管理工具YaST,KDE桌面环境里的KDE System Guard也 ...

  7. Python转码问题的解决方法

    FROM: http://www.jb51.net/article/16104.htm 在Python中,可以对String调用decode和encode方法来实现转码.     比如,若要将某个St ...

  8. SparkMLlib聚类学习之KMeans聚类

    SparkMLlib聚类学习之KMeans聚类 (一),KMeans聚类 k均值算法的计算过程非常直观: 1.从D中随机取k个元素,作为k个簇的各自的中心. 2.分别计算剩下的元素到k个簇中心的相异度 ...

  9. asp.net敏感词过滤

    敏感词过滤是一个能够让用户发表评论的网站的一个很重要的功能(你懂的~) 下面开始全套流程: 1.需要有一套比较完整的词库,由于我的词库很少所以就不贴上来了,网上找找应该很多 2.设计一个可以将词库导入 ...

  10. PHP empty()函数说明---用了N遍了就是记不住

    从表面上看,很容易误解empty()函数是判断字符串是否为空的函数,其实并不是,我也因此吃了很多亏. empty()函数是用来测试变量是否已经配置.若变量已存在.非空字符串或者非零,则返回 false ...