javascript - 在 React 中处理静态文件(css、js、img)

标签 javascript html css reactjs

我有一个 React 应用程序,我正在为这个应用程序使用一个模板。这是我的 React 应用程序的文件夹结构:

|app
|-client
|---assets
|---component
|-node_modules
|-server
|---index.html
|---index.js

在我的server/index.html里有很多静态文件,比如css、js、img。

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="description" content="">
    <meta name="author" content="">
    <link rel="shortcut icon" href="/assets/img/logo-fav.png">
    <title>Loyalty Multipolar</title>
    <link rel="stylesheet" type="text/css" href="/assets/lib/perfect-scrollbar/css/perfect-scrollbar.min.css"/>
    <link rel="stylesheet" type="text/css" href="/assets/lib/material-design-icons/css/material-design-iconic-font.min.css"/>
    <link href="https://fonts.googleapis.com/css?family=Roboto" rel="stylesheet">

    <!--[if lt IE 9]>
    <script src="https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js"></script>
    <script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
    <![endif]-->
    <link rel="stylesheet" href="/assets/css/style.css" type="text/css"/>

  </head>
  <body>
    <div class="be-wrapper" id="root">

    </div>
  <script src="bundle.js"></script>

  <script src="assets/lib/jquery/jquery.min.js" type="text/javascript"></script>
  <script src="assets/lib/perfect-scrollbar/js/perfect-scrollbar.jquery.min.js" type="text/javascript"></script>
  <script src="assets/lib/bootstrap/dist/js/bootstrap.min.js" type="text/javascript"></script>
  <script src="assets/js/main.js" type="text/javascript"></script>
  <script type="text/javascript">
    $(function(){
      Plugins.init();
    });

  </script>
  </body>
</html>

如何在 React 应用程序中处理这些文件?同时在 Node JS 应用程序中,我们使用它来处理静态文件:

app.use('/assets',express.static(__dirname + '/assets'));

静态文件没有加载,如果我键入例如: localhost:3000/assets/js/jquery,文件不可用

这是我的server/index.js 文件:

import express from 'express';
import path from 'path';

import webpack from 'webpack';
import webpackMiddleware from 'webpack-dev-middleware';
import webpackHotMiddleware from 'webpack-hot-middleware';
import webpackConfig from '../webpack.config.dev';

let app = express();
const compiler = webpack(webpackConfig);

app.use(webpackMiddleware(compiler, {
  hot: true,
  publicPath: webpackConfig.output.publicPath,
  noInfo: true,
}));
app.use(webpackHotMiddleware(compiler));

app.use('/assets',express.static(__dirname + '/assets'));


app.get('/*', (req, res) => {
  res.sendFile(path.join(__dirname,'../index.html'));
})

app.listen(3000, () => console.log('Running port 3000'));

谢谢。

最佳答案

你可以像下面这样放置静态文件:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>React Container Components Example</title>
    <link rel="stylesheet" href="/dist/css/bootstrap.min.css">
    <link rel="stylesheet" href="/dist/css/bootstrap.theme.min.css">
    <link rel="stylesheet" href="/css/styles.css">
</head>
<body>

<div id="root"></div>
<script src="/js/bundle.js"></script>

</body>
</html>

来源:https://github.com/johibkhan2/react-sample-app/blob/master/index.html

关于javascript - 在 React 中处理静态文件(css、js、img),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45137778/

相关文章:

javascript - Regex/Jquery - 删除字符串/保留 Int

Javascript从多个字符串设置日期对象

javascript - 如何根据 div 高度添加 .css 文件?

html - 最新 Chrome 和 Flexbox 的问题/溢出

CSS child width 100% or px 问题

javascript - 带 babel 的 NPM 7 工作区 - 在工作区之间导入

javascript - 如何获取JS提示框的值然后保存到数组中

javascript - 如何使用 CSS 以 Angular 进行滑动?

CSS 2 Div 布局 float

html - 如何强制图像以纵向显示?