この記事は 2025 年 6 月 23 日に投稿しました。
目次
リンク
1. はじめに
こんにちは、iOS のエディタアプリPWEditorとその後継PWEditor2の開発者の二俣です。
今回はReactのMaterial UIのステッパーを縦に表示する方法についてです。
2. ReactのMaterial UIのステッパーを縦に表示する
ReactのMaterail UIのステッパーを縦に表示するには、以下のような実装にします。
実装例
※create-react-appで作成したTypeScriptのプロジェクトです。
index.tsx
import React from "react"; import ReactDOM from "react-dom/client"; import App from "./App"; const root = ReactDOM.createRoot( document.getElementById("root") as HTMLElement ); root.render( <React.StrictMode> <App /> </React.StrictMode> );
App.tsx
import * as React from "react"; import Box from "@mui/material/Box"; import Stepper from "@mui/material/Stepper"; import Step from "@mui/material/Step"; import StepLabel from "@mui/material/StepLabel"; import StepContent from "@mui/material/StepContent"; import Button from "@mui/material/Button"; import Paper from "@mui/material/Paper"; import Typography from "@mui/material/Typography"; const steps = [ { label: "Select campaign settings", description: `For each ad campaign that you create, you can control how much you're willing to spend on clicks and conversions, which networks and geographical locations you want your ads to show on, and more.`, }, { label: "Create an ad group", description: "An ad group contains one or more ads which target a shared set of keywords.", }, { label: "Create an ad", description: `Try out different ad text to see what brings in the most customers, and learn how to enhance your ads using features like ad extensions. If you run into any problems with your ads, find out how to tell if they're running and how to resolve approval issues.`, }, ]; export default function App() { const [activeStep, setActiveStep] = React.useState(0); const handleNext = () => { setActiveStep((prevActiveStep) => prevActiveStep + 1); }; const handleBack = () => { setActiveStep((prevActiveStep) => prevActiveStep - 1); }; const handleReset = () => { setActiveStep(0); }; return ( <Box sx={{ maxWidth: 400, margin: 8 }}> <Stepper activeStep={activeStep} orientation="vertical"> {steps.map((step, index) => ( <Step key={step.label}> <StepLabel optional={ index === steps.length - 1 ? ( <Typography variant="caption">Last step</Typography> ) : null } > {step.label} </StepLabel> <StepContent> <Typography>{step.description}</Typography> <Box sx={{ mb: 2 }}> <Button variant="contained" onClick={handleNext} sx={{ mt: 1, mr: 1 }} > {index === steps.length - 1 ? "Finish" : "Continue"} </Button> <Button disabled={index === 0} onClick={handleBack} sx={{ mt: 1, mr: 1 }} > Back </Button> </Box> </StepContent> </Step> ))} </Stepper> {activeStep === steps.length && ( <Paper square elevation={0} sx={{ p: 3 }}> <Typography>All steps completed - you're finished</Typography> <Button onClick={handleReset} sx={{ mt: 1, mr: 1 }}> Reset </Button> </Paper> )} </Box> ); }
実行結果
リファレンス
3. おわりに
ステッパーは縦にも表示できるようです。
リンク
紹介している一部の記事のコードはGitlabで公開しています。
興味のある方は覗いてみてください。
私が勤務しているニューラルでは、主に組み込み系ソフトの開発を行っております。
弊社製品のハイブリッド OS Bi-OSは高い技術力を評価されており、特に制御系や通信系を得意としています。
私自身はiOS モバイルアプリやウィンドウズアプリを得意としております。
ソフトウェア開発に関して相談などございましたら、お気軽にご連絡ください。
また一緒に働きたい技術者の方も随時募集中です。
興味がありましたらご連絡ください。
EMAIL : info-nr@newral.co.jp / m-futamata@newral.co.jp
TEL : 042-523-3663
FAX : 042-540-1688