欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React實現(xiàn)組件全屏化的操作方法

 更新時間:2021年10月16日 10:09:06   作者:米洛  
開發(fā)今天給我提了一個sql編輯器輸入框比較小,不支持放大,不太方便,下面看下我的處理方法,本文基于React+antd,給大家演示一個完整的全屏demo,感興趣的朋友一起看看吧

介紹

本文基于React+antd,給大家演示一個完整的全屏demo。

起因是開發(fā)今天給我提了一個sql編輯器輸入框比較小,不支持放大,不太方便。希望能夠全屏顯示,聯(lián)想到自己以后可能也會需要,便研究并記錄之。

其實我覺得也沒有很?。╫rz)

全屏

大家應該都在web頁面里面見過全屏按鈕,點擊它以后頁面就成了全屏,經(jīng)常會在代碼編輯器中出現(xiàn)。

上圖就是leetcode全屏后的效果了,省略了菜單等內(nèi)容

看起來全屏展示分為很多種,我說說我的看法。

  • leetcode這種 它只是頁面全屏
  • F11 我們可以按F11進入全屏模式,是chrome自帶的,不需要修改代碼
  • 改變dom,其實和第一種一樣,只不過會隱藏瀏覽器部分內(nèi)容

如上圖一樣,瀏覽器的軀殼已經(jīng)不見了。

全屏的用處

全屏的話,似乎當你希望全身心投入閱讀的時候比較需要,就好像大家看電影也喜歡全屏一樣。主要還是放大組件,讓大量輸入/閱讀操作能夠更愉快♀地進行。

安裝react-full-screen

// yarn add react-full-screen
npm install react-full-screen --save

使用yarn或者npm安裝這個庫。官網(wǎng)提供了一些demo,鏈接在此

編寫一個最簡單的組件

這里就直接上代碼了,代碼不多,很好懂。

import React, { useState } from "react";
import ReactDOM from "react-dom";
import "antd/dist/antd.css";
import "./index.css";
import { FullscreenOutlined, FullscreenExitOutlined } from "@ant-design/icons";
import { Tooltip, Card, Col, Row } from "antd";
import { FullScreen, useFullScreenHandle } from "react-full-screen";

const App = () => {
  // 定義full變量,為的是兼容全屏和非全屏的樣式,比如full的時候高度為200,非full高度為100
  const [full, setFull] = useState(false);
  // 創(chuàng)建一個fullScreen的handle
  const handle = useFullScreenHandle();

  return (
    <div style={{ background: "#ececec", height: 500 }}>
      <Row gutter={[8, 8]}>
        <Col span={8}>
          <Card style={{ height: 500 }}>左側card</Card>
        </Col>
        <Col span={16}>
          <FullScreen
            handle={handle}
            onChange={setFull}
            style={{ background: "#ffffff" }}
          >
            <Card style={{ height: 500 }}>
              <div>
                <Tooltip title="全屏">
                  <FullscreenOutlined
                    style={{ fontSize: 16 }}
                    onClick={() => {
                      // 點擊設置full為true,接著調(diào)用handle的enter方法,進入全屏模式
                      setFull(true);
                      handle.enter();
                    }}
                  />
                </Tooltip>
                <Tooltip title="退出全屏">
                  <FullscreenExitOutlined
                    style={{ fontSize: 16, marginLeft: 16 }}
                    // 退出全屏模式并把full設置為false
                    onClick={() => {
                      setFull(false);
                      handle.exit();
                    }}
                  />
                </Tooltip>
              </div>
              <div>假設這是一個編輯器</div>
            </Card>
          </FullScreen>
        </Col>
      </Row>
    </div>
  );
};

ReactDOM.render(<App />, document.getElementById("container"));

展示出來是這個樣子,代碼里面加入了注釋,大家對著看即可。由于codesandbox里面不太支持,所以我放到了一個antd pro的項目里面,給大家看看效果。

這樣,我們做到了只放大編輯器的效果,隱藏掉了其他不重要的部分(左側部分)。

存在的問題

這樣還遠遠不夠,里面還有一些細節(jié)要優(yōu)化。

  • 默認背景為黑色,不友好,我們需要設置樣式
  • 我們應該在全屏模式把編輯器高度變大
  • 還有暗坑,待會再說

各個擊破

背景色

我們使用的這個庫,會默認包裹一個全局的div,當全屏的時候,class為.fullscreen.fullscreen-enabled,而非全屏的時候則為fullscreen。

所以我們在全局/組件的樣式里面寫如下的css即可:

.fullscreen.fullscreen-enabled {
  background: #fff;
  padding: 24px;
}

可以看到這個樣式已經(jīng)生效了,而且我們加入了padding,這樣看起來Card就不會被擠到邊上。

高度

我們之前設置了full變量,所以我們修改一下代碼,根據(jù)full來判斷高度。

可以看到盒子的高度已經(jīng)發(fā)生了變化。

擴展部分

如果你以為這就結束了,那就大錯特錯了。接下來我們說一說暗坑。

在antd組件里面,modal/drawer/message等等都是在body中生成的dom元素,所以我們會遇到什么問題呢?

全屏模式根本就看不到對話框/消息提示等。

好在antd提供了對應的參數(shù),控制dom的掛載元素。

Modal

modal可以這么解決,我們首先設置一個full_screen的id:

注意,這個id一定要在FullScreen組件里面。

接著我們在Modal.info,Modal組件里面都加入如下參數(shù):

注意: 這里的modal我的demo里面并沒有寫,這個屬于擴展部分。寫一個modal組件也不復雜,大家可以自己嘗試下。

Modal.info這樣的api

Modal.info({
  title: 'cud請求參數(shù)',
  width: 800,
  // 注意加上這個
  getContainer: document.getElementById('full_screen')
  })

message

通過message.config傳入getContainer方法:

這里我沒找到很好的辦法,每次message.info的時候都需要config一下,還是比較麻煩的。如果作為全局配置則又可能出問題,大家有更好的辦法可以留言哈。

到此這篇關于React實現(xiàn)組件全屏化的文章就介紹到這了,更多相關React組件全屏化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 詳解各版本React路由的跳轉(zhuǎn)的方法

    詳解各版本React路由的跳轉(zhuǎn)的方法

    這篇文章主要介紹了詳解各版本React路由的跳轉(zhuǎn)的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • React動畫實現(xiàn)方案Framer Motion讓頁面自己動起來

    React動畫實現(xiàn)方案Framer Motion讓頁面自己動起來

    這篇文章主要為大家介紹了React動畫實現(xiàn)方案Framer Motion讓頁面自己動起來,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • react實現(xiàn)自定義拖拽hook

    react實現(xiàn)自定義拖拽hook

    這篇文章主要為大家詳細介紹了react實現(xiàn)自定義拖拽hook,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • react-router實現(xiàn)跳轉(zhuǎn)傳值的方法示例

    react-router實現(xiàn)跳轉(zhuǎn)傳值的方法示例

    這篇文章主要給大家介紹了關于react-router實現(xiàn)跳轉(zhuǎn)傳值的相關資料,文中給出了詳細的示例代碼,對大家具有一定的參考學習價值,需要的朋友們下面跟著小編一起來學習學習吧。
    2017-05-05
  • React事件處理過程中傳參的實現(xiàn)方法

    React事件處理過程中傳參的實現(xiàn)方法

    這篇文章主要介紹了React事件處理過程中傳參的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-10-10
  • react-router?v6新特性總結示例詳解

    react-router?v6新特性總結示例詳解

    在V6版本中,<Switch>組件被替換成<Routes>組件,同時,component屬性被element屬性替換,這篇文章主要介紹了react-router?v6新特性總結,需要的朋友可以參考下
    2022-12-12
  • 在react-antd中彈出層form內(nèi)容傳遞給父組件的操作

    在react-antd中彈出層form內(nèi)容傳遞給父組件的操作

    這篇文章主要介紹了在react-antd中彈出層form內(nèi)容傳遞給父組件的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • 詳解使用create-react-app快速構建React開發(fā)環(huán)境

    詳解使用create-react-app快速構建React開發(fā)環(huán)境

    這篇文章主要介紹了詳解使用create-react-app快速構建React開發(fā)環(huán)境,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • React useEffect的理解與使用

    React useEffect的理解與使用

    這篇文章主要介紹了React useEffect的理解與使用,幫助大家更好的理解和學習使用React,感興趣的朋友可以了解下
    2021-04-04
  • React父子組件傳值(組件通信)的實現(xiàn)方法

    React父子組件傳值(組件通信)的實現(xiàn)方法

    本文主要介紹了React父子組件傳值(組件通信)的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-05-05

最新評論