React中路由参数怎么改变页面不刷新数据的情况


这篇文章主要介绍“React中路由参数怎么改变页面不刷新数据的情况”,在日常操作中,相信很多人在React中路由参数怎么改变页面不刷新数据的情况问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”React中路由参数怎么改变页面不刷新数据的情况”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!路由的参数由于是在componentDidMount中获取的,如果在详情页面再次打开详情页面,由于组件并没有重新渲染,导致didMount不会获取路由参数。因此在参数改变的时候,可以利用componentWillReceiveProps来更新变量。在web开发早期的年代里,前端的功能远不如现在这么强大,一直是后端路由占据主导地位。服务端渲染就是在浏览器请求页面URL时,(每次切换页面时,浏览器都会刷新页面)服务端按照不同的URL地址与不同的html + css + 后端数据 之间的映射,直接将我们需要的HTML文本组装好,并返回给浏览器,这个HTML文本被浏览器解析之后,不需要经过JavaScript脚本的执行,可直接构建出完整的DOM树并展示页面中。随着 ajax 的使用越来越广泛,前端的页面逻辑开始变得越来越复杂,特别是单页Web应用(Single Page Web Application,SPA))的兴起,前端路由系统随之开始流行。1、用户的角度前端路由主要实现了两个功能(使用ajax更新页面状态的情况下):记录当前页面的状态(保存或分享当前页的url,再次打开该url时,网页还是保存(分享)时的状态);可以使用浏览器的前进后退功能(如点击后退按钮,可以使页面回到使用ajax更新页面之前的状态,url也回到之前的状态);2、作为开发者要实现这两个功能,我们需要做到:改变url且不让浏览器向服务器发出请求;监测 url 的变化;免费云主机域名截获 url 地址,并解析出需要的信息来匹配路由规则。模糊匹配模式默认情况下, React路由是模糊匹配模式模糊匹配规则:只要pathname以path开头就会匹配成功,对应的组件就会被渲染出来。精确匹配给 Route组件添加exact属性,让其变为精确匹配模式精确匹配:只有当path和 pathname完全匹配时才会展示该路由,严格匹配不要随便开启,需要再开,有些时候开启会导致无法继续匹配二级路由。点击Link组件(a标签)会修改浏览器地址栏中的urlReact路由监听到地址栏url的变化。Reat路由内部遍历所有 Route组件,使用路由规则(path)与 pathname进行匹配。当路由规则(path)能够匹配地址栏中的pathname时,就展示渲染该 Route组件的内容这里的 hash 就是指 url 尾巴后的 # 号以及后面的字符。这里的 # 和 css 里的 # 是一个意思。hash也称作锚点,本身是用来做页面定位的,她可以使对应 id 的元素显示在可视区域内。由于 hash 值变化不会导致浏览器向服务器发出请求,而且 hash 改变会触发 hashchange 事件,浏览器的进后退也能对其进行控制,所以人们在 html5 的 history 出现前,基本都是使用 hash 来实现前端路由的。已经有 hash 模式了,而且 hash 能兼容到IE8, history 只能兼容到 IE10,为什么还要搞个 history 呢?首先,hash 本来是拿来做页面定位的,如果拿来做路由的话,原来的锚点功能就不能用了。其次,hash 的传参是基于 url的,如果要传递复杂的数据,会有体积的限制,而history 模式不仅可以在url里放参数,还可以将数据存放在一个特定的对象中。React实现页面路由的模块:react-router-dom1、HashRouter和BrowserRouter其实就是路由的hash和history两种模式,并且这两个组件是路由的容器,必须在最外层。2、Route路由的一个原材料,它是控制路径对应显示的组件。 Route的参数:path:跳转的路径component: 对应路径显示的组件render:可以自己写render函数返回具体的dom,而不需要去设置component。location: 传递route对象,和当前的route对象对比,如果匹配则跳转exact: 匹配规则,true的时候则精确匹配。3、Link和NavLink(1)Link的apito: 有两种写法,表示跳转到哪个路由字符串写法对象写法replace:就是将push改成replaceinnerRef:访问Link标签的dom(2) NavLink的apiLink的所有apiactiveClassName 路由激活的时候设置的类名activeStyle 路由激活设置的样式exact 参考Route,符合这个条件才会激活active类strict 参考Route,符合这个条件才会激活active类isActive 接收一个回调函数,active状态变化的时候回触发,返回false则中断跳转。location 接收一个location对象,当url满足这个对象的条件才会跳转。4、Redirect:页面重定向5、Switch路由切换,只会匹配第一个路由,可以想象成tab栏Switch内部只能包含Route、Redirect、Router6、Router Hooks在Router5.x中新增加了Router Hooks用于在函数组件中获取路由信息。使用规则和React的其他Hooks一致。useHistory:返回history对象useLocation:返回location对象useRouteMatch:返回match对象useParams:返回match对象中的params,也就是path传递的参数7、history对象在每个路由组件中我们可以使用this.props.history获取到history对象,也可以使用withRouter包裹组件获取,在history中封装了push,replace,go等方法,具体内容如下:这样我们想使用api来操作前进后退就可以调用history中的方法到此,关于“React中路由参数怎么改变页面不刷新数据的情况”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注百云主机网站,小编会继续努力为大家带来更多实用的文章!

相关推荐: C语言的switch分支语句怎么使用

这篇文章主要介绍了C语言的switch分支语句怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言的switch分支语句怎么使用文章都会有所收获,下面我们一起来看看吧。switch语句也是一种分支语句,常常用于多分支的情况…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 03/27 12:29
下一篇 03/27 12:29

相关推荐