582. 【前端】React 組件調(diào)試小技巧

一般我們在調(diào)試單個(gè)React組件時(shí)移稳,借助于熱更新,我們改改代碼可以在瀏覽器實(shí)時(shí)看到更新爵卒,但當(dāng)項(xiàng)目比較大的時(shí)候导帝,我們調(diào)試的頁面在整個(gè)應(yīng)用中的路由層級比較深守谓,就會導(dǎo)致:每一次咱們修改完一個(gè)地方的代碼,瀏覽器自動(dòng)刷新到了首頁您单,并進(jìn)入修改的頁面斋荞,才能看到更新之后的變化。

介于此虐秦,這篇分享一個(gè)前端調(diào)試React組件的方法平酿。

一、使用 createPortal 構(gòu)建測試組件

scss代碼:

.test-container {
  position: fixed;
  width: 100vw;
  height: 100vh;
  background-color: white;
  z-index: 99999999999999999999999999999;
  top: 0;
}
  • position: fixed 是 CSS 中一種定位方式悦陋,它可以讓元素相對于瀏覽器窗口固定不動(dòng)染服,無論頁面滾動(dòng)到哪個(gè)位置,該元素都會保持在窗口的固定位置叨恨。具體來說,position: fixed 的元素會被從文檔流中拖出來挖垛,并相對于瀏覽器窗口進(jìn)行定位痒钝,而不是相對于其父元素秉颗。因此,固定定位的元素不會影響其他元素的布局送矩,也不會受到頁面滾動(dòng)的影響蚕甥。使用固定定位的元素通常用于創(chuàng)建導(dǎo)航欄、懸浮廣告或工具欄等需要始終保持在頁面頂部或底部的元素栋荸。
  • 這串樣式代碼可以讓我們的測試組件位于窗口最前端菇怀,調(diào)試代碼時(shí)就不需要跳轉(zhuǎn)頁面了

tsx代碼:

import React, {
    FC,
    useState,
    useEffect,
    ReactNode
} from "react";
import './test-container.scss'
import {createPortal} from "react-dom";

interface TestContainerProps {
    element: ReactNode;
}

export const TestContainer: FC<TestContainerProps> = (props) => {
    const [isReady, setIsReady] = useState<boolean>(false)
    useEffect(() => {
        setIsReady(true)
    }, [])

    if (!isReady) return null
    return createPortal(<article className={"test-container"}>
        {props.element}
    </article>, document.body)
}

TestContainer.defaultProps = {}
export {TestContainer as default} from './test-container'

  • 該組件用起來很簡單,將需要測試的組件作為一個(gè)ReactNode傳進(jìn)來就可以了晌块。

使用示例如下:

<TestContainer element={<IMarkdown content={content}/>} />
  • IMarkdown 是我需要測試的組件(對react-markdown的封裝)爱沟。

總結(jié):作為一個(gè)開發(fā),如果開發(fā)過程中有件事一直在重復(fù)做匆背,那么就應(yīng)該想解決方案呼伸,解決這個(gè)問題。比如重復(fù)的代碼钝尸,就可以封裝起來括享。比如重復(fù)的文件復(fù)制粘貼,在windows下可以寫bat腳本珍促,在linux下可以寫shell腳本铃辖;比如每天都要執(zhí)行測試用例的執(zhí)行,就可以集成到CI/CD(continuous integration/continuous deloyment/delivery)中猪叙。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末娇斩,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子沐悦,更是在濱河造成了極大的恐慌成洗,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件藏否,死亡現(xiàn)場離奇詭異瓶殃,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)副签,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進(jìn)店門遥椿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人淆储,你說我怎么就攤上這事冠场。” “怎么了本砰?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵碴裙,是天一觀的道長。 經(jīng)常有香客問我,道長舔株,這世上最難降的妖魔是什么莺琳? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮载慈,結(jié)果婚禮上惭等,老公的妹妹穿的比我還像新娘。我一直安慰自己办铡,他們只是感情好辞做,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著寡具,像睡著了一般秤茅。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上晒杈,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天嫂伞,我揣著相機(jī)與錄音,去河邊找鬼拯钻。 笑死帖努,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的粪般。 我是一名探鬼主播拼余,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼亩歹!你這毒婦竟也來了匙监?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤小作,失蹤者是張志新(化名)和其女友劉穎亭姥,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體顾稀,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡达罗,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了静秆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片粮揉。...
    茶點(diǎn)故事閱讀 39,991評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖抚笔,靈堂內(nèi)的尸體忽然破棺而出扶认,到底是詐尸還是另有隱情,我是刑警寧澤殊橙,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布辐宾,位于F島的核電站狱从,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏叠纹。R本人自食惡果不足惜矫夯,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望吊洼。 院中可真熱鬧,春花似錦制肮、人聲如沸冒窍。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽综液。三九已至,卻和暖如春儒飒,著一層夾襖步出監(jiān)牢的瞬間谬莹,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工桩了, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留附帽,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓井誉,卻偏偏與公主長得像蕉扮,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子颗圣,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評論 2 355

推薦閱讀更多精彩內(nèi)容