React实现Step组件的示例代码
简介
本文将会实现步骤条组件功能。步骤条在以下几个方面改进。
1、将url与Step组件绑定,做到浏览器刷新,不会重定向到Step 1
2、通过LocalStorage 存储之前的Step,做到不丢失数据。
实现
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中的步骤数,并设置Step-Content。
2.表单在最后一个步骤会有提交按钮,会从local storage中获取表单参数
3.step header 是导航栏, step content是具体的内容,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组件需要将表单数据与localStorage绑定
到此这篇关于React实现Step组件的示例代码的文章就介绍到这了,更多相关React Step组件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
React组件实例三大核心属性State props Refs详解
组件实例的三大核心属性是:State、Props、Refs。类组件中这三大属性都存在。函数式组件中访问不到 this,也就不存在组件实例这种说法,但由于它的特殊性(函数可以接收参数),所以存在Props这种属性2022-12-12react-native中ListView组件点击跳转的方法示例
ListView作为React Native的核心组件,用于高效地显示一个可以垂直滚动的变化的数据列表。下面这篇文章主要给大家介绍了关于react-native中ListView组件点击跳转的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。2017-09-09react Table准备Spin Empty ConfigProvider组件实现
这篇文章主要为大家介绍了react Table准备Spin、Empty、ConfigProvider组件实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪<BR>2023-02-02
最新评论