我是reactjs中的新手,我想在tomcat服务器上部署我的reactjs应用程序而不是在反应服务器上运行,默认端口是3000。 我运行npm serve命令来运行npm本地服务器,但需要使用tomcat服务器访问该应用程序。
请提出任何建议。
由于
答案 0 :(得分:6)
npm run build 可以触发构建过程,但它会生成代码,假设基本URL没有任何相对路径,但如果我想部署到服务器中的相对路径,该怎么办? 所以我的意思是相对路径是,我在tomcat webapps目录中有一个simpleapp文件夹,我想从那个http://localhost/simpleapp访问我的反应应用程序。 如果使用反应路由器,它会变得更加复杂。
我得到一个空白页面,但后来我found Some changes 完成了反应路由器和package.json解决了我的问题。
所以我找到的解决方案是: -
在package.json中提及主页属性
"主页":" https://localhost:8080/simpleapp",
对于react路由器,我们必须添加basename属性。
在上面的情况下,app将部署在simpleapp相对路径
上
<Router basename={'/simpleapp'}>
<Route path='/' component={Home} />
{/* … */}
</Router>
&#13;
答案 1 :(得分:1)
在您的反应代码的根文件夹中运行此命令。
npm run build
这会在名为&#39; build&#39;的文件夹中生成优化的生产版本,该文件夹基本上包含一个index.html页面,其中包含静态JS和CSS文件。然后,您可以将这些文件复制并粘贴到Tomcat WebContent文件夹中。
这里有link可能会对此有所了解。
答案 2 :(得分:0)
您需要首先决定如何使用Grunt或webpack构建项目。您还可以在包json中添加npm run build
之类的脚本,这可以触发构建过程。
只需放置构建的文件并将脚本包含在index.html中,即可在任何Web服务器中使用构建的项目。