2015-02-07——js笔记
示例1:
var abc;
console.log(abc === undefined);
console.log(abc === null);
console.log(typeof abc === undefined);
console.log(typeof abc === 'undefined');
=> true;
=> false;
=> false;
=> true;
示例2:
var ceshi = document.getElementById('ceshi');
ceshi.abc = '1111';
var abc = '2222';
function ceshiListener() {
alert(this.abc);
}
ceshi.addEventListener('click', ceshiListener, false);
=> 1111
PS:测试结果,在W3C标准中,侦听器的this的执行环境为被侦听对象。
示例3:
var ceshi = document.getElementById('ceshi');
ceshi.abc = '1111';
var abc = '2222';
function ceshiListener() {
alert(this.abc);
}
ceshi.attachEvent('onclick', ceshiListener);
=> 2222
PS:测试结果,在IE10及以下版本中,侦听器的this的执行环境为window。但在IE11中已不支持attachEvent。
示例4:
指定MSIE标准的事件侦听器中this的执行环境,解决示例3中的问题。
要素:1、将原函数传递给被侦听节点对象某成员。2、注意MSIE标准,不自动传递事件对象window.event给侦听器
示例代码:
node['abc'] = listener; //改变this执行环境
node['delegate'] = function () {
node['abc'](window.event); //针对IE不自动传递事件对象给侦听器
};
node.attachEvent('onclick', node['delegate']);
示例5:
var ceshi = 1;
function abc(ceshi) {//传入的参数名为特殊的局部变量
ceshi = 2; //局部变量
alert(ceshi);
}
abc();
alert(ceshi);
=> 2
=> 1
PS:传入同名参数,可截断作用域链。不影响上级变量,上级变量也不自动传入。
示例6:
全局替换
var a = 'dede';
var b = a.replace(/d/g, '-');
alert(a);
alert(b);
=> dede
=> -e-e
示例7:
关于转义
字符串中,一个\代表转义,单个\可直接忽视。两个\\,输出\。转义不能转义的字符时,转义失败,但\并不输出。
正则表达式中,一般情况下,对于-,转义字符\,可加可不加,出于良好的语义,最好加上。
示例代码:
var abc = 'my\-class\-abc';
var ceshi = abc.replace(/\-/g, '\\-');
alert(abc);
alert(ceshi);
=> my-class-abc
=> my\-class\-abc
var abc = 'my-class-abc';
var ceshi = abc.replace(/\-/g, '\\-');
alert(abc);
alert(ceshi);
=> my-class-abc
=> my\-class\-abc
var abc = 'my\-class\-abc';
var ceshi = abc.replace(/-/g, '\\-');
alert(abc);
alert(ceshi);
=> my-class-abc
=> my\-class\-abc
示例8:
改变函数执行环境
示例代码:
function changeFuncEnv(obj, func) {
return function () {//不用function包装,会立刻执行func函数。且不可接受自定义参数。
func.apply(obj, arguments);
}
}
示例9:
得到浏览器宽高
示例代码:
function getBorwerSize() {
var w3cDom = document.documentElement;
return {
'width': window.innerWidth || (w3cDom && w3cDom.clientWidth) || document.body.clientWidth,
'height': window.innerHeight || (w3cDom && w3cDom.clientHeight) || document.body.clientHeight
};
}
示例10:
基本的nodeType
ELEMENT_NODE: 1,
ATTRBUTE_NODE: 2,
TEXT_NODE: 3,
CDATA_SECTION_NODE: 4,
ENTITY_REFERENCE_NODE: 5,
ENTITY_NODE: 6,
PROCESSING_INSTRUCTION_NODE: 7,
COMMENT_NODE: 8,
DOCUMENT_NODE: 9,
DOCUMENT_TYPE_NODE: 10,
DOCUMENT_FRAGMENT_NODE: 11,
NOTATION_NODE: 12
示例11:
线性遍历节点
function walkDOMLinear(node, func) {
node = node || doucment;
var nodes = node.getElementsByTagName('*');
for (var i = 0; i < nodes.length; i++) {
func.call(nodes[i]);
}
}
示例12:
深度递归遍历节点
function walkDOMRecursive(node, depth, func) {
var root = node || window.document;
var node = root.firstChild;
func.call(root, depth++);
if (node) {
walkDOMRecursive(node, depth, func);
node = node.nextSibling;
}
}
示例13:
深度递归遍历节点属性(未验证)
function walkDOMAttrRecursive(node, depth, func) {
var root = node || window.document;
var node = root.firstChild;
if (root.attributes) {
for (var i = 0; i < root.attributes.length; i++) {//将属性节点视为普通节点,遍历
func(root.attributes[i], depth);
}
}
depth++;
while (node) {
walkDOMAttrRecursive(node, depth, func);
node = node.nextSibling;
}
}
2015-02-07——js笔记的更多相关文章
- [2017.02.07] Lua入门学习记录
#!/home/auss/Projects/Qt/annotated/lua -- 这是第一次系统学习Lua语言 --[[ 参考资料: 1. [Lua简明教程](http://coolshell.cn ...
- 02: vue.js常用指令
目录:Vue其他篇 01: vue.js安装 02: vue.js常用指令 目录: 1.1 vuejs简介 1.2 选择器:根据id.class等查找 1.3 静态绑定数据 data 1.4 插值 { ...
- Data Visualization and D3.js 笔记(1)
课程地址: https://classroom.udacity.com/courses/ud507 什么是数据可视化? 高效传达一个故事/概念,探索数据的pattern 通过颜色.尺寸.形式在视觉上表 ...
- js笔记-0
#js笔记-0 数组: indexOf方法: Array也可以通过indexOf()来搜索一个指定的元素的位置: var arr = [10, 20, '30', 'xyz']; arr.indexO ...
- 【算法训练营day4】LeetCode24. 两两交换链表中的结点 LeetCode19. 删除链表的倒数第N个结点 LeetCode面试题 02.07. 链表相交 LeetCode142. 环形链表II
[算法训练营day4]LeetCode24. 两两交换链表中的结点 LeetCode19. 删除链表的倒数第N个结点 LeetCode面试题 02.07. 链表相交 LeetCode142. 环形链表 ...
- Node.js 笔记02
一.关于命令 常用命令: dir 列出当前目录下面所有的文件 cd 目录名 进入到指定的目录,. 当前目录, .. 进入上级目录,cd . 当前目录, cd .. 上级目录 md 目录名 创建文件夹 ...
- 2015年10月23日JS笔记
ECMAScript标准:JavaScript核心语法 微软:Jscript ECMAScript标准:一纸空文 JavaScript和JScritp都号称完全实现了 ECMAScript标准 W3C ...
- JS笔记—02
1.String截取:substr:截几位, substring:截到哪. 2.String的操作,例如变大写,小写,本身不会变,只是在栈里交换引用似的 var str = "hello w ...
- Node.js笔记07——不使用generator自定义一个项目,深入了解项目结构
一.初始化项目 新建项目 git init manager 新建view文件夹,建几个静态文件夹 新建app.js 快速初始化项目依赖 npm init -y 安装express npm instal ...
- iOS 学习笔记 二 (2015.02.26)
How To Use Git Source Control with Xcode in iOS 6 If you're new here, you may want to subscribe to m ...
随机推荐
- 移动负载均衡技术(MBL)
移动负载均衡技术(MBL) 转至元数据结尾 附件:5 被admin添加,被admin最后更新于四月 27, 2015 转至元数据起始 互联网技术发展到今天,已经进入移动时代,很多在传统CS和BS的 ...
- python 利用numpy进行数据分析
一.numpy.loadtxt读取数据 data=numpy.loadtxt('数据路径.txt',delimiter=',',usecols=(0,1,2,3) , dtype=float)#读取后 ...
- mac系统中搭建apache+mysql+php的开发环境,安装mysql后,登录报错:mac ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: NO)
php新手在mac系统中搭建apache+mysql+php的开发环境(按照这篇博客来操作的:http://my.oschina.net/joanfen/blog/171109?fromerr=xvC ...
- eclipse spring xml 无提示解决
增加自动提示的步骤: 1.window->preference.->xml-xml catalog 2.选中 user specified entried 3.选则Add..按钮 URI: ...
- MyBatis官方教程及源代码解析——mapper映射文件
缓存 1.官方文档 MyBatis 包括一个非常强大的查询缓存特性,它能够非常方便地配置和定制. MyBatis 3 中的缓存实现的非常多改进都已经实现了,使得它更加强大并且易于配置. 默认情况下是没 ...
- Strategy模式
Strategy模式 Strategy模式要解决的问题和Template模式类似.都是为了把算法的声明和算法的实现解耦.Template模式是通过继承来实现的,而Strategy模式是通过组合来实现的 ...
- 【算法拾遗(java描写叙述)】--- 插入排序(直接插入排序、希尔排序)
插入排序基本思想 每次将一个待排序的记录按其keyword大小插入到前面已经拍好序的子文件的适当位置,直到全部记录插入完毕为止. 直接插入排序 基本思想 直接插入排序的基本操作是将一个记录插入到已排好 ...
- 1.const
在C++中,const 的含义并没有改变,只是对细节进行了一些调整,以下是最主要的两点. 一.C++中的 const 更像编译阶段的 #define 先来看下面的两条语句: ; int n = m; ...
- flink checkpoint 源码分析 (一)
转发请注明原创地址http://www.cnblogs.com/dongxiao-yang/p/8029356.html checkpoint是Flink Fault Tolerance机制的重要构成 ...
- Python 中,matplotlib绘图无法显示中文的问题
在python中,默认情况下是无法显示中文的,如下代码: import matplotlib.pyplot as plt # 定义文本框和箭头格式 decisionNode = dict(boxsty ...