, 主要是为了封装一个公共方法,为后续我们写router源码的时候提供一些基石, 因为我们知道, react-router一旦路径匹配上了, 是会向组件里注入history, location等属性的,...方法, 都会根据参数返回给我们一个react-router中的match对象,参考 前端手写面试题详细解答history库的使用我们知道, 当路由匹配组件以后, react-router会向组件内部注入一些属性..., 其中的match属性我们已经有生成的方法了, 但是location和history还得劳烦我们自己写一写其实location就是history对象身上的一个属性, 我们搞定了location, history...React中, Router组件是用来提供上下文的, 而BrowserRouter创建了一个控制浏览器history api的history对象以后然后传递给Router我们在react-router中新建一个文件...routerContext;// 我们知道: 这个Router组件是一定需要一个history对象的, 他不管history对象是怎么来的, 但是必须通过属性传递给他import React, { useState