当前位置: 首页 > news >正文

2 html5 浏览器已经支持的新API

HTML5规范下很多API浏览器都已经支持,这里我们列举几个很常用的浏览器支持的API:

1 tab页之间通信:

BroadcastChannel(channelName);

可用于多个不同浏览器tab页之间通信。实例化的时候Channel名称必须相同。

const broadcastChannel = new BroadcastChannel('myChannel')broadcastChannel.postMessage('Hello from tab 1');

使用postMessage 发送消息,并在另一个窗口监听消息

broadcastChannel.onmessage = function(e) {

console.log('Received:', e.data);

};

这里的postMessage,和 onMessage 事件,你可能在ifram和父窗体通信时你也用过。

2 浏览器全屏:

requestFullscreen()

img, video, div元素等加上这个方法就可以实现全屏,使用document.exitFullscreen();退出全屏。

3 屏幕分享:

navigator.mediaDevices.getDisplayMedia() 这个就是将当前指定的屏幕分享出去。我们如下当代是将截取内容放在播放器中播放。

 const stream = await navigator.mediaDevices.getDisplayMedia({video: true,});videoElement.srcObject = stream;

当然看到这个mediaDevices,这个对象目前可以使用的还有:

1 获取摄像头

navigator.mediaDevices.getUserMedia()

2 获取设备信息:

 navigator.mediaDevices.enumerateDevices()

4 网络状态

navigator.onLine

以及给window增加了两个事件

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

5 requestAnimationFrame实现浏览器绘制帧时的调用

这个api可用来替代使用interval回调时动画都问题。当然vue底层也用了这个新的api.

var ball = document.getElementById("ball");var pos = 0;function moveBall() {if (pos == 350) {return; // 如果到达指定位置则停止动画} else {pos += 1;ball.style.top = pos + "px";ball.style.left = pos + "px";window.requestAnimationFrame(moveBall); // 继续下一帧动画}}// 启动动画window.requestAnimationFrame(moveBall);

6 Clipboard 粘贴板对象,当然这对象功能也很强大。

通过writeText写入内容,通过 readText读取复制内容。

navigator.clipboard.writeText(text).then(function() {console.log("复制成功!");}, function() {console.log("复制失败!");});

7 MutationObserver DOM变化监听

说到这个Api,你可能之前使用过insertBefore()甚至自己封装了insertAfter(),但是更为详细的监听,html5 浏览器已经实现了MutationObserver,利用这个对象可以实现更详细的dom变化的监听。

 // Observer需要一个用于监听的目标DOMconst targetNode = document.getElementById("app");//用于确定mutation监听变化的范围const config = {attributes: true, // 监听目标节点的属性变化,例如id,class等属性childList: true, // 除目标节点外还要监听目标节点的直接子节点subtree: true, // subtree的范围大于childList,还包括子节点childrencharacterData: true, // 监听TextNode需要额外配置,默认TextNode变化不会触发callback};// 当观察到变动时执行的回调函数,mutationsList包含本次变更的信息const callback = function (mutationsList, observer) {console.log(mutationsList);};const observer = new MutationObserver(callback);observer.observe(targetNode, config);

8 scrollIntoView 快速滚动到指定的元素位置。

这是一个dom新增的方法,可以配合一个behavior: "smooth",block: "start"即可实现平滑滚动。

 document.body.scrollIntoView({behavior: "smooth",block: "start",});

9 Notification通知消息

 var notification = new Notification("通知标题", {body: "通知内容",icon: "notif-icon.png",});

等等,还有一些其他的,比如formData,fileRender等等这些大家平时用的比较多的,我这里就不再举例。还有canvas这种,svg等这些后面我会单独拿出来讲。 

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 腾讯云技术深度解析:AI代码助手与微服务架构的实践应用
  • 服务器数据恢复—如何应对双循环RAID5阵列的数据丢失问题?
  • 【初出江湖】分布式之什么是分布式存储?
  • P-Tuning v2:一种普遍有效的提示调整方法
  • 三分钟搭建线上RAG应用,实现定制化的知识库问答
  • 解锁企业微信营销新纪元:智驭未来,让每一次触达都精准高效!
  • Tensorflow实现深度学习8:猫狗识别
  • Qt Dialog退出事件
  • AIGC时代从新手到高手:B端竞品分析实战案例与技巧分享
  • 华为Huawei路由器交换机SSH配置
  • 设计模式-结构型模式-组合模式
  • 学习WebGl基础知识(二)
  • Docker原理及实例
  • 使用docker部署project-exam-system(项目)
  • QT connect的使用
  • [rust! #004] [译] Rust 的内置 Traits, 使用场景, 方式, 和原因
  • 《深入 React 技术栈》
  • gulp 教程
  • Java读取Properties文件的六种方法
  • Objective-C 中关联引用的概念
  • Octave 入门
  • Storybook 5.0正式发布:有史以来变化最大的版本\n
  • vue 个人积累(使用工具,组件)
  • vue:响应原理
  • web标准化(下)
  • 大主子表关联的性能优化方法
  • 对话:中国为什么有前途/ 写给中国的经济学
  • 前嗅ForeSpider教程:创建模板
  • 用mpvue开发微信小程序
  • 追踪解析 FutureTask 源码
  • FaaS 的简单实践
  • 扩展资源服务器解决oauth2 性能瓶颈
  • # Pytorch 中可以直接调用的Loss Functions总结:
  • # SpringBoot 如何让指定的Bean先加载
  • #include<初见C语言之指针(5)>
  • #我与虚拟机的故事#连载20:周志明虚拟机第 3 版:到底值不值得买?
  • $jQuery 重写Alert样式方法
  • (ZT)出版业改革:该死的死,该生的生
  • (超详细)2-YOLOV5改进-添加SimAM注意力机制
  • (附源码)ssm码农论坛 毕业设计 231126
  • (过滤器)Filter和(监听器)listener
  • (每日持续更新)信息系统项目管理(第四版)(高级项目管理)考试重点整理 第13章 项目资源管理(七)
  • (四)软件性能测试
  • .net framework 4.0中如何 输出 form 的name属性。
  • .NET 中使用 TaskCompletionSource 作为线程同步互斥或异步操作的事件
  • .NET/C# 使用 ConditionalWeakTable 附加字段(CLR 版本的附加属性,也可用用来当作弱引用字典 WeakDictionary)
  • .NET开发者必备的11款免费工具
  • .pop ----remove 删除
  • .w文件怎么转成html文件,使用pandoc进行Word与Markdown文件转化
  • 。。。。。
  • @ConfigurationProperties注解对数据的自动封装
  • @DataRedisTest测试redis从未如此丝滑
  • [ 数据结构 - C++] AVL树原理及实现
  • [bzoj2957]楼房重建
  • [C# WPF] 如何给控件添加边框(Border)?