React使用api的方式封裝彈窗的示例代碼
在現(xiàn)代開(kāi)發(fā)中的彈窗樣式,經(jīng)常會(huì)是底部一個(gè)叉號(hào)樣式的彈窗,但是目前組件庫(kù)中并無(wú)類似彈窗組件,所以基于蒙層組件Overlay二次開(kāi)發(fā),彈窗組件名DialogTest
<Overlay visible={props.show} closeOnOverlayClick={false}>
<div class="dialog-container">{props.children}</div>
</Overlay>
然后在到需要彈窗的地方引入該彈窗組件
<div>
<div class="top-part"></div>
<div class="main-part"></div>
<div class="bottom-part"></div>
<DialogTest></DialogTest>
</div>
但是假如彈窗組件越來(lái)越多,就會(huì)像下面這樣
<div>
<div class="top-part"></div>
<div class="main-part"></div>
<div class="bottom-part"></div>
<DialogTest1></DialogTest>
<DialogTest2></DialogTest2>
<DialogTest3></DialogTest3>
<DialogTest4></DialogTest4>
</div>
這樣看上去代碼結(jié)構(gòu)就會(huì)很亂,那怎么辦,能不能改成api的方式調(diào)用,讓代碼回歸只有基礎(chǔ)布局模塊,在涉及彈窗的地方在對(duì)應(yīng)的方法里面調(diào)用即可
import modelApi from './modelApi.ts'
const showDialog = ()=>{
modelApi.show()
}
<div>
<div class="top-part"></div>
<div class="main-part"></div>
<div class="bottom-part"></div>
</div>
import React, { useState, useEffect } from "react";
import ReactDOM from "react-dom";
import { Overlay } from "";
// 彈窗組件
const Modal = ({ visible, onClose, children }) => {
return ReactDOM.createPortal(
<Overlay visible={visible} onClick={onClose}>
<div className="modal-content">{children}</div>
</Overlay>,
document.body,
);
};
// API方法封裝
const modalAPI = {
show: (content) => {
const div = document.createElement("div");
document.body.appendChild(div);
const closeModal = () => {
ReactDOM.unmountComponentAtNode(div);
document.body.removeChild(div);
};
ReactDOM.render(
<Modal visible={true} onClose={closeModal}>
{content}
</Modal>,
div,
);
},
};
export default modalAPI;
到此這篇關(guān)于React使用api的方式封裝彈窗的示例代碼的文章就介紹到這了,更多相關(guān)React api封裝彈窗內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ReactDOM.render在react源碼中執(zhí)行原理
這篇文章主要為大家介紹了ReactDOM.render在react源碼中執(zhí)行原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
漸進(jìn)式源碼解析React更新流程驅(qū)動(dòng)
這篇文章主要為大家介紹了漸進(jìn)式源碼解析React更新流程驅(qū)動(dòng)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
React實(shí)現(xiàn)菜單欄滾動(dòng)功能
本文將會(huì)基于react實(shí)現(xiàn)滾動(dòng)菜單欄功能,點(diǎn)擊菜單,內(nèi)容區(qū)域會(huì)自動(dòng)滾動(dòng)到對(duì)應(yīng)卡片,內(nèi)容區(qū)域滑動(dòng),指定菜單欄會(huì)被選中,代碼簡(jiǎn)單易懂,感興趣的朋友一起看看吧2024-03-03
React+hook實(shí)現(xiàn)聯(lián)動(dòng)模糊搜索
這篇文章主要為大家詳細(xì)介紹了如何利用React+hook+antd實(shí)現(xiàn)聯(lián)動(dòng)模糊搜索功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02
一文詳解手動(dòng)實(shí)現(xiàn)Recoil狀態(tài)管理基本原理
這篇文章主要為大家介紹了一文詳解手動(dòng)實(shí)現(xiàn)Recoil狀態(tài)管理基本原理實(shí)例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
React項(xiàng)目build打包頁(yè)面空白的解決方案
React項(xiàng)目執(zhí)行build命令后,在本地服務(wù)器打開(kāi)頁(yè)面是空白的,本文主要介紹了React項(xiàng)目build打包頁(yè)面空白的解決方案,感興趣的可以了解一下2023-08-08
react中使用forEach或map兩種方式遍歷數(shù)組
這篇文章主要介紹了react中使用forEach或map兩種方式遍歷數(shù)組,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
react antd實(shí)現(xiàn)動(dòng)態(tài)增減表單
antd是react流行的ui框架庫(kù),本文主要介紹了react antd實(shí)現(xiàn)動(dòng)態(tài)增減表單,分享給大家,感興趣的小伙伴們可以參考一下2021-06-06
react-native聊天室|RN版聊天App仿微信實(shí)例|RN仿微信界面
這篇文章主要介紹了react-native聊天室|RN版聊天App仿微信實(shí)例|RN仿微信界面,需要的朋友可以參考下2019-11-11

