国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

反應(yīng)模態(tài)的滑動(dòng)動(dòng)畫
P粉514458863
P粉514458863 2023-08-30 22:49:29
0
1
686
<p>我已經(jīng)在react和css中實(shí)現(xiàn)了一個(gè)模態(tài),目前,當(dāng)我打開它時(shí),我已經(jīng)實(shí)現(xiàn)了一個(gè)向上滑動(dòng)的動(dòng)畫,其中模態(tài)從底部向上滑動(dòng),但是當(dāng)我關(guān)閉它時(shí)我希望它向下滑動(dòng),我無(wú)法弄清楚如何準(zhǔn)確創(chuàng)建向下滑動(dòng)的動(dòng)畫,有人可以幫忙嗎? 代碼=></p> <pre class="brush:php;toolbar:false;">import "./styles.css"; import react, { useState } from "react"; export default function App() { const [isModalOpen, setIsModalOpen] = useState(false); return ( <div> <button onClick={() => setIsModalOpen(true)}>open </button> {isModalOpen && ( <div className={`modal-overlay`}> <div className={`modal-content`}> <div className="feedbackModalHeader"> <img src="/assets/dislike_modal.svg" alt="" className="dislikeBtnNonFilled" /> <p className="provideFeedback">Provide additional feedback</p> </div> <button onClick={() => setIsModalOpen(false)}> close </button> </div> </div> )} </div> ); }</pre> <p>css 代碼=></p> <pre class="brush:php;toolbar:false;">.modal-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background-color: rgba(0, 0, 0, 0.5); display: flex; align-items: center; justify-content: center; z-index: 9999; transition: opacity 0.3s ease; } * { max-width: 100%; } .modal-content { background: #f5f0f0; padding: 20px; border-radius: 4px; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.15); z-index: 999; transform: translateY(100%); animation: slide-up 0.3s ease-out forwards; width: 59rem; border-radius: 8px; margin-left: auto; margin-right: auto; box-shadow: 0 4px 20px 0 rgb(0 0 0 / 10%), 0 1px 2px 0 rgb(0 0 0 / 6%); height: 21rem; position: relative; left: 2rem; } @keyframes slide-up { from { transform: translateY(100%); } to { transform: translateY(0); } } .close-button { position: absolute; top: 10px; right: 10px; border: none; background: transparent; font-size: 24px; cursor: pointer; } .provideFeedback { font-size: 20px; } .feedbackModalHeader { display: flex; align-items: center; gap: 1.2rem; margin-top: 0.8rem; }</pre> <p>程式碼沙箱連結(jié) => https://codesandbox.io/s/dark-river-6ckllv?file=/src/styles.css</p>
P粉514458863
P粉514458863

全部回覆(1)
P粉846294303

您必須根據(jù)狀態(tài)更改模式的類別。 (條件類別名稱

這是一種使用您想要的內(nèi)容創(chuàng)建模式的簡(jiǎn)單方法:

首先,定義 CSS 動(dòng)畫:

.modal-slide-down {
  animation-name: slide-down;
  animation-duration: 0.5s;
  animation-fill-mode: forwards;
}

@keyframes slide-down {
  0% {
    transform: translateY(-100%);
    opacity: 0;
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

然後,在您的 React 元件中,新增一個(gè)狀態(tài)變數(shù)來(lái)追蹤模式是否應(yīng)該開啟或關(guān)閉:

const [isOpen, setIsOpen] = useState(false);

當(dāng)使用者點(diǎn)擊按鈕或執(zhí)行其他動(dòng)作來(lái)開啟模式時(shí),將 isOpen 狀態(tài)設(shè)為 true:

<button onClick={() => setIsOpen(true)}>Open Modal</button>

最後,根據(jù) isOpen 狀態(tài)有條件地將 CSS 類別套用到模式:

<div className={`modal ${isOpen ? 'modal-slide-down' : ''}`}>
  {/* Modal content goes here */}
</div>

更多解釋:

#當(dāng)isOpen狀態(tài)為true時(shí),在模態(tài)元件中會(huì)加入modal-slide-down類,從而觸發(fā)向下滑動(dòng)動(dòng)畫。當(dāng) isOpen 狀態(tài)為 false 時(shí),modal-slide-down 類別將會(huì)移除,從而觸發(fā)上滑動(dòng)畫。

透過(guò)這些更改,模式將在打開時(shí)向下滑動(dòng)到視圖中,並在關(guān)閉時(shí)向上滑動(dòng)回來(lái)。當(dāng)然,您可能需要調(diào)整動(dòng)畫持續(xù)時(shí)間和其他 CSS 屬性以適合您的特定用例。

希望我能夠解決您的問(wèn)題。

最新下載
更多>
網(wǎng)站特效
網(wǎng)站源碼
網(wǎng)站素材
前端模板