1. BOM이란
BOM(Browser Object Document)은 브라우저 객체 모델입니다.
BOM은 콘텐츠와 독립적으로 브라우저 창과 상호 작용하는 개체를 제공합니다.
BOM은 주로 창 간의 통신을 관리하는 데 사용되므로 핵심 개체는 창입니다. 일련의 관련 개체로 구성되며 각 개체는 많은 메서드와 속성을 제공합니다.
BOM에는 표준이 부족합니다. JavaScript 구문의 표준화 조직은 ECMA이고 DOM의 표준화 조직은 W3C입니다. Netscape 브라우저 표준의 일부입니다.
2. BOM 학습 시 배울 점
브라우저를 이동하고 크기를 조정할 수 있는 window 객체, 브라우저 창과 상호작용하는 몇 가지 객체를 학습합니다. 내비게이션 개체를 사용하면 네비게이터 및 화면 개체가 브라우저, 운영 체제 및 사용자 화면 정보를 얻을 수 있습니다. 문서를 HTML 문서에 액세스하고 프레임 개체를 관리하는 입구로 사용할 수 있습니다. 등. 여기서는 윈도우 객체 등에 대한 기본적인 지식만 소개하고, ECMAscript 지식도 일부 설명하겠습니다. 그 외의 객체인 Location, Screen, Navigator, History는 일일이 자세히 소개하지 않습니다. .
3. Window 객체
window 객체는 js의 최상위 객체입니다. 전역 범위에 정의된 모든 변수와 함수는 호출 시 window 객체의 속성과 메서드가 됩니다. 창은 생략 가능합니다.
예:
打开窗口 window.open(url,target,param); // url 要打开的地址 //target 新窗口的位置 _blank _self _parent(父框架) //param 新窗口的一些设置 //返回值,新窗口的句柄 关闭窗口:window.close();
4. BOM 단편적 지식(창 개체)
1. > 지연된 실행 setTimeout( [string | function] code, 간격); = setInterval(code, 간격);
clearInterval(timerId); //타이머 지우기카운트다운 사례:
<body> <input type="button" value="closeTimerId" id="btn"> <script> var btn = document.getElementById("btn"); var timerId = setTimeout(function () { alert("23333"); }, 3000); btn.onclick = function () { //在设置的时间之前(3s内)点击可以取消定时器 clearTimeout(timerId); } </script> </body>
2.offset 계열 방법
offsetWidth 및 offsetHeight
2. .style.height는 문자열(단위 px 포함)이고 offsetHeight는 숫자 값(단위 없음)입니다. 3. .style.height는 인라인 스타일을 설정할 수 있지만 offsetHeight는 읽기입니다. -속성만 있고 설정할 수 없습니다 그래서: deco.style.height는 요소의 값을 가져옵니다. 실제 높이/너비, .style.height를 사용하여 높이/너비를 설정합니다. offsetLeft 및 offsetTop offsetLeft 구성 1, 자체에 가장 가까운 위치(위치 지정 포함) 상위 요소의 왼쪽/상단 2, 모든 상위 요소가 위치 지정되지 않은 경우 본문이 우선합니다 3, offsetLeft는 자체 테두리의 왼쪽이며 부모 패딩의 왼쪽입니다. 측면 거리 offsetLeft와 style.left의 차이 1, style.left는 인라인 스타일만 가져올 수 있습니다 2, offsetLeft는 읽기 전용, style.left는 읽기 가능 쓰기 3, offsetLeft는 숫자 값, style.left는 문자열 px4라는 단위가 있습니다. 위치 지정이 없으면 style.left에서 얻은 값이 유효하지 않을 수 있습니다. 5, 가장 큰 차이점: offsetLeft는 왼쪽 위 모서리를 기준으로 합니다. border, style.left는 여백의 왼쪽 상단을 기준으로 합니다. offsetParent 구성 1. 개체 상위 요소의 가장 가까운 위치를 반환합니다. 2. 현재 요소의 상위 요소가 배치되지 않은 경우(위치는 절대 또는 상대) offsetParent는 body3입니다. offsetLeft가 얻는 것은 offsetParent에 상대적입니다. 거리 와 parentNode parentNode는 위치 여부에 관계없이 항상 현재 요소의 가장 가까운 상위 요소를 가리킵니다. 3.scroll 시리즈 메서드 scrollHeight 및 scrollWidth 높이/너비 객체 내부의 실제 콘텐츠(테두리 제외)scrollTop 및 scrollLeft 스크롤된 부분의 위쪽/왼쪽에서 시각적 영역의 위쪽/왼쪽까지의 거리onscroll 이벤트 스크롤 막대 스크롤로 인해 발생하는 이벤트페이지 스크롤 좌표 var scrollTop = window.pageYoffset || document.documentElement.scrollTop || document.body.scrollTop || 0;4 .client 시리즈clientX 및 clientY 가시 영역에서 마우스 위치 가져오기 clientX = 너비 + 패딩, clientY = 높이 + 패딩clientLeft 스크롤 막대가 있는 경우 스크롤을 포함한 테두리 너비 Bar예: 페이지의 표시 영역 크기를 가져옵니다
<body> <input type="button" value="倒计时开始10" id="btn" disabled/> <script> var btn = document.getElementById("btn"); var num = 10; var timerId = setInterval(function () { num--; btn.value = "到时器开始" + num; if (num == 0) { clearInterval(timerId); btn.disabled = false; btn.value = "同意,可以点了"; } },1000); </script> </body>
获取鼠标在页面中的位置(IE8中不支持pageX和pageY,支持window.event获取参数事件) pageX = clientX + 页面滚动出去的距离
6.获得计算后样式的方法
w3c标准 window.get ComputedStyle(element, null)[属性]IE浏览器 element.currentStyle[属性]封装浏览器兼容性函数
function getStyle(element, attr) { if(window.getComputedStyle) { return window.getComputedStyle(element, null)[attr]; } else { return element.currentStyle[attr]; } }
7.事件补充
注册事件
注册事件的性能问题
移除事件
事件冒泡
事件捕获 事件的三个阶段
事件对象的常见属性
DOM笔记里有提到注册事件和移除事件,这里着重讲事件对象,事件对象的常见属性
7.1 target 和currentTarget
target 始终是点击的元素(IE8及之前是srcElement)
currentTarget 执行事件处理函数的元素
this 始终和currentTarget一样
7.2 事件冒泡
用addEventListener注册事件的时候,第三个参数是false,即是冒泡。
冒泡的好处 - 事件委托
从一个例子中说明
<body> <ul id="ul"> <li>我是第1个li标签</li> <li>我是第2个li标签</li> <li>我是第3个li标签</li> <li>我是第4个li标签</li> </ul> <input type="button" value="insertLi" id="btn"> <script> var ul = document.getElementById("ul"); var btn = document.getElementById("btn"); //把本来应该给li注册的事件,委托给ul,只需要给一个元素注册事件 //动态创建的li,也会执行预期的效果 ul.addEventListener("click", test, false); //注册点击事件 btn.onclick = function () { //点击同样会有alert var li = document.createElement("li"); li.innerHTML = "我是新插入的li标签"; ul.appendChild(li); }; //函数写在注册事件代码之外,提高性能 function test(e) { alert(e.target.innerText); } </script> </body>
当事件冒泡影响到了其他功能的实现时,需要阻止冒泡
e.stopPropagation( ) IE8及之前: event.cancleBubble = true;
阻止默认行为的执行
e.preventDefault() IE8及之前: event.returnValue = false;
看一下阻止跳转到百度的例子:
<body> <a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" id="link">百度</a> <script> var link = document.getElementById("link"); link.addEventListener("click", fn, false); function fn(e) { e.preventDefault(); //若用return false; 不起作用,若用link.onclick = function();return false可以阻止 } </script> </body>
7.3 鼠标事件的参数
e.type 事件的类型,如click,mouseover
事件的3个阶段 1 捕获阶段 2 目标阶段 3 冒泡阶段
e.eventPhase 事件阶段
shiftKey/ctrlKey/altKey 按下鼠标同时按下组合键
button 获取鼠标的按键
e.clientX和e.clientY 获取鼠标在可视区域的位置
还有7.2中的取消事件冒泡和阻止默认行为的执行
8.正则表达式
定义:
正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。
规则:
1 元字符
. 匹配任何单个字符,除了换行
d 数字 \D 非数字 [0-9] w 数字 字母 下划线 \W 非 [0-9a-zA-Z_] \s 空白 \S 非空白
\n 换行
\t 制表符
2 范围-- 匹配的是一个字符 [0-9][0123][a-z][A-Z] 匹配的是一个字符
3 | 或者 | 或者
4 量词 -只修饰一个字符
a+ 1个或多个a
a? 1个或0个a
a* 0个或多个a
a{x} x个n
a{x,} 至少x个a
a{x,y} x-y个a
5 开始结束
^a 以a开始
a$ 以a结束
6 ( ) 看成是一个整体,即分组
7 匹配汉字 [\u4e00-\u9fa5]8 参数
i 忽略大小写
g 全局匹配
9 ^在[ ]中的作用——取反
10 贪婪模式和非贪婪模式
默认情况 贪婪模式 <.+>
非贪婪模式 <.+?>
8.1 正则表达式对象RegExp
<body> <a href="http://www.baidu.com" rel="external nofollow" rel="external nofollow" id="link">百度</a> <script> // var regularExpression = new RegExp("\\d"); //第一种写法 var regularExpression = /\d/; //第二种写法 var str = "adfj23dald"; console.log(regularExpression.test(str)); //test就是匹配方法,结果是true </script> </body>
8.2 正则之匹配
例:验证电子邮箱
//验证电子邮箱 // abc@sohu.com // 11111@qq.com // aaaaa@163.com // abc@sina.com.cn var reg = /^\w+@\w+\.\w+(\.\w+)?$/; var str = "abc@sina.com.cn"; console.log(reg.test(str));
8.3 正则之提取
例:找数字
var str = "张三: 1000,李四:5000,王五:8000。"; var reg = /\d+/g; //默认情况下,找到第一个匹配的结果就返回,后面加个g,就是全局找 var arr = str.match(reg); console.log(arr);
8.4 正则之替换
例:所有的逗号替换成句号
var str = "abc,efg,123,abc,123,a"; str = str.replace(/,/g,"."); console.log(str);
8.5 正则的分组( )
在正则表达式中用( )把要分到一组的内容括起来,组分别是RegExp.$1 RegExp.$2等等
例:交换位置 源字符串"5=a, 6=b, 7=c" 要的结果"a=5, b=6, c=7"
var str = "5=a, 6=b, 7=c"; str = str.replace(/(\d+)=(\w+)/g, "$2=$1"); console.log(str);
9.键盘事件对象[b][/b]
方法
keydown 按下时
keypress 按下
keyup 抬起时
属性
keyCode 键盘码,只有数字和字母对应ASCII码
charCode 对应ASCII码,只有在keypress中才生效(IE9+)
例:在切换鼠标焦点时,用enter键代替tab键
<body> <input type="text"><input type="text"><input id="t1" type="text"><input type="text"><input type="text"><input type="text"><inputtype="text"><input type="text"><input type="text"><input type="text"> <script> var inputs = document.body.getElementsByTagName("input"); for(var i = 0, length = inputs.length; i < length ; i++) { var input = inputs[i]; //回车键的keyCode是13 if(input.type === "text") { //按下回车,让下一个文本框获得焦点 input.onkeydown = function (e) { if(e.keyCode === 13) { this.nextElementSibling.focus();//focus() 他触发了onfocus事件 } } } } </script> </body>
补充:js中的instanceof运算符介绍
判断某个变量是不是某种类型的对象
var num = 5; var arr = []; console.log(num instanceof Array); //false console.log(arr instanceof Array); //true
更多javascript中BOM基础知识总结相关文章请关注PHP中文网!