定义了JavaScript 的语法规范javascript
JavaScript的核心,描述了语言的基本语法和数据类型,ECMAScript是一套标准,定义了一种语言的标准与具体实现无关html
一套操做浏览器功能的APIjava
经过BOM能够操做浏览器窗口,好比:弹出框、控制浏览器跳转、获取分辨率等node
一套操做页面元素的APIgit
DOM能够把HTML看作是文档树,经过DOM提供的API能够对树上的节点进行操做数组
掌握
getElementById()
getElementsByTagName()
了解
getElementsByName()
getElementsByClassName()
querySelector()
querySelectorAll()
复制代码
var div = document.getElementById('main');
console.log(div);
// 获取到的数据类型 HTMLDivElement,对象都是有类型的
复制代码
注意:因为id名具备惟一性,部分浏览器支持直接使用id名访问元素,但不是标准方式,不推荐使用。浏览器
var divs = document.getElementsByTagName('div');
复制代码
*
var inputs = document.getElementsByName('hobby');
复制代码
*
var mains = document.getElementsByClassName('main');
复制代码
*
var text = document.querySelector('#text');
console.log(text);
var boxes = document.querySelectorAll('.box');
for (var i = 0; i < boxes.length; i++) {
var box = boxes[i];
console.log(box);
}
复制代码
var box = document.getElementById('box');
box.innerHTML = '我是文本<p>我会生成为标签</p>';
console.log(box.innerHTML);
box.innerText = '我是文本<p>我不会生成为标签</p>';
console.log(box.innerText);
复制代码
" " ' ' & & < < // less than 小于 > > // greater than 大于 空格 © © 复制代码
表单元素属性bash
自定义属性操做服务器
样式操做app
var box = document.getElementById('box');
box.style.width = '100px';
box.style.height = '100px';
box.style.backgroundColor = 'red';
复制代码
注意
经过样式属性设置宽高、位置的属性类型是字符串,须要加上px
类名操做
var box = document.getElementById('box');
box.className = 'show';
复制代码
document.write('新设置的内容<p>标签也能够生成</p>');
复制代码
var box = document.getElementById('box');
box.innerHTML = '新内容<p>新标签</p>';
复制代码
var div = document.createElement('div');
document.body.appendChild(div);
复制代码
var body = document.body;
var div = document.createElement('div');
body.appendChild(div);
var firstEle = body.children[0];
body.insertBefore(div, firstEle);
body.removeChild(firstEle);
var text = document.createElement('p');
body.replaceChild(text, div);
复制代码
function Element(option) {
this.id = option.id || '';
this.nodeName = option.nodeName || '';
this.nodeValue = option.nodeValue || '';
this.nodeType = 1;
this.children = option.children || [];
}
var doc = new Element({
nodeName: 'html'
});
var head = new Element({
nodeName: 'head'
});
var body = new Element({
nodeName: 'body'
})
doc.children.push(head);
doc.children.push(body);
var div = new Element({
nodeName: 'div',
nodeValue: 'haha',
});
var p = new Element({
nodeName: 'p',
nodeValue: '段落'
})
body.children.push(div);
body.children.push(p);
function getChildren(ele) {
for(var i = 0; i < ele.children.length; i++) {
var child = ele.children[i];
console.log(child.nodeName);
getChildren(child);
}
}
getChildren(doc);
复制代码
注意
childNodes和children的区别,childNodes获取的是子节点,children获取的是子元素
nextSibling和previousSibling获取的是节点,获取元素对应的属性是nextElementSibling和previousElementSibling获取的是元素
nextElementSibling和previousElementSibling有兼容性问题,IE9之后才支持
总结
节点操做,方法
appendChild()
insertBefore()
removeChild()
replaceChild()
节点层次,属性
parentNode
childNodes
children
nextSibling/previousSibling
firstChild/lastChild
复制代码
var box = document.getElementById('box');
box.onclick = function () {
console.log('点击后执行');
};
box.onclick = null;
//注册与删除事件
box.addEventListener('click', eventCode, false);
box.removeEventListener('click', eventCode, false);
//IE特有的删除与注册事件
box.attachEvent('onclick', eventCode);
box.detachEvent('onclick', eventCode);
function eventCode() {
console.log('点击后执行');
}
复制代码
function addEventListener(element, type, fn) {
if (element.addEventListener) {
element.addEventListener(type, fn, false);
} else if (element.attachEvent){
element.attachEvent('on' + type,fn);
} else {
element['on'+type] = fn;
}
}
function removeEventListener(element, type, fn) {
if (element.removeEventListener) {
element.removeEventListener(type, fn, false);
} else if (element.detachEvent) {
element.detachEvent('on' + type, fn);
} else {
element['on'+type] = null;
}
}
复制代码
window.onload = function () {
// 当页面加载完成执行
// 当页面彻底加载全部内容(包括图像、脚本文件、CSS 文件等)执行
}
复制代码
window.onunload = function () {
// 当用户退出页面时执行
}
复制代码
在指定的毫秒数到达以后执行指定的函数,只执行一次
// 建立一个定时器,1000毫秒后执行,返回定时器的标示
var timerId = setTimeout(function () {
console.log('Hello World');
}, 1000);
// 取消定时器的执行
clearTimeout(timerId);
复制代码
定时调用的函数,能够按照给定的时间(单位毫秒)周期调用函数
// 建立一个定时器,每隔1秒调用一次
var timerId = setInterval(function () {
var date = new Date();
console.log(date.toLocaleTimeString());
}, 1000);
// 取消定时器的执行
clearInterval(timerId);
复制代码
location对象是window对象下的一个属性,时候的时候能够省略window对象
location能够获取或者设置浏览器地址栏的URL
统一资源定位符 (Uniform Resource Locator, URL)
scheme://host:port/path?query#fragment
scheme:通讯协议
经常使用的http,ftp,maito等
host:主机
服务器(计算机)域名系统 (DNS) 主机名或 IP 地址。
port:端口号
整数,可选,省略时使用方案的默认端口,如http的默认端口为80。
path:路径
由零或多个'/'符号隔开的字符串,通常用来表示主机上的一个目录或文件地址。
query:查询
可选,用于给动态网页传递参数,可有多个参数,用'&'符号隔开,每一个参数的名和值用'='符号隔开。例如:name=zs
fragment:信息片段
字符串,锚点.
复制代码
经过userAgent能够判断用户浏览器的类型
经过platform能够判断浏览器所在的系统平台类型.
var box = document.getElementById('box');
console.log(box.offsetParent);
console.log(box.offsetLeft);
console.log(box.offsetTop);
console.log(box.offsetWidth);
console.log(box.offsetHeight);
复制代码
var box = document.getElementById('box');
console.log(box.clientLeft);
console.log(box.clientTop);
console.log(box.clientWidth);
console.log(box.clientHeight);
复制代码
var box = document.getElementById('box');
console.log(box.scrollLeft)
console.log(box.scrollTop)
console.log(box.scrollWidth)
console.log(box.scrollHeight)
复制代码