H5新增API

1. Location对象

location 对象是 window 对象的一部分,可通过window.location属性对其进行访问。

属性

名称释义
origin返回页面来源的域(当前协议 + 主机名+端口号)
host返回一个URL的主机名和端口
hostname返回URL的主机名
port返回一个URL服务器使用的端口号
pathname返回的URL路径名。
protocol返回一个URL协议
href返回完整的URL
hash返回从井号 (#) 开始的 URL(锚)
search返回从问号 (?) 开始的 URL(查询部分)

方法

属性描述
assign()加载新的文档。跟href一样,可以跳转页面
replace()用新的文档替换当前文档。替换当前页面,不记录历史,不可以后退
reload()重新加载当前文档。

 

2. Navigator对象

navigator 对象是包含有关浏览器的信息。

window.navigator 接口表示用户代理的状态和标识。

navigator 对象包含有关浏览器的信息,它有很多属性,我们最常用的是 userAgent,该属性可以返回由客户机发送服务器的 user-agent 头部的值。

下面前端代码可以判断用户那个终端打开页面,实现跳转。

if((navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i))) {
    window.location.href = "";     //跳转到手机端的页面
 } else {
    window.location.href = "";     //跳转到pc端的页面
 }

扩展阅读:

浏览器的User-Agent

浏览器的小故事

2.1 通过第三方API获取

HTML5中提供了一个Navigator.geolocation可以获取地理位置,但是由于兼容性太差,所以在这我们不过多给同学讲解。

在现实开发中,通过调用第三方API(如百度地图)来实现地理定位信息,这些API都是基于用户当前位置的,并将用位置位置(经/纬度)当做参数传递,就可以实现相应的功能。

百度地图开放平台 | 百度地图API SDK | 地图开发 百度地图api,调用百度API进行地图设置

2.2 Navigator.onLine网络状态

onLine 属性是一个只读的布尔值,声明了系统是否处于脱机模式,如果系统属于脱机状态,则返回 false,否则返回 true。

if (navigator.onLine) {
  alert('online')
} else {
  alert('offline');
}

HTML5 也给我们提供了2个事件 online 和 offline,给window绑定事件--检测网络开始状态

window.ononline = function() {
    console.log('你的浏览器在线工作');
};
window.onoffline = function() {
    console.log('你的浏览器离线工作');
}

3. History对象

History 对象包含用户(在浏览器窗口中)访问过的 URL。

History 对象是 window 对象的一部分,可通过 window.history 属性对其进行访问。

属性

属性描述
length返回浏览器历史列表中的 URL 数量。
state返回浏览器在当前 URL 下的状态信息,如果没有调用过 pushState() 或 replaceState() 方法,则返回默认值 null。

方法

方法描述
back()加载 history 列表中的上一个 URL。
forward()加载 history 列表中的下一个 URL。
go()加载 history 列表中的某个具体页面。其中go()参数为正值前进,参数为负值后退,为0刷新页面
pushState()用于在历史中添加一条记录。
replaceState()用来修改 History 对象的当前记录,其他都与pushState()方法一模一样。

3.1 History.back()、History.forward()、History.go()

这三个方法用于在浏览历史之中切换。

  • History.back():切换到上一个网址,等同于点击浏览器的后退键。对于第一个访问的网址,该方法无效果。

  • History.forward():切换到下一个网址,等同于点击浏览器的前进键。对于最后一个访问的网址,该方法无效果。

  • History.go():接受一个整数作为参数,以当前网址为基准,移动到参数指定的网址,比如go(1)相当于forward(),go(-1)相当于back()。如果参数超过实际存在的网址范围,该方法无效果;如果不指定参数,默认参数为0,相当于刷新当前页面。

注意,切换到以前访问过的页面时,页面通常是从浏览器缓存之中加载,而不是重新要求服务器发送新的网页。

3.2 History.pushState()

History.pushState()方法是html5中新增无刷新修改URL,用于在历史中添加一条记录。

window.history.pushState(state, title, url)
//读出状态对象
console.log(history.state)

该方法接受三个参数,依次为:

  • state:一个与添加的记录相关联的状态对象,浏览器会将这个对象序列化以后保留在本地,重新载入这个页面的时候,可以拿到这个对象。如果不需要这个对象,此处可以填null。

  • title:新页面的标题。不需要时可以填空字符串。

  • url:新的网址,必须与当前页面处在同一个域。浏览器的地址栏将显示这个网址。

3.3 History.replaceState()

History.replaceState()方法用来修改 History 对象的当前记录,其他都与pushState()方法一模一样。 假定当前网页是example.com/example.html。

history.pushState({page: 1}, 'title 1', '?page=1')
// URL 显示为 http://example.com/example.html?page=1

总结:

相同点:(1)共同的参数,(2)不会刷新页面只是修改或喜欢历史记录。

不同点:pushState会在history中添加一个新的记录( replace不会添加新的history记录,而是替换当前的url。

4. Files对象(文件读取)

怎么上传文件显示到页面? 或者 上传完毕图片显示缩略图到页面上。。。

通过FileReader对象我们可以读取本地存储的文件,使用 File 对象来指定所要读取的文件或数据。其中File对象可以是来自用户在一个元素上选择文件后返回的FileList 对象。

4.1 Files对象

由于HTML5中我们可以通过为表单元素添加multiple属性,因此我们通过<input>上传文件后得到的是一个Files对象(伪数组形式)。

4.2 FileReader对象

HTML5新增内建对象,可以读取本地文件内容。

var reader = new FileReader(); 可以实例化一个对象

实例方法

1、reader.readAsDataURL():DataURL形式读取文件

2、reader.readAsText():读取文件根据特殊的编码格式转化为内容(字符串形式)

事件监听

onload 当文读取完成时调用

属性

reader.result 文件读取结果

参考资料

FileReader - Web API 接口参考 | MDN

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是一个简单的 H5 入门教程,希望对你有所帮助: 1. HTML5 是什么? HTML5 是 HyperText Markup Language 的第五个版本,是 web 开发的一种核心技术,它提供了一系列新的标签、功能和 API,可以让网页更加丰富、多样化。 2. HTML5 新增了哪些标签? HTML5 新增了很多标签,以下是其中一些常用的标签: - header、nav、section、article、aside、footer:用于定义网页的结构。 - audio、video:用于在网页中播放音频、视频。 - canvas:用于绘制图形、动画。 - progress、meter:用于显示进度条、进度值。 - datalist、output:用于创建数据列表、输出结果。 3. 如何使用 HTML5 标签? 使用 HTML5 标签和使用其他标签一样,只需要按照标准的语法来编写就可以了。例如,使用 <header> 标签来定义网页的页眉: ```html <!DOCTYPE html> <html> <head> <title>My Webpage</title> </head> <body> <header> <h1>Welcome to my webpage!</h1> <nav> <ul> <li><a href="#">Home</a></li> <li><a href="#">About</a></li> <li><a href="#">Contact</a></li> </ul> </nav> </header> <section> <h2>About me</h2> <p>Hi, my name is John Doe and I'm a web developer.</p> </section> </body> </html> ``` 4. HTML5 的一些常用 API - Canvas API:用于绘制图形和动画。 - Web Storage API:用于在客户端存储数据。 - Web Workers API:允许在后台运行 JavaScript 代码,不会影响页面的性能。 - Geolocation API:用于获取用户的地理位置信息。 - WebRTC API:用于实现实时通信。 以上是一个简单的 H5 入门教程,希望对你有所帮助。如果你对其他方面有疑问,可以再向我提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值