-_-#【JS】HTML5 API
《JavaScript高级程序设计(第3版)》
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
</head>
<body>
<ul class="list">
<li class="item">1</li>
<li class="item">2</li>
<li class="item current">3</li>
</ul>
<button id="myButton">button</button>
<script>
/**
* getElementsByClassName()
* 支持 getElementsByClassName()方法的浏览器有 IE 9+、Firefox 3+、Safari 3.1+、Chrome 和 Opera 9.5+
*/
+function() {
var nodeList = document.getElementsByClassName('item current') // item && current
console.log(nodeList)
var nodeList = document.getElementsByClassName('item')
console.log(nodeList)
}(); /**
* classList
* 支持 classList 属性的浏览器有 Firefox 3.6+和 Chrome
* add(value)
* contains(value)
* remove(value)
* toggle(value)
*/
+function() {
var nodeList = document.getElementsByClassName('item')
nodeList.item(0).classList.add('current')
nodeList.item(2).classList.remove('current')
}(); /**
* document.activeElement document.hasFocus()
* 实现了这两个属性的浏览器的包括 IE 4+、Firefox 3+、Safari 4+、Chrome 和 Opera 8+
* 元素获得焦点的方式有页面加载、用户输入(通常是 通过按 Tab 键)和在代码中调用 focus()方法
* 默认情况下,文档刚刚加载完成时,document.activeElement 中保存的是 document.body 元 素的引用。
* 文档加载期间,document.activeElement 的值为 null
* 查询文档获知哪个元素获得了焦点,以及确定文档是否获得了焦点
* 通过检测文档是否获得了焦点,可以知道用户是不是正在与页面交互
*/
+function() {
console.log(document.activeElement)
console.log(document.hasFocus())
var button = document.getElementById('myButton')
button.focus()
console.log(document.activeElement === button)
console.log(document.hasFocus())
}(); /**
* document.readyState
* 支持 readyState 属性的浏览器有 IE4+、Firefox 3.6+、Safari、Chrome 和 Opera 9+
* IE4 最早为 document 对象引入了 readyState 属性。
* 然后,其他浏览器也都陆续添加这个属性, 最终 HTML5 把这个属性纳入了标准当中
* Document 的 readyState 属性有两个可能的值
* loading,正在加载文档
* complete,已经加载完文档
*/
+function() {
if (document.readyState == 'complete') {
console.log('complete')
}
}(); /**
* document.compatMode
* 陆续实现这个属性的浏览器有 Firefox、Safari 3.1+、Opera 和 Chrome
* 标准模式 CSS1Compat
* 混杂模式 BackCompat
*/
if (document.compatMode == 'CSS1Compat') {
console.log('Standards mode')
} else {
console.log('Quirks mode')
} /**
* 作为对 document.body 引用文档的<body>元素的补充,HTML5 新增了 document.head 属性, 引用文档的<head>元素
* 实现 document.head 属性的浏览器包括 Chrome 和 Safari 5
*/
var head = document.head || document.getElementsByTagName('head')[0]
console.log(head)
</script>
</body>
</html>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
</head>
<body>
<ul class="list">
<li class="item" data-appId="12345" data-my-name="na">1</li>
<li class="item">2</li>
<li class="item current">3</li>
</ul>
<div id="box1">box1</div>
<div id="box2">box2</div>
<div id="box3" style="margin-top:600px">box3</div>
<div id="box4">box4</div>
<script>
/**
* document.charseet
* document.defalutCharset
* 表示根据默认浏览器及操作系统的设置,当前文档默认的字符集 应该是什么
* 支持 document.charset 属性的浏览器有 IE、Firefox、Safari、Opera 和 Chrome。
* 支持 document.defaultCharset 属性的浏览器有 IE、Safari 和 Chrome
*/
console.log(document.charset, document.defaultCharset) // dataset
var firstLi = document.querySelector('.item')
firstLi.setAttribute('data-appId2', '54321')
firstLi.setAttribute('data-my-name2', 'nana')
// chrome DOMStringMap {appid: "12345", myName: "na", appid2: "54321", myName2: "nana"}
console.log(firstLi.dataset)
if (firstLi.dataset.appid) {
firstLi.dataset.appid = 111111
} var lastLi = document.querySelectorAll('.item')[2]
lastLi.dataset.appId = 'data-app-id'
lastLi.dataset.appid = 'data-appid' /**
* innerHTML
* 但是,不同浏览器返回的文本格式会有所不同。
* IE 和 Opera 会将所有标签转换为大写形式,
* 而 Safari、 Chrome 和 Firefox 则会原原本本地按照原先文档中(或指定这些标签时)的格式返回 HTML,包括空格 和缩进。
* 不要指望所有浏览器返回的 innerHTML 值完全相同
*
* 并不是所有元素都支持 innerHTML 属性。
* 不支持 innerHTML 的元素有:<col>、<colgroup>、 <frameset>、<head>、<html>、<style>、<table>、<tbody>、<thead>、<tfoot>和<tr>。
* 此 外,在 IE8 及更早版本中,<title>元素也没有 innerHTML 属性
*/ /**
* outerHTML
* 支持 outerHTML 属性的浏览器有 IE4+、Safari 4+、Chrome 和 Opera 8+。
* Firefox 7 及之前版本都不 支持 outerHTML 属性
*/
document.getElementById('box1').outerHTML = '<p>This is a paragraph.</p>' /**
* scrollIntoView
* 支持 scrollIntoView()方法的浏览器有 IE、Firefox、Safari 和 Opera
*/
setTimeout(function() {
document.getElementById('box4').scrollIntoView()
}, 0)
</script>
</body>
</html>
-_-#【JS】HTML5 API的更多相关文章
- -_-#【JS】defer / async
引用JavaScript文件时的两个属性defer和async <script src="js1.js" defer></script> <scrip ...
- 【转】HTML5 API——无刷新更新地址 history.pushState/replaceState 方法
(window.location)在通过JavaScript更改以后,浏览器都会通过刷新来到达你更改后的URL(location的意思就是位 置..) 而在JavaScript MVC开始流行之后,通 ...
- 【转】HTML5 API --- 页面可见性改变(visibilitychange)事件
[摘要:[本文属本创,若有转载,请说明出处http://blog.csdn.net/yl02520/article/] visibilitychange事情是扫瞄器新增加的一个事情,当扫瞄器的某个标签 ...
- -_-#【JS】element.click()
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- -_-#【JS】隐含全局变量
隐含全局变量与明确定义的全局变量有细微的不同,不同之处在于能否使用delete操作符撤销变量 使用var创建的全局变量(这类变量在函数外部创建)不能删除不使用var创建的隐含全局变量(尽管它是在函数内 ...
- -_-#【JS】isFinite
/** * isFinite(number) * 检查是否是无穷大 * 如果 number 是有限数字(或可转换为有限数字),那么返回 true * 如果 number 是 NaN(非数字),或者是正 ...
- 【javascript】html5中使用canvas编写头像上传截取功能
[javascript]html5中使用canvas编写头像上传截取功能 本人对canvas很是喜欢,于是想仿照新浪微博头像上传功能(前端使用canvas) 本程序目前在谷歌浏览器和火狐浏览器测试可用 ...
- 【译】html5游戏入门
[译]html5游戏入门 原文链接 简介 如果你想用canvas做个游戏,那么来对地方了. 但是但是你至少知道javascript怎么拼写(╯‵□′)╯︵┻━┻ 既然没问题,那先来玩一下或者下载 创建 ...
- 【Demo】HTML5 拍照上传
本文主要讲解 手机浏览器 如何拍照 为什么会有这个需求 最近做一个项目要用到拍照然后上传照片,但是网页拍照一般都是用Flash做的,而我们主要是H5页面,如果在微信里面有权限就可以通过JSSDK调起摄 ...
随机推荐
- Linux的进程优先级-邹立巍
http://liwei.life/2016/04/07/linux%E7%9A%84%E8%BF%9B%E7%A8%8B%E4%BC%98%E5%85%88%E7%BA%A7/
- spring 读取properties的两种方法
一:直接使用context命名空间 <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi= ...
- ajax提交富文本,内容被截断,解决方法及思路
问题描述: 使用百度的UEditor富文本插件用于前端富文本编辑,后端使用jsp,提交普通文本没有问题,后来发现在提交某些指定文本时,数据查回的数据出现不完整现象:第一件事就是想到“垃圾编辑器”
- Codeforces-Div312
题意:给你n个数,进行*2,/2操作,求解最小操作次数能使所有数相同. 思路:因为数值在100000以内,直接枚举过去,对读入的每一个数,模拟操作,用数组s来存放累计操作步数,数组flag用来标记确 ...
- c - static 变量
static变量和普通的局部变量不同,位于数据区中,在函数的外部初始化. ref: http://www.cnblogs.com/hustcat/archive/2009/06/30/1513755. ...
- SystemConfig.getPropertyValue("test");配置文件已经加了test=abc,但是取得时候空字符串
1.定位tomcat中System.properties是否配置了,发现配置了 2.定位myeclipse中修改的tomcat是不是自己配置的tomcat.发现是 3.定位如下位置配置是否读取我先在用 ...
- birt报表中使用多个数据集。
这个问题困扰了几天,也没搜到答案,由于工作需要,创建了两个数据集和两个表格,第一个数据集和表格之间没有任何问题.但是第二个数据集拖过去就显示不可用,除非拖到表格外面,当然也就没用了.一朋友说拖一个网格 ...
- iOS 中的传值方式
一. 属性传值 将A页面所拥有的信息通过属性传递到B页面使用 很常用的传值,也很方便,但是要拿到类的属性.例如: B页面定义了一个naviTitle属性,在A页面中直接通过属性赋值将A页面中的值传 ...
- iOS中的设计模式
一. MVC MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,用一种业务逻辑.数据.界面显示分离 ...
- Visual Studio 2010 单元测试目录
单元测试的重要性这里我就不多说了,以前大家一直使用NUnit来进行单元测试,其实早在Visual Studio 2005里面,微软就已经集成了一个叫Test的专门测试插件,经过几年的发展,这个工具现在 ...