大佬教程收集整理的这篇文章主要介绍了使用React Router v4的React Hooks-如何重定向到另一条路由?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
您的问题与使用react-router-v4(而非钩子)以编程方式进行导航有关,
在react-
router-v4中,如果Todos组件以子代或Route的形式呈现,则可以从props获取历史记录,或者从Route呈现的祖先那里获得Router的历史记录,并将它传递Router的props。但是,它没有收到路由器道具,您可以使用withRouter
HOC从中react-
router
获取路由器道具并进行呼叫props.history.push(desturlEdit)
import React, {useState, useContext, useEffect} from 'react';
import TodosContext from './context'
import { withRouter } from 'react-router-dom';
function Todos(props){
const [todo, setTodo] = useState("")
const {state, dispatch} = useContext(TodosContext)
useEffect(()=>{
if(state.currentTodo.text){
setTodo(state.currentTodo.text)
} else {
setTodo("")
}
dispatch({
type: "GET_TodoS",
payload: state.todos
})
}, [state.currentTodo.ID])
const editRow = event =>{
let desturlEdit = `/todos/${event.ID}`
let obj = {}
obj.ID = event.ID
obj.text = event.text
dispatch({type:"SET_CURRENT_Todo", payload: obj})
//after dispatch I would like to redirect to another route to do the actual edit
//desturlEdit
props.history.push(desturlEdit);
}
return(
<div>
<h1>List of Todos</h1>
<h4>{titlE}</h4>
<ul>
{state.todos.map(todo => (
<li key={todo.ID}>{todo.text}
<button onClick={()=>{
editRow(todo)}}>
</button>
</li>
))}
</ul>
</div>
)
}
export default withRouter(Todos);
我有一个简单的react hooks应用程序-Todos列表-使用react router v4
在待办事项列表上,单击待办事项时,我需要:
在以前的基于React Class的实现中,我可以使用this.context.history.push重定向到另一条路由。
我将如何结合使用React Hooks和React Router v4来处理该问题(在下面的代码中,请参见我在函数editRow()中的注释)?
代码如下:
===== index.js =====
import React from 'react';
import ReactDOM from 'react-dom';
import { BrowserRouter} from "react-router-dom"
import App from './App';
ReactDOm.render(
<BrowserRouter>
<App />
</BrowserRouter>,document.getElementById('root'));
===== main.js =====
import React from 'react'
import { Switch,Route } from 'react-router-dom'
import TodosList from './todoslist'
import TodosEdit from './todosedit'
const Main = () => (
<main>
<Switch>
<Route exact path="/todos" component={TodosList}/>
<Route exact path="/todos/:id" component={TodosEdit} />
</Switch>
</main>
)
export default Main
===== app.js =====
import React,{useContext,useReducer} from 'react';
import Main from './main'
import TodosContext from './context'
import todosReducer from './reducer'
const App = () => {
const initialState = useContext(TodosContext);
const [state,dispatch] = useReducer(todosReducer,initialStatE);
return (
<div>
<TodosContext.Provider value={{state,dispatch}}>
<Main/>
</TodosContext.Provider>
</div>
)
}
export default App;
===== TodosContext.js =====
import React from 'react'
const TodosContext = React.createContext({
todos: [
{id:1,text:'Get Grocery',complete:falsE},{id:2,text:'Excercise',{id:3,text:'Drink Water',complete:truE},],currentTodo: {}
})
export default TodosContext
===== reducer.js =====
import React from 'react'
export default function reducer(state,action){
switch(action.typE){
case "GET_TODOS":
return {
...state,todos: action.payload
}
case "SET_CURRENT_TODO":
return {
...state,currentTodo: action.payload
}
default:
return state
}
}
===== Todos.js =====
import React,{useState,useContext,useEffect} from 'react';
import TodosContext from './context'
function Todos(){
const [todo,setTodo] = useState("")
const {state,dispatch} = useContext(TodosContext)
useEffect(()=>{
if(state.currentTodo.text){
setTodo(state.currentTodo.text)
} else {
setTodo("")
}
dispatch({
type: "GET_TODOS",payload: state.todos
})
},[state.currentTodo.id])
const editRow = event =>{
let desturlEdit = `/todos/${event.iD}`
let obj = {}
obj.id = event.id
obj.text = event.text
dispatch({type:"SET_CURRENT_TODO",payload: obj})
//after dispatch I would like to redirect to another route to do the actual edit
//desturlEdit
}
return(
<div>
<h1>List of ToDos</h1>
<h4>{titlE}</h4>
<ul>
{state.todos.map(todo => (
<li key={todo.iD}>{todo.text}
<button onClick={()=>{
editRow(todo)}}>
</button>
</li>
))}
</ul>
</div>
)
}
export default Todos;
@H_674_72@@H_674_72@
以上是大佬教程为你收集整理的使用React Router v4的React Hooks-如何重定向到另一条路由?全部内容,希望文章能够帮你解决使用React Router v4的React Hooks-如何重定向到另一条路由?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。