使用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 相关文章推荐
判断JavaScript对象是否可用的最正确方法分析
Oct 03 Javascript
JavaScript 创建对象
Jul 17 Javascript
javascipt基础内容--需要注意的细节
Apr 10 Javascript
jquery二级导航内容均分的原理及实现
Aug 13 Javascript
js中自定义方法实现停留几秒sleep
Jul 11 Javascript
js实现iPhone界面风格的单选框和复选框按钮实例
Aug 18 Javascript
javascript自动恢复文本框点击清除后的默认文本
Jan 12 Javascript
JS判断键盘是否按的回车键并触发指定按钮点击操作的方法
Feb 13 Javascript
jQuery的$.extend 浅拷贝与深拷贝
Mar 08 Javascript
详解Vue如何支持JSX语法
Nov 10 Javascript
javascript用rem来做响应式开发
Jan 13 Javascript
微信小程序如何使用canvas二维码保存至手机相册
Jul 15 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
php计算数组相同值出现次数的代码(array_count_values)
2015/01/20 PHP
PHP中使用imagick生成PSD文件缩略图教程
2015/01/26 PHP
详解js异步文件加载器
2016/01/24 PHP
纯CSS3实现质感细腻丝滑按钮
2021/03/09 HTML / CSS
ExtJS的FieldSet的column列布局
2009/11/20 Javascript
使用js判断控件是否获得焦点
2014/01/03 Javascript
jQuery经过一段时间自动隐藏指定元素的方法
2015/03/17 Javascript
JS实现的图片预览插件与用法示例【不上传图片】
2016/11/25 Javascript
javascript滚轮事件基础实例讲解(37)
2017/02/14 Javascript
数组Array的排序sort方法
2017/02/17 Javascript
vue.js中引入vuex储存接口数据及调用的详细流程
2017/12/14 Javascript
详解Vue.js中.native修饰符
2018/04/24 Javascript
微信小程序自定义tab实现多层tab嵌套功能
2018/06/15 Javascript
详解Angularjs 自定义指令中的数据绑定
2018/07/19 Javascript
[38:39]KG vs Mineski 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
Python中random模块用法实例分析
2015/05/19 Python
python 读取摄像头数据并保存的实例
2018/08/03 Python
python2和python3的输入和输出区别介绍
2018/11/20 Python
Django REST框架创建一个简单的Api实例讲解
2019/11/05 Python
Python找出列表中出现次数最多的元素三种方式
2020/02/24 Python
python 深度学习中的4种激活函数
2020/09/18 Python
快速实现一个简单的canvas迷宫游戏的示例
2018/07/04 HTML / CSS
大学生毕业自我鉴定范文
2013/11/03 职场文书
幼师求职自荐信
2014/05/31 职场文书
安全生产一岗双责责任书
2014/07/28 职场文书
以幸福为主题的活动方案
2014/08/22 职场文书
纪念九一八事变演讲稿:忘记意味着背叛
2014/09/14 职场文书
2015年清明节演讲稿范文
2015/03/17 职场文书
法律进社区活动总结
2015/05/07 职场文书
交通事故调解协议书
2015/05/20 职场文书
2015中学教师个人工作总结
2015/07/22 职场文书
高二数学教学反思
2016/02/18 职场文书
python文件目录操作之os模块
2021/05/08 Python
vue项目中的支付功能实现(微信支付和支付宝支付)
2022/02/18 Vue.js
国产动画《万圣街》日语配音版制作决定!
2022/03/20 国漫
GPU服务器的多用户配置方法
2022/07/07 Servers