JavaScript基础深入研究
一、DOM事件
1.事件阻止API
preventDefault() — 阻止浏览器默认
stopPropagation() — 阻止事件流冒泡
stopImmediatePropagation() — 阻止事件流冒泡+阻止目标节点上绑定的其他优先级低的回调函数
2.jquery中的return false
比如xx.on('click',function(){...})
...为return; — 结束当前回调函数
...为return false; — 结束当前回调函数+preventDefault()+stopPropagation()
3.事件优先级 ie兼容
标准浏览器以及ie9+中 addEventListener优先级按照绑定顺序;
ie8- attachEvent 优先级是随机的
ie ele.attachEvent('onclick',function(){...this..}) this指的window
二、javascript加载执行顺序
1.两个<script>代码段,因为执行顺序问题,上面的代码段调用下面的代码段函数的话,会报错。
2.如果分成预编译和执行两个阶段的话,预编译期会声明所有变量与函数,执行期会给变量赋值。
<script type="text/javascript">
alert(a);
var a=1;
b();
b=function(){alert(1);}
</script> a 代码不会报错,弹出undefined(因为已经声明,但是没有赋值)
b 代码报错,因为下面的函数是作为一个变量,预编译期并未赋值
三、正则
0.基础
/[a-z|A-Z]/ 匹配任意大小写以及|
/[-]/ 匹配-
/[-z]/ 匹配-或z
/[a-zA-Z]/ 匹配任意大小写
1.构造函数RegExp()创建正则时的转义
两种方式可以创建正则对象:正则表达式直接量和构造函数RegExp()。
注意:用构造函数的话,需要对特殊符号进行转义。详细:http://www.cnblogs.com/wang123/archive/2007/09/19/898668.html
var reg=new RegExp("\d");
reg.test("1");
//false
var reg=new RegExp("\\d");
reg.test("1");
//true
/\d/.test("1")
//true
2.replace+正则高级应用
replace的参数是(reg,fn)的时候,每个匹配都调用fn,它返回的字符串将作为替换文本使用。fn有四个参数:
1.匹配模式的字符串。
2.与模式中的子表达式匹配的字符串,可以有 0 个或多个这样的参数。
3.一个整数,声明了匹配在 stringObject 中出现的位置。
4.最后一个参数是 stringObject 本身。
"xx-yy-zz".replace(/-(.)/g,function(){
console.log(arguments);
return arguments[1].toUpperCase();
});
//["-y", "y", 2, "xx-yy-zz"]
//["-z", "z", 5, "xx-yy-zz"]
//"xxYyZz"
"xx-yy-zz".replace(/((-)(.))/g,function(){
console.log(arguments);
return arguments[1].toUpperCase();
});
//["-y", "-y", "-", "y", 2, "xx-yy-zz"]
//["-z", "-z", "-", "z", 5, "xx-yy-zz"]
//"xx-Yy-Zz"
四、元素的大小和位置
每个元素都有下面几个属性(注意要和鼠标事件的位置属性offsetX、clientX、pageX区别开)
大小:offsetWidth、clientWidth、scrollWidth
位置:offsetLeft、clientLeft、scrollLeft
当然对应的还有Height、Top。
| js API属性 | 说明 | jquery API |
| clientWidth | width+padding | innerWidth() |
| offsetWidth | width+padding+border | outerWidth() |
| scrollWidth | clientWidth+溢出部分 | —— |
| clientLeft | border-left | —— |
| offsetLeft | border外边缘与offsetParent的border内边缘的距离 | —— |
| scrollLeft | 滚动条向右滚动的距离,可写 | —— |
注:css中定义的width需要用o.style.width或window.getComputedStyle(o).width 来获取
五、函数作用域
var name = "window";
var object = {
name : "object",
funA : function(){
return this.name;
},
funB:function(){
return this.funA();
},
funC:function(){
return this.funA;
}
};
alert(object.funA());//object
alert(object.funB());//object
alert(object.funC()());//window
alert(object.funA.call(window));//window
alert(object.funC().call(object));//object
JavaScript基础深入研究的更多相关文章
- 一步步学习javascript基础篇(0):开篇索引
索引: 一步步学习javascript基础篇(1):基本概念 一步步学习javascript基础篇(2):作用域和作用域链 一步步学习javascript基础篇(3):Object.Function等 ...
- 【JavaScript基础系列】决定你的人生能走多远的,是基础。
前言 javaScript门槛非常低,一点语法,一个dom,一个bom就可以使用它开发大部分js应用,再加上现在层出不穷的框架极大的简化抽象了javaScript的使用方式,但是我们始终不能忘记的一点 ...
- javascript基础修炼(7)——Promise,异步,可靠性
开发者的javascript造诣取决于对[动态]和[异步]这两个词的理解水平. 一. 别人是开发者,你也是 Promise技术是[javascript异步编程]这个话题中非常重要的,它一度让我感到熟悉 ...
- JavaScript基础入门10
目录 JavaScript 基础入门10 正则表达式 为什么使用正则表达式? 正则表达式的应用场景 如何创建一个正则表达式 基础语法 具有特殊意义的转义字符 量词 字符类 贪婪模式 练习 邮箱验证 中 ...
- JavaScript——基础知识,开始我们的js编程之旅吧!
JavaScript基础第01天 1. 编程语言 编程语言: 可以通过类似于人类语言的"语言"来控制计算机,让计算机为我们做事情,这样的语言就叫做编程语言(Programming ...
- JavaScript基础语法资料
JavaScript基础第01天 1 - 编程语言 1.1 编程 编程: 就是让计算机为解决某个问题而使用某种程序设计语言编写程序代码,并最终得到结果的过程. 计算机程序: 就是计算机所执行的一系列的 ...
- JavaScript基础第01天笔记
JavaScript基础第01天 1 - 编程语言 1.1 编程 编程: 就是让计算机为解决某个问题而使用某种程序设计语言编写程序代码,并最终得到结果的过程. 计算机程序: 就是计算机所执行的一系列的 ...
- JavaScript基础
JavaScript基础 JavaScript是一门编程语言,浏览器内置了JavaScript语言的解释器,所以在浏览器上按照JavaScript语言的规则编写相应代码之,浏览器可以解释并做出相应的处 ...
- 前端之JavaScript基础
前端之JavaScript基础 本节内容 JS概述 JS基础语法 JS循环控制 ECMA对象 BOM对象 DOM对象 1. JS概述 1.1. javascript历史 1992年Nombas开发出C ...
随机推荐
- 关于i++,++i 的理解
由于经常有同学在遇到 i++.++i 时犯困难.所以举例说明一下: int i = 20; int sum = i++ * 30; //这个等式中 i = 20 int s ...
- java反射机制,通过类名获取对象,通过方法名和参数调
import java.lang.reflect.Method; import javax.persistence.Table; /** * 通过注解javax.persistence.Tabl ...
- jquery 无刷新多级联动
原先不熟悉jquery时,总在寻找无刷新的方法,在此不断的积累自己所知道的jquery属性,常用方法.以下为jquery实现的无刷新联动事件 分公司: <select id="Sele ...
- 谢欣伦 - OpenDev原创教程 - 蓝牙设备查找类CxBthRemoteDeviceFind
这是一个精练的蓝牙设备查找类,类名.函数名和变量名均采用匈牙利命名法.小写的x代表我的姓氏首字母(谢欣伦),个人习惯而已,如有雷同,纯属巧合. CxBthRemoteDeviceFind的使用如下: ...
- SDOI 2016 数字配对
题目大意:给定n个数字以及每个数字的个数和权值,将满足条件的数字配对,使得总代价不小于0,且配对最多 最大费用最大流拆点,对于每个点,连一条由S到该点的边,容量为b,花费为0,再连一条到T的边 对于每 ...
- shell简单用法笔记(shell中数值运算)二
shell中变量值,如果不手动指定类型,默认都是字符串类型: 例如: a= b= c=$a+#b echo $c 结果会输出:123+456 shell中,如果要进行数值运算,可以通过一下方法: 方法 ...
- SQL Server 2016 CTP2.2 安装手记
SQL Server 2016 CTP2.2 安装手记 下载一个iso文件,解压出来(大约2.8G左右),在该路径下双击Setup.exe即可开始安装. 安装之前请先安装.NET 3.5 SP1,在服 ...
- Android5.1.1 - APK签名校验分析和修改源码绕过签名校验
Android5.1.1 - APK签名校验分析和修改源码绕过签名校验 作者:寻禹@阿里聚安全 APK签名校验分析 找到PackageParser类,该类在文件“frameworks/base/cor ...
- Python黑帽编程 3.2 ARP监控
Python黑帽编程 3.2 ARP监控 在第3.1节<ARP欺骗>中,我们学习了ARP的基本原理,使用Python实现了我们自己的ARP欺骗工具.在上一节的基础上,我们来实现一个ARP监 ...
- 启动 Apache2.2 的问题
启动 Apache2.2 的问题: windows不能在本地计算机启动 Apache2.2.有关更多信息,查阅系统事件日志.如果这是非Microsoft服务,请与服务厂商联系,并参考特定服务错误代码1 ...