HTML – Native Dialog Modal
前言
之前介绍 Native Form 的时候有提及过 method="dialog", 但由于它太新了, 所以没去研究. 这篇就介绍一下.
Dialog 也好 Modal 也好, 都有人叫, 我的理解是 Modal 更抽象一点, Dialog 按 Material Design, 应该是要有 action 的才算. Modal 只要是 popup 的都算.
但这篇我们配合 HTML 叫它 dialog 吧.
参考:
Youtube – Use dialog for the easiest way to make a popup modal
搭场景
<button id="js-open-dialog-btn">Show Dialog</button>
<dialog class="dialog" id="js-dialog">
<h1>title</h1>
<p>
Lorem ipsum, dolor sit amet consectetur adipisicing elit. Nihil itaque deleniti eligendi
possimus perferendis necessitatibus officiis minus libero? Sapiente nisi dolores eius dicta
</p>
<button id="js-close-dialog-btn">Close Dialog</button>
</dialog>
一个 show dialog button
一个 dialog, 里面有内容和 close button
效果

dialog 会自动被隐藏起来. 看不见的.
show dialog
const openDialogBtn = document.querySelector<HTMLButtonElement>('#js-open-dialog-btn')!;
const dialog = document.querySelector<HTMLDialogElement>('#js-dialog')!;
openDialogBtn.addEventListener('click', () => {
dialog.showModal();
});
找到 dialog element 调用 showModal 它就会出来了.
HTMLDialogElement
typescript 目前没用这个类型, 所以需要自己写. 可以参考: MDN – HTMLDialogElement
interface HTMLDialogElement extends Element {
open: boolean;
returnValue: string;
show: () => void;
showModal: () => void;
close: (returnValue?: string) => void;
}
open 是看当前是 show 还是 hide, 这个命名不太好的, 应该用 opened 名词而不是动词.
show 是把 <dialog> show 出来, 但是它不会 popup 而在它原来的位置.
showModal 才是像 popup 那样 show 在中间
close 是关闭, 同时可以 passing 一个 string value 作为 return value
returnValue 是在 close 的时候 set 进去的, 默认是 empty string
default style

1. backdrop 是灰色
2. dialog 有默认的 border-width
custom style
.dialog {
&::backdrop {
background-color: rgb(255 0 0 / 0.5);
}
border-width: 0;
max-width: 50%;
}
::backdrop 可以选择到 backdrop 修改颜色
效果

scroll 逻辑

当 dialog 开启的时候 body 依然是可以 scroll 的哦.
backdrop & close 逻辑
keyboard Esc 会关闭 dialog, backdrop 的区域也属于 dialog 内. 它是无法监听到的
参考: stackoverflow – Dismiss html dialog element by clicking the backdrop
除了 Esc 只有 dialog 内自己做 button 通过 JS 才能 close dialog.
closeDialogBtn.addEventListener('click', () => {
dialog.close('some return value');
});
调用 close 的时候可以传入 return value, 通过 dialog.returnValue 获取.
event
dialog 有 2 个 event 可以监听.
1. cancel
2. close
cancel 只有在 Esc 的时候会触发
Esc, .close 都会触发 close event.
所以 Esc 会触发 cancel 然后再触发 close event.
form method="dialog"
<dialog class="dialog" id="js-dialog">
<form method="dialog">
<input name="firstName" value="Derrick" />
<button type="submit" value="value123">submit</button>
</form>
</dialog>
dialog 里面的 form method="dialog" 在 submit 时会 close dialog.
button value 会被 set to return value 里.

HTML – Native Dialog Modal的更多相关文章
- [转]jQuery UI Dialog Modal Popup Yes No Confirm example in ASP.Net
本文转自:http://www.aspsnippets.com/Articles/jQuery-UI-Dialog-Modal-Popup-Yes-No-Confirm-example-in-ASPN ...
- iframe中的jquery ui modal dialog 覆盖父窗口
在iframe中 使用jquery ui dialog,弹出后可以覆盖父窗体 ///iframe中的jquery ui modal dialog 覆盖父窗口 function openDialog() ...
- wxPython Modal Dialog 模式对话框
<wxPython in Action>chap 9 笔记 1. Modal Dialog(模式对话框) A modal dialog blocks other widgets from ...
- wx.Dialog
wx.Dialog A dialog box is a window with a title bar and sometimes a system menu, which can be moved ...
- 一起来看 HTML 5.2 中新的原生元素 <dialog>
不到一个月前,HTML 5.2 正式成为 W3C 的推荐标准(REC),其中,推出了一个新的原生模态对话框元素 <dialog>,乍一看,可能感觉它就是一个新增的元素,然而,作者最近在玩的 ...
- JqueryUI Dialog 加载动态页 部分页
问题:使用JqueryUIDialog 加载部分页,可以弹出对话框,但是在操作页面上的按钮是提示"dialog"找不到,思路是,先取到部分页加载到要dialog的Div上,在dia ...
- JQuery-UI Dialog下使用服务器端按钮失效
目标:点按钮弹出div层,选择数据后自动隐藏div,将所选数据赋值到窗体. <div id="divWinPop"> //里面是要实现弹出框的代码,包括翻页.查找等. ...
- jQuery UI 实例 - 对话框(Dialog)(zhuan)
http://www.runoob.com/jqueryui/example-dialog.html ************************************************* ...
- Jquery UI dialog 详解 (中文)
转载▼ 1 属性 1.11 autoOpen ,这个属性为true的时候dialog被调用的时候自动打开dialog窗口.当属性为false的时候,一开始隐藏窗口,知道.dialog("op ...
- jQuery.dialog
本篇文章主要是对JQUERY中dialog的用法进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助 今天用到了客户端的对话框,把 jQuery UI 中的对话框学习了一下. 准备 jQ ...
随机推荐
- 2024-07-17:用go语言,给定一个整数数组nums, 我们可以重复执行以下操作: 选择数组中的前两个元素并删除它们, 每次操作得到的分数是被删除元素的和。 在保持所有操作的分数相同的前提下,
2024-07-17:用go语言,给定一个整数数组nums, 我们可以重复执行以下操作: 选择数组中的前两个元素并删除它们, 每次操作得到的分数是被删除元素的和. 在保持所有操作的分数相同的前提下, ...
- ABC361-D题解
背景 保佑LC能来一中. 题意 给你一个长度为 \(n\) 的初始字符串和目标字符串,都由 W 和 B 两种字符构成. 现在初始字符串末尾接有两个空格字符,每次你可以在该字符串中选出连续两个非空格字符 ...
- hbuilderx+香蕉云编生成ios证书和上架教程
现在很多公司都使用uniapp作为底层框架来开发app应用,而uniapp的开发工具hbuilderx云打包的时候,需要证书和证书profile文件. 假如是ios应用,则还需要上架到appstore ...
- layui下拉框的数据如何直接从数据库提取(动态赋值)
代码说明部分 第一步:先把layui官方给的模板粘到自己的前端注:下面的代码是我直接从layui官网粘过来的 <div class="layui-form-item"> ...
- Jmeter函数助手13-threadGroupName
threadGroupName函数获取当前线程组的名称.该函数没有参数,直接引用即可. 1. 返回当前线程组的名称
- .Net 6.0 Web API 项目生成镜像并上传到私有仓库 Harbor
〇.前言 本文首先简单介绍了 Dockerfile 内容和常用命令: 然后是在 Windows 环境 Docker desktop 的安装和配置: 最后创建了 Web API 示例项目,并简单说明了从 ...
- 【SqlServer】01 概念及笔记
视频地址: https://www.bilibili.com/video/BV1qW411y7Bq 一.什么是数据库? 狭义定义: 数据仓库 广义定义: 对数据进行存储和操作的软件,和数据本身合并称为 ...
- 如何理解自动驾驶的分级:L0、L1、L2、L3、L4、L5
相关: https://baijiahao.baidu.com/s?id=1792281493472406727&wfr=spider&for=pc L0,就是完全没有自动驾驶技术的车 ...
- GPG公钥的删除与注销
参考: 如何在 Gitee 上使用 GPG 我们通过在本地主机保存GPG私钥,然后在Gitee或Github上保存GPG公钥的方式来实现对git的commit和tag操作的签名. 当GPG公私秘钥对作 ...
- css手撕奥运五环
巴黎奥运会正如火如荼地进行,本文来使用 CSS 来画一个奥运五环.奥运五环是相互连接的,因此在视觉上会产生重叠效果,这也是实现五环最有挑战性的部分.接下来,将利用 CSS 的伪元素,巧妙地实现环环相扣 ...