React實現(xiàn)Step組件的示例代碼
簡介
本文將會實現(xiàn)步驟條組件功能。步驟條在以下幾個方面改進。
1、將url與Step組件綁定,做到瀏覽器刷新,不會重定向到Step 1
2、通過LocalStorage 存儲之前的Step,做到不丟失數(shù)據(jù)。
實現(xiàn)
Step.jsx (組件)
import {useEffect, useState} from "react";
export const Step = ({name, data})=>{
const submit = (event)=>{
event.preventDefault();
const local = localStorage.getItem(name);
console.log(JSON.parse(local))
}
const [current, setCurrent] = useState(0);
useEffect(()=>{
let paths = window.location.pathname.split('/');
setCurrent(parseInt(paths[paths.length - 1]));
}, [])
return (
<form className={'Step'} onSubmit={submit}>
<div className={'Step-Header'}>
<div>
{
data.map((item, idx) =>{
return <a key={idx} href= {`/step/${idx}`} style={{paddingRight:30}}>{item.name + ((idx === current) ? '√':'')}</a>;
})
}
</div>
</div>
<div className={'Step-Content'}>
{data[current].content}
</div>
<div className={'Step-Footer'}>
{current > 0 && <button onClick={()=>setCurrent(current-1)}>pre</button>}
{current + 1 < data.length && <button onClick={()=> setCurrent(current+1)}>next</button>}
{current === data.length - 1 && <button type="submit">提交</button>}
</div>
</form>
);
}
1. Step會獲取瀏覽器url中的步驟數(shù),并設置Step-Content。
2.表單在最后一個步驟會有提交按鈕,會從local storage中獲取表單參數(shù)
3.step header 是導航欄, step content是具體的內(nèi)容,step footer為步驟條操作按鈕。
app.jsx (使用)
unction App() {
const stepName = 'Demo';
const Step1 = ()=>{
const local = localStorage.getItem(stepName);
const [username, setUsername] = useState(local ? local.username:'');
const change = (event)=>{
setUsername(event.target.value);
localStorage.setItem(stepName, JSON.stringify({
username: event.target.value
}));
}
return <>
<label htmlFor='username'>用戶名:</label><input type={'text'} value={username} onChange={change}/>
</>;
}
const steps = [
{
name: "步驟1",
content: <Step1/>
},
{
name: "步驟2",
content: (<span>2號</span>)
}
]
return <Step data={steps} name={stepName} />
}
export default App;
1.Step1組件需要將表單數(shù)據(jù)與localStorage綁定
到此這篇關于React實現(xiàn)Step組件的示例代碼的文章就介紹到這了,更多相關React Step組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
詳解Jotai Immer如何實現(xiàn)undo redo功能示例詳解
這篇文章主要為大家介紹了詳解Jotai Immer如何實現(xiàn)undo redo功能示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04
webpack 2.x配置reactjs基本開發(fā)環(huán)境詳解
本篇文章主要介紹了webpack 2.x配置reactjs基本開發(fā)環(huán)境詳解,具有一定的參考價值,有興趣的可以了解一下2017-08-08
React使用hook如何實現(xiàn)數(shù)據(jù)雙向綁定
這篇文章主要介紹了React使用hook如何實現(xiàn)數(shù)據(jù)雙向綁定方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03
ReactNative點擊事件.bind(this)操作分析
這篇文章主要為大家介紹了ReactNative點擊事件.bind(this)操作分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-11-11

