近期,我們因 Bootstrap CSS 框架太肥大,導致 Google Lighthouse 每頁平均下降 5-10 分,因此我們計劃移除 Bootstrap,因為我們只有用到Bootstrap CSS ,並未使用到元件,替換起來相較容易許多。
但因為頁面太多了,如果將每頁的網格佈局,重構成 Tailwind Grid 的排版方式,可能需要耗費相當多的時間,也提昇頁面改壞的風險,因此重構頁面部份,拆到下個階段執行。
# 設定搜尋的目錄路徑 $directoryPath = "E:\VisualStudioProject\Apps\NextJS" # 設定需要替換的字詞對應 $replacements = @{ 'd-none' = 'hidden' 'd-block' = 'block' 'd-flex' = 'flex' 'd-inline-flex' = 'inline-flex' 'flex-column' = 'flex-col' 'justify-content-end' = 'justify-end' 'align-items-start' = 'items-start' 'align-items-center' = 'items-center' 'align-items-end' = 'items-end' 'align-items-stretch' = 'items-stretch' 'justify-content-center' = 'justify-center' 'justify-content-start' = 'justify-start' 'justify-content-between' = 'justify-between' 'justify-content-around' = 'justify-around' 'position-absolute' = 'absolute' 'd-xl-none' = 'xl:hidden' 'd-xl-block' = 'xl:block' 'd-md-block' = 'md:block' 'd-md-none' = 'md:hidden' 'w-100' = 'w-full' 'h-100' = 'h-full' 'p-3' = 'p-4' 'p-4' = 'p-6' 'p-5' = 'p-12' 'px-3' = 'px-4' 'px-4' = 'px-6' 'px-5' = 'px-12' 'py-3' = 'py-4' 'py-4' = 'py-6' 'py-5' = 'py-12' 'pt-3' = 'pt-4' 'pt-4' = 'pt-6' 'pt-5' = 'pt-12' 'pb-3' = 'pb-4' 'pb-4' = 'pb-6' 'pb-5' = 'pb-12' 'ps-3' = 'ps-4' 'ps-4' = 'ps-6' 'ps-5' = 'ps-12' 'p-md-4' = 'md:p-6' 'p-lg-4' = 'lg:p-6' 'py-md-4' = 'md:py-6' 'pt-lg-5' = 'md:p-12' 'pb-md-4' = 'md:pb-6' 'ps-lg-3' = 'lg:ps-4' 'pe-md-5' = 'md:pe-12' 'm-3' = 'm-4' 'm-4' = 'm-6' 'm-5' = 'm-12' 'mx-3' = 'mx-4' 'mx-4' = 'mx-6' 'mx-5' = 'mx-12' 'my-3' = 'my-4' 'my-4' = 'my-6' 'my-5' = 'my-12' 'mt-3' = 'mt-4' 'mt-4' = 'mt-6' 'mt-5' = 'mt-12' 'mb-3' = 'mb-4' 'mb-4' = 'mb-6' 'mb-5' = 'mb-12' 'ms-3' = 'ms-4' 'ms-4' = 'ms-6' 'ms-5' = 'ms-12' 'my-md-3' = 'md:my-4' 'mt-md-5' = 'md:mt-12' 'mt-lg-5' = 'md:lg-12' 'fs-1' = 'text-6xl' 'fs-2' = 'text-5xl' 'fs-3' = 'text-4xl' 'fs-4' = 'text-3xl' 'fs-5' = 'text-2xl' 'fs-6' = 'text-xl' 'fw-bold' = 'font-bold' 'fw-lighter' = 'font-[lighter]' 'fw-light' = 'font-light' 'fw-semibold' = 'font-semibold' 'col-12' = 'w-full' 'col-md-4' = 'md:w-1/3' 'col-6' = 'w-1/2' 'col-lg-4' = 'lg:w-1/3' 'col-lg-2' = 'lg:w-1/6' 'col-sm-6' = 'sm:w-1/2' 'col-sm-4' = 'sm:w-1/3' 'col-3' = 'w-1/4' 'col-4' = 'w-1/3' 'col-lg-6' = 'lg:w-1/2' 'col-lg-3' = 'lg:w-1/4' 'col-md-8' = 'md:w-2/3' 'col-xl-5' = 'xl:w-5/12' 'col-md-6' = 'md:w-1/2' 'col-md-10' = 'md:w-5/6' 'col-md-12' = 'md:w-full' 'col-lg-5' = 'lg:w-5/12' 'col-lg-7' = 'lg:w-7/12' 'col-lg-8' = 'lg:w-2/3' 'col-lg-9' = 'lg:w-3/4' 'col-sm-8' = 'sm:w-2/3' 'col-sm-9' = 'sm:w-3/4' 'col-sm-12' = 'sm:w-full' 'col-1' = 'w-1/12' 'col-2' = 'w-1/6' 'col-5' = 'w-5/12' 'col-7' = 'w-7/12' 'col-8' = 'w-2/3' 'col-9' = 'w-3/4' 'col-11' = 'w-11/12' 'col-md-5' = 'md:w-5/12' 'col-md-7' = 'md:w-7/12' 'col-xl-6' = 'xl:w-1/2' 'col-xl-2' = 'xl:w-1/6' 'col-sm-offset-1' = 'sm:ml-1/12' // 依據你們專案用到的,可以自己增加... } Set-Location -Path $directoryPath Get-ChildItem -Recurse -Filter '*.tsx' | ForEach-Object { $escapedFileName = $_.FullName -replace '\[(.*?)\]', '`[$1`]' $content = Get-Content $escapedFileName -Raw $replacements.GetEnumerator() | ForEach-Object { $content = $content -replace "(?<!\!)$($_.Key)", $_.Value } [System.IO.File]::WriteAllText($_.FullName, $content) } pause
// bootstrap 的 container 比較特別,因此需要在 global scss 額外宣告 container .container { width: 100%; margin-right: auto; margin-left: auto; } @media (min-width: 576px) { .container { max-width: 540px; } } @media (min-width: 768px) { .container { max-width: 720px; } } @media (min-width: 992px) { .container { max-width: 960px; } } @media (min-width: 1200px) { .container { max-width: 1140px; } } @media (min-width: 1400px) { .container { max-width: 1320px; } }
雖然切換技術總是有挑戰性的,考慮到長期的效能和可維護性,這是值得的,如果你也正在考慮這樣的昇級,希望也能夠解決你的問題。