我有一个遗留的Web应用程序正在被React取代,它被这些不同的系统调用,通过传递一个URL(从现有数据库系统中的记录派生)应用程序呈现文件夹视图,沙箱容器中的文件根据传入的路径。
我需要能够识别这些请求并将它们路由到文件/文件夹处理页面,将路径的' / files /部分之后的所有内容视为文件或文件夹路径的参数
<Route path="/" handler={Master}>
<Route name="files_link" path="files" handler={Files} />
<Route name="filesWithPath_link" path="files/*:path" handler={Files} />
</Route>
我希望能够处理传递到
的请求/files
并在页面中处理它(默认为顶级文件夹,因为没有传递路径参数。
并将以下所有可能的URL示例传递给路由器,并从/ files /后的位中提取路径参数。
/files/folder path=folder
/files/folder/filename.ext path=folder/filename.ext
/files/folder/folder1 path=folder/folder1
/files/folder/folder1/filename.ext path=folder/folder1/filename.ext
/files/folder/folder1/folder2/ path=folder/folder1/folder2
/files/folder/folder1/folder2/filename.ext path=folder/folder1/folder2/filename.ext
.... and so on ...
当我尝试这个时,我收到错误
Uncaught Invariant Violation: Missing "splat" parameter for path "/beta/page/files/*:path"
我目前正在使用react
0.14.2和react-router
0.13.4。
如何在React-router中以这种方式处理可变长度路径?
答案 0 :(得分:15)
您需要像这样使用它:
<Route name="filesWithPath_link" path="files/*" handler={Files} />
然后在您的React组件中,您可以访问splat的值:
// The '*' in the path match gets assigned to this.props.params.splat
var path = this.props.params.splat;
答案 1 :(得分:0)
为了完整起见,可以从 useParams()
钩子作为属性 0
访问 splat 参数:
const splat = useParams()[0];