使用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学习笔记(四) Number 数字类型
Jun 19 Javascript
jquery方法+js一般方法+js面向对象方法实现拖拽效果
Aug 30 Javascript
jquery实现表格奇数偶数行不同样式(有图为证及实现代码)
Jan 23 Javascript
使用JS读秒使用示例
Sep 21 Javascript
编程语言JavaScript简介
Oct 16 Javascript
JavaScript实现打开链接页面的方式汇总
Jun 02 Javascript
javascript实现抽奖程序的简单实例
Jun 07 Javascript
AngularJS ng-template寄宿方式用法分析
Nov 07 Javascript
用jquery的attr方法实现图片切换效果
Feb 05 Javascript
微信小程序实现工作时间段选择
Feb 15 Javascript
js实现通过开始结束控制的计时器
Feb 25 Javascript
Preload基础使用方法详解
Feb 03 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数字游戏 计算24算法
2012/06/10 PHP
解析curl提交GET,POST,Cookie的简单方法
2013/06/29 PHP
laravel 验证错误信息到 blade模板的方法
2019/09/29 PHP
如何在Laravel5.8中正确地应用Repository设计模式
2019/11/26 PHP
再说AutoComplete自动补全之实现原理
2011/11/05 Javascript
javascript 在firebug调试时用console.log的方法
2012/05/10 Javascript
js修改地址栏URL参数解决url参数问题
2012/12/15 Javascript
ES6新特征数字、数组、字符串
2016/10/01 Javascript
js原生代码实现轮播图的实例讲解
2017/07/28 Javascript
js实现拖拽上传图片功能
2017/08/01 Javascript
javascript将list转换成树状结构的实例
2017/09/08 Javascript
JavaScript&quot;模拟事件&quot;的注意要点详解
2019/02/13 Javascript
js 对象使用的小技巧实例分析
2019/11/08 Javascript
解决vue-cli 打包后自定义动画未执行的问题
2019/11/12 Javascript
c++生成dll使用python调用dll的方法
2014/01/20 Python
Python中join和split用法实例
2015/04/14 Python
pycharm安装和首次使用教程
2018/08/27 Python
Python中修改字符串的四种方法
2018/11/02 Python
用python脚本24小时刷浏览器的访问量方法
2018/12/07 Python
Python实现将通信达.day文件读取为DataFrame
2018/12/22 Python
Python中模块(Module)和包(Package)的区别详解
2019/08/07 Python
Python标准库json模块和pickle模块使用详解
2020/03/10 Python
Jupyter Notebook远程登录及密码设置操作
2020/04/10 Python
Python Selenium截图功能实现代码
2020/04/26 Python
Python调用C/C++的方法解析
2020/08/05 Python
CSS3属性 line-clamp控制文本行数的使用
2020/03/19 HTML / CSS
MATCHESFASHION.COM美国官网:英国奢侈品零售商
2018/10/29 全球购物
Quiksilver荷兰官方网站:冲浪和滑雪板
2019/11/16 全球购物
Nike墨西哥官网:Nike MX
2020/08/30 全球购物
SQL Server 2000数据库的文件有哪些,分别进行描述
2013/03/30 面试题
2014年教师节寄语
2014/04/03 职场文书
大学共青团员个人自我评价
2014/04/16 职场文书
2019年警察入党转正申请书最新范文
2019/09/03 职场文书
go设置多个GOPATH的方式
2021/05/05 Golang
使用CSS3实现按钮悬停闪烁动态特效代码
2021/08/30 HTML / CSS
windows11选中自动复制怎么开启? Win11自动复制所选内容的方法
2022/07/23 数码科技