使用React手写一个对话框或模态框的方法示例


Posted in Javascript onApril 25, 2019

打算用React写对话框已经很长一段时间,现在是时候兑现承诺了。实际上,写起来相当简单。

核心在于使用React的接口React.createPortal(element, domContainer)。该接口将element渲染后的DOM节点嵌入domContainer(通常是document.body),并保证只嵌入一次。

所以,我们可以这样写一个对话框或模态框:

function Dialog() {
  return React.createPortal( <div>Dialog contents</div>, document.body )
}

一个新的div会出现在body内部:

使用React手写一个对话框或模态框的方法示例

一个完整DEMO:

使用React手写一个对话框或模态框的方法示例

点击运行DEMO

class Modal extends React.Component {
 render() {
  const {
   visible,
   onClose
  } = this.props
  return visible && ReactDOM.createPortal(<StyledModalRoot>
   <div className="box">
    Content
    <br/>
    <button onClick={onClose}>Close</button>
   </div>
  </StyledModalRoot>, document.body)
 }
}

class App extends React.Component {
 state = {
  visibleModal: false
 }
 showModal = () => this.setState( { visibleModal: true } )
 handleCloseModal = () => this.setState( { visibleModal: false } )
 render() {
  const { visibleModal } = this.state
  return <div style={{padding: '20px'}}>
  <button onClick={ this.showModal }>Show Modal</button>
  <Modal visible={visibleModal} onClose={ this.handleCloseModal } />
 </div>
 }
}

const StyledModalRoot = styled.div`
 position: fixed;
 z-index: 1001;
 left: 0;
 top: 0;
 display: grid;
 place-items: center;
 width: 100%;
 height: 100%;
 background: rgba( 0, 0, 0, 0.2 );

 >.box {
  position: relative;
  display: grid;
  place-items: center;
  width: 80%;
  height: 80%;
  background: white;
  border-radius: 10px;
  box-shadow: 0px 3px 5px -1px rgba(0,0,0,0.2), 0px 5px 8px 0px rgba(0,0,0,0.14), 0px 1px 14px 0px rgba(0,0,0,0.12);
 }
`

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery 中关于CSS操作部分使用说明
Jun 10 Javascript
用Javascript数组处理多个字符串的连接问题
Aug 20 Javascript
javascript判断ie浏览器6/7版本加载不同样式表的实现代码
Dec 26 Javascript
JavaScript高级程序设计(第3版)学习笔记9 js函数(下)
Oct 11 Javascript
javascript两种function的定义介绍及区别说明
May 02 Javascript
js实现缓冲运动效果的方法
Apr 10 Javascript
JQ技术实现注册页面带有校验密码强度
Jul 27 Javascript
jQuery实现的购物车物品数量加减功能代码
Nov 16 Javascript
详解html-webpack-plugin插件(用法总结)
Sep 12 Javascript
element-ui的回调函数Events的用法详解
Oct 16 Javascript
微信小程序使用wxParse解析html的方法示例
Jan 17 Javascript
js实现随机点名
Jan 19 Javascript
elementUI Tree 树形控件的官方使用文档
Apr 25 #Javascript
微信小程序Flex布局用法深入浅出分析
Apr 25 #Javascript
详解如何实现Element树形控件Tree在懒加载模式下的动态更新
Apr 25 #Javascript
小程序开发踩坑:页面窗口定位(相对于浏览器定位)(推荐)
Apr 25 #Javascript
微信小程序整合使用富文本编辑器的方法详解
Apr 25 #Javascript
微信小程序实现的五星评价功能示例
Apr 25 #Javascript
微信小程序实现单列下拉菜单效果
Apr 25 #Javascript
You might like
一个用于mysql的数据库抽象层函数库
2006/10/09 PHP
Mysql数据库操作类( 1127版,提供源码下载 )
2010/12/02 PHP
PHP编程风格规范分享
2014/01/15 PHP
Php无限级栏目分类读取的实现代码
2014/02/19 PHP
php简单压缩css样式示例
2016/09/22 PHP
thinkPHP5.0框架环境变量配置方法
2017/03/17 PHP
PHP实现蛇形矩阵,回环矩阵及数字螺旋矩阵的方法分析
2017/05/29 PHP
js实现简单模态窗口,背景灰显
2008/11/14 Javascript
javascript下判断一个对象是否具有指定名称的属性的的代码
2010/01/11 Javascript
jQuery 打造动态渐变按钮 详细图文教程
2010/04/25 Javascript
Jquery css函数用法(判断标签是否拥有某属性)
2011/05/28 Javascript
jquery ajax跨域解决方法(json方式)
2014/02/04 Javascript
javascript实现画不相交的圆
2015/04/07 Javascript
js实现刷新iframe的方法汇总
2015/04/27 Javascript
javascript弹出窗口实现代码
2015/11/12 Javascript
EasyUI中的dataGrid的行内编辑
2017/06/22 Javascript
JS一个简单的注册页面实例
2017/09/05 Javascript
浅谈Vue服务端渲染框架Nuxt的那些事
2018/12/21 Javascript
详解Vue路由自动注入实践
2019/04/17 Javascript
详解JavaScript执行模型
2020/11/16 Javascript
在实例中重学JavaScript事件循环
2020/12/03 Javascript
深入理解javascript中的this
2021/02/08 Javascript
[53:43]VP vs NewBee Supermajor 胜者组 BO3 第三场 6.5
2018/06/06 DOTA
[01:10:02]IG vs Winstrike 2018国际邀请赛小组赛BO2 第一场 8.19
2018/08/21 DOTA
详解Python中DOM方法的动态性
2015/04/11 Python
简单的Python的curses库使用教程
2015/04/11 Python
使用FastCGI部署Python的Django应用的教程
2015/07/22 Python
Python for Informatics 第11章之正则表达式(二)
2016/04/21 Python
Python内建模块struct实例详解
2018/02/02 Python
python pandas时序处理相关功能详解
2019/07/03 Python
Python基于pandas绘制散点图矩阵代码实例
2020/06/04 Python
Python 列表推导式需要注意的地方
2020/10/23 Python
termux中matplotlib无法显示中文问题的解决方法
2021/01/11 Python
法国大使拉杆箱官网:DELSEY Paris
2018/03/20 全球购物
党建示范点实施方案
2014/03/12 职场文书
2015年干部教育培训工作总结
2015/05/15 职场文书