初探HTML5.x新特性《dialog》标签

简介:

maxresdefault
HTML5.2加入了一个新的元素dialog,表示一个对话框或其他交互式组件,书写的时候不能省略结束标签。API很简单用起来也非常顺手。

Usage

<dialog open>
<p>老王又有时间可以陪女朋友看电影了</p>
</dialog>

Attributes

此标签包含所有全局属性,除了tabIndex

open

该open属性意味着该对话框是可见的。没有它,这个对话框就会隐藏起来,直到你使用JavaScript来显示它。添加任何样式之前,对话框呈现如下默认样式:
image
默认水平居中,宽高适配文字内容
JavaScript有几个方法和属性可以使dialog 元素容易处理。你可能最需要的三种方法是showModal()show()close()

const modal = document.querySelector('dialog');

modal.showModal();

modal.close();
  • showModal()会添加open属性即打开对话框。
  • show()和showModal一样打开对话框,但是有区别在于show方法的打开的模态框是没有背景遮罩的。showModal的方式打开会有一个透明的遮罩层,且这个遮罩层可以通过::backdrop设置样式的。
  • close()则会删除open属性即隐藏,close是可以传参的像这样:modal.close('some return value')。传入的值可以通过modal.returnValue获取。

当然还有可以用的事件close。

  • close: 当modal关闭的时候触发
  • cancel: 当按下ESC关闭模态框的时候触发
// display returnValue
modal.addEventListener('close', () => {
  returnSpan.innerHTML = modal.returnValue;
});
// esc
modal.addEventListener('cancel', () => {
  // something
});

notes:

通过::backdrop伪元素可以为背景遮罩设置样式

dialog::backdrop{
  background-color: rgba(0, 0, 0, 0.4);
}

可以监听dialog的click事件,做到点击背景遮罩就能关闭模态框(当然这个可能不是完美的玩法):

modal.addEventListener('click', (event) => {
  if (event.target === modal) {
    modal.close('cancelled');
  }
});

Browser compatibility

目前,PC端只有Chrome,Opera支持,其他的厂家也应该会很快支持。不过也不用担心,可以通过dialog-polyfill(https://github.com/GoogleChrome/dialog-polyfill) 来兼容到IE9+

Polyfill

安装的方式可以通过npm也可以通过常规的script标签来引入。当使用polyfill的时候,每个对话框都需要初始化一次。

dialogPolyfill.registerDialog(modal);

在低版本的浏览器是不支持伪元素的,polyfill会添加一个新的元素来充当backdrop。样式上得再加上:

dialog + .backdrop {
  background-color: rgba(0, 0, 0, 0.4);
}

完整的demo在这里(https://codepen.io/keithjgrant/pen/eyMMVL?editors=0101

目录
相关文章
|
21天前
HTML_表单标签
HTML_表单标签
16 0
|
8天前
|
存储 前端开发 JavaScript
【Web 前端】如何找到所有 HTML select 标签的选中项?
【5月更文挑战第2天】【Web 前端】如何找到所有 HTML select 标签的选中项?
|
10天前
|
编解码 移动开发 前端开发
【专栏:HTML与CSS移动端开发篇】使用Viewport Meta标签优化移动端显示
【4月更文挑战第30天】本文介绍了HTML的Viewport Meta标签在移动端网页优化中的作用。Viewport Meta标签定义了视口属性,如宽度、高度、初始缩放等,解决移动设备因屏幕尺寸差异导致的显示问题。主要属性包括width(常用device-width)、initial-scale、maximum-scale、minimum-scale和user-scalable。
|
10天前
|
移动开发 前端开发 开发者
【专栏:HTML进阶篇】网页结构与语义化标签进阶
【4月更文挑战第30天】提升网页结构清晰度和无障碍访问性,有利于SEO。这些标签为屏幕阅读器提供额外上下文,简化CSS样式设计,避免无意义的&lt;div&gt;和&lt;span&gt;。正确使用语义化标签是现代网页开发的关键,能创造更优质、易访问和优化的Web体验。
|
10天前
|
移动开发 搜索推荐 JavaScript
【专栏:HTML 进阶篇】HTML5 新特性探索:视频、音频与画布
【4月更文挑战第30天】HTML5的视频、音频和画布元素为网页开发注入新活力。视频和音频元素提供跨平台兼容的播放体验,支持自适应和交互控制;画布则允许动态图形和动画创作。在线视频网站、音乐播放器和游戏开发广泛应用这些特性。尽管面临版权和性能挑战,HTML5持续发展,为网页创新带来更多可能。拥抱这些新特性,创造更丰富的网页世界!
|
13天前
|
前端开发 数据安全/隐私保护
Day-1 HTML基本标签和CSS常用样式
Day-1 HTML基本标签和CSS常用样式
|
21天前
|
前端开发 容器
HTML_块级标签
HTML_块级标签
12 0
|
21天前
HTML_行内标签
HTML_行内标签
13 0
|
22天前
|
前端开发 JavaScript 开发者
html标签的样式
【4月更文挑战第19天】html标签的样式
14 2
|
22天前
|
JavaScript 前端开发 SEO
html标签
【4月更文挑战第19天】html标签
21 1