JavaScript DOM高级程序设计1.3-常见陷阱--我要坚持到底!
区分大小写
- 单引号双引号
大多数开发人员选择用单引号,因为XTHML要求所有XHTML的属性都必须使用双引号
var html='<h2 class="a">A list!</h2>'
+'<ol>'
+'<li class="a">Foo</li>'
+'<li class="a">Bar</li>'
+'</ol>'
总是比
var html="<h2 class=\"a\">A list!</h2>"
+"<ol>"
+"<li class=\"a\">Foo</li>"
+"<li class=\"a\">Bar</li>"
+"</ol>"
但是对于行内(inline)单引号仍然必须转义:
var html = '<p class="a">Don\'t forget to escape single quotes!</p>';
- 换行
最佳方案就是使用连接操作符(+)并将每行用引号括起来:
var html='<h2 class="a">A list!</h2>'
+'<ol>'
+'<li class="a">Foo</li>'
+'<li class="a">Bar</li>'
+'</ol>'
- 可选的分号和花括号
- 重载(并非真正的重载)
相同名字的函数永远只能存在一个实例。如果编写如下的函数
function alert(message)
{
ADS.$('messageBox').appendChild(document.createTextNode(message));
}
浏览器将不会执行往常的提示信息
- 匿名函数
看一下我们常规的注册函数
function clicked()
{
alert('Linked to :'+this.href);
}
var anchor= ADS.$('someID');
ADS.addEvent(anchor,'click',clicked)
匿名函数:
var anchor=ADS.$('someId');
addEvent(anchor,'click',function(){
alert('Linked to:' + this.href);
});
- 作用域解析和闭包
作用域:(通过var维护作用域链)
function myFunction()
{
var myVar='inside';
}
//定义变量
var myVar='outside';
myFunction();
alert(myVar);//outside
如果去掉:
function myFunction()
{
myVar='inside';
}
//定义变量
var myVar='outside';
myFunction();
alert(myVar);//inside
下面看一个例子:
ADS.addEvent(window, 'load', function(W3CEvent) {
for (var i=1 ; i<=3 ; i++ ) {
var anchor = document.getElementById('anchor' + i);
ADS.addEvent(anchor,'click',function() {
alert('My id is anchor' + i);
});
}
});
<li><a href="http://advanceddomscripting.com" id="anchor1">Anchor 1</a></li>
<li><a href="http://advanceddomscripting.com" id="anchor2">Anchor 2</a></li>
<li><a href="http://advanceddomscripting.com" id="anchor3">Anchor 3</a></li>
</ul>
目的:点击anchorx 便提示My id is anchorx,但是情况却不是这样。
原因:i的值时间上是在单机时间发生时,才从 作用域链中取得的,当单机时间发生时,initAnchors()已经执行完毕,因此i的值为4,所以每个alert()显示的都是同一个结果。原因:
处理办法:
function
registerListener(anchor,i) { ADS.addEvent(anchor, 'click', function() { alert('My id is anchor' + i); }); } function initAnchors() { for ( i=1 ; i<=5 ; i++ ) { var anchor = document.getElementById('anchor'+i); registerListener(anchor,i); } } ADS.addEvent(window, 'load', initAnchors);

- 迭代对象
通过hasOwnProperty()方法检查不涉及其他对象继承的属性和方法。智慧检查在特定对象自身中直接创建的属性
- 函数的调用和引用(不带括号)
JavaScript DOM高级程序设计1.3-常见陷阱--我要坚持到底!的更多相关文章
- JavaScript DOM高级程序设计 4.2 事件类型--我要坚持到底!
对象事件 load和unload(载入页面的时候调用load,关闭页面的时候调用unload) abort和error 对于载入图像时出现错误的情况,可以使用error事件侦听器来进行说明: ADS. ...
- JavaScript DOM高级程序设计 7.向应用程序加入Ajax--我要坚持到底!
有时候,或许是因为理解能力,也或许是因为浮躁,看东西总是不入心,而且还老是想跳过本节,或者赶紧看完本节,这样的恶性循环,让我在即没有真正的学习到知识,又打击我的学习信心,还浪费了我很多事件,我想,当遇 ...
- JavaScript DOM高级程序设计 4.3控制事件流和注册事件侦听器--我要坚持到底!
一.事件流 我们通过下面一个实例,进行说明. <body> <h1>Event Flow</h1> <ul id="nav"> &l ...
- JavaScript DOM高级程序设计 3.6 实例 将HTML代码转换成DOM代码(附源码)--我要坚持到底!
作为一名Web开发者,最讨厌的事情就是重复性任务,摆脱乏味的日常重复性事物的一种方法,是借助可重用的对象或者说与你现在建立的ADS库类似的库,另外一种让事情变得有意思,且能够加速开发进程的方式是编写能 ...
- JavaScript DOM高级程序设计 3.-DOM2和HTML2--我要坚持到底!
由一个HTML进行说明,我就不敲了,直接copy <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" " ...
- JavaScript DOM 高级程序设计读书笔记二
响应用户操作和事件 事件就是操作检测与脚本执行的组合,或者基于检测到的操作类型在某个对象上调用事件侦听器(事件处理程序). 事件的类型 事件可以分为几种类型:对象事件,鼠标事件,键盘事件(只适用于do ...
- JavaScript DOM 高级程序设计读书笔记一
创建可重用的对象 简而言之,对象就是包含一组变量(称为属性)和函数(称为方法)的集合的实例.对象通常由类派生而来,而类中定义了对象拥有的属性和方法.如果你的脚本中都是对象之间的交互操作,那么就可以称之 ...
- JavaScript DOM高级程序设计 5动态修改样式和层叠样式表2--我要坚持到底!
把样式置于DOM脚本之外 style属性 我们可以这样设置前景色之类的属性: element.style.color='red'; 也可以使用下面的代码设置背景颜色: element.style.ba ...
- JavaScript DOM高级程序设计 5动态修改样式和层叠样式表1(源代码)--我要坚持到底!
W3C DOM2样式规范 现在这边贴出本章要的源代码,注意要结合前面用到的ADS库http://vdisk.weibo.com/s/Dq8NU CSSStyleSheet对象属性: type :始终是 ...
随机推荐
- CentOS系统中手动调整系统时间的方法
我们一般使用“date -s”命令来修改系统时间.比如将系统时间设定成1996年6月10日的命令如下. #date -s 06/10/96 将系统时间设定成下午1点12分0秒的命令如下. #date ...
- JavaScript 高级程序设计 目录
为什么会写这个学习教程呢??因为一直以来,学习JavaScript都没有系统的学过,用什么学什么,所以今天开始,重新把JavaScript系统的学一遍!(本人也是菜鸟一枚,语文水平也还是小学程度,看得 ...
- PL/SQL Developer编码格式设置及中文乱码解决方案
1.PL/SQL Developer中文字段显示乱码 原因:因为数据库的编号格式和pl /sql developer的编码格式不统一造成的. 2.PL/SQL Developer编码格式设置详细的解决 ...
- c 递归函数浅析
所谓递归,简而言之就是应用程序自身调用自身,以实现层次数据结构的查询和访问. 递归的使用可以使代码更简洁清晰,可读性更好(对于初学者到不见得),但由于递归需要系统堆栈,所以空间消耗要比非递归代码要大很 ...
- 【C++】GacLib——ListView.ViewSwitching
http://www.gaclib.net/Demos/Controls.ListView.ViewSwitching/Demo.html#FILESYSTEMINFORMATION_H
- WPF中利用DynamicDataDisplay快速实现示波器功能
DynamicDataDisplay控件是一个功能很强的绘图工具,除了能生成曲线外,还有很多其他功能,具体见http://dynamicdatadisplay.codeplex.com/.这里你也能下 ...
- Android 的自定义Spinner组件实现方式
一.Android的API方式默认实现的方式 1.layout下编辑main_activity.xml <RelativeLayout xmlns:android="http://sc ...
- 【ibatis】cachemodel、属性 及特殊配置
http://www.cnblogs.com/13590/archive/2013/03/01/2938126.html <?xml version="1.0" encodi ...
- OData 集成
OData 集成 文档目录 本节内容: 简介 安装 安装Nuget包 设置模块依赖 配置你的实体 创建控制器 示例 获取实体列表 请求 响应 获取单个实体 请求 响应 获取单个实体及导航属性 请求 响 ...
- Weblogic12c安装与配置详解
Weblogic是什么Weblogic的安装Weblogic创建域Weblogic管理域Weblogic的应用Weblogic是什么 Weblogic这是我入职以后第一次接触到的词汇,我很陌生,就从我 ...