对话框(别称模态框,浮层)是web项目中用于用户交互的重要部分,咱们最多见的就是js中 alert(),confirm()
,可是这个对话框的不美观,也不能自定义样式,因此在开发的过程当中,通常根据本身本身的需求造轮子或者使用第三方的。css
常见的弹出框形式:html
位置:屏幕的左上角,右上角,左下角,右下角,垂直居中等vue
大小:定宽定高,定宽不定高,不定宽不定高等react
开发中的对话框形式就是位置和大小随机组合的一种状况。ios
可是有一种状况(不定宽高的垂直居中)不易实现(可使用display:table或css3的translate或flex实现),具体可参考水平垂直居中布局css3
上面的对话框包含内容的容器,还有一个是对话框下面的遮罩层(mask),遮罩层是用户触发弹出框后,造成的一个对话框与页面主体的分割图层,它的存在能够给用户一个更明显的视觉差效果,同时也起到避免用户触发对话框后的其余没必要要的页面主体操做,从而产生更有的用户体验。git
虽然,有不少对话框的轮子供咱们选择,可是咱们面临着各类各样的问题。es6
那么,有没有一个简单的方法来作作一个对话框呢?固然有,咱们可使用HTML5的 dialog
元素。github
<dialog open> <h2> Hello world.</h2> </dialog>
很简单,咱们使用上面的代码就能够作一个弹出内容为‘Hello world.’ 的对话框。web
控制对话框的显示/隐藏也很容易,添加 open
属性表示显示,去除为隐藏。固然,咱们也能够经过DOM接口来控制 dialog
的显隐(show(), close())
对话框下面的遮罩层,咱们可使用 ::backgrop
伪元素,而它的激活,咱们须要使用 showModal()
这个DOM的API,::backgrop
的特性是它的位置在dialog之下,在任何 z-index
之上。
使用 showModal()
不只可让遮罩层显示,dialog容器也显示,因此用到 ::backdrop
的时候,能够用 showModal()
代替 show()
这个API;若是按键盘 ESC
键将关闭弹出层,固然你一可使用 close()
这个DOM API。
咱们能够设置 ::backdrop
这个图层为半透明图层,代码以下:
dialog::backdrop { background-color: rgba(0, 0, 0, 0.75); }
除了咱们常见的提示信息的弹出层外,还有一类比较使用的是带表单的弹出层。
咱们可使用HTML5的dialog元素结合form元素来作这些弹出层吗?
答:能够
咱们怎么作才能让form元素和dialog元素紧密的结合起来呢?
答:咱们只须要在dialog元素中添加 method="dialog"
这个属性便可,这样就能够将button元素的属性 value
的值传递给dialog元素。
<dialog> <form method="dialog"> <p>肯定 or 取消</p> <button type="submit" value="yes">肯定</button> <button type="submit" value="no">取消</button> </form> </dialog> <script> var dialog = document.querySelector('dialog') dialog.showModal() dialog.addEventListener('close', function(event) { console.log(dialog.returnValue) }) </script>
虽然,这是一个比较好用的HTML5,可是还存在兼容性问题,chrome和opera支持的比较好,Firefox中是实验特性,可是IE,Edge, safari支持的很差,ios不支持,Android也支持的不够好,只有Android6之后支持。具体可参考caniuse
那么,能不能让旧版本的浏览器支持HTML5的dialog呢?首先,咱们想到的是有没有一个支持dialog的polyfill,就像支持es6新特性的babel-polyfill同样,确实有这样一个开源项目a11y-dialog,它分别提供了vue和react的不一样版本。