我有点糊涂了。当我调试React原生应用程序时,我通常同时启用热重载和生活重新加载。我想知道它们之间的区别是什么?
生活重新加载在文件更改时重新加载或刷新整个应用程序。例如,如果你在导航中有四个链接,并保存了一个更改,实时重新加载将重新启动应用程序,并将应用程序加载回初始路由。
热重载只刷新被更改的文件,而不会丢失应用程序的状态。例如,如果你在导航的四个链接深处保存了对某些样式的更改,状态不会改变,但新的样式将出现在页面上,而无需导航回当前页面,因为你仍然在同一页面上。
两者都可以使用CMD+D / CMD+CTRL+Z / Shake Gesture menu来启用。两者都使用watchman监听文件更改。
CMD+D / CMD+CTRL+Z / Shake Gesture menu
实时重新加载重新加载整个应用程序。
热重新加载背后的想法是保持应用程序运行,并注入你在运行时编辑的文件的新版本。这样,你就不会丢失任何状态,这在你调整UI的时候特别有用。所以它只重新加载你修改更多信息的页面在这里
这两个(热重新加载和实时重新加载)特性在react-native的0.62版本中合并为fast refresh,如果你使用的是下面的版本,那么这两个(热重新加载和实时重新加载)将可用。
fast refresh
1. 热重载
热重载只是根据新的代码更改显示代码更改 无需重新启动应用程序从开始和它的影响仅对 更改的代码或更改将只应用于特定的组件 注:热重载有时不起作用,如果你在你的 导航。< / p >
2. 生活重新加载
两者的区别是,实时重新加载会重新加载你的整个应用。它会说,文件改变了,重载整个应用,热重载不会重载整个应用。它只会修补被改变的代码并将状态保存在你的应用中。
Hot Reload:
热重新加载仅用于刷新代码发生更改的文件
Live Reload:
Live Reload用于刷新它不关心的整个应用程序
热重载:热重载仅用于刷新代码发生更改的文件 Live Reload: Live Reload用于刷新整个应用