i'm trying bundle react app using webpack client-side rendering , including bundle.js
in tag. however, whenever run app keep getting 404 (not found) bundle.js
. here webpack.config.js:
webpack.config.js
const path = require('path'); const config = { entry: ['babel-polyfill', './views/index.jsx'], output: { path: path.resolve(__dirname, 'public'), filename: 'bundle.js', publicpath: '/' }, module: { rules: [ { test: /\.(jsx|js)$/, exclude: /node_modules/ , use: 'babel-loader' } ] } }; module.exports = config;
./views/index.jsx
points main template file looks this:
index.jsx
import react 'react'; import layout './layout.jsx'; import cube './components/cube/cube.jsx'; class index extends react.component { render() { return ( <layout title={this.props.title}> <cube /> </layout> ); } } export default index;
where layout.jsx
i'm including <script src="/public/bundle.js">
:
layout.jsx
import react 'react'; class layout extends react.component { render() { return ( <html> <head> <title>{this.props.title}</title> <script type="text/javascript" src="/public/bundle.js"></script> </head> <body> {this.props.children} </body> </html> ); } } export default layout;
can me understand why isn't working? full project if helps: https://github.com/markscode/personalwebsite
i think might have me using server-side rendering express-react-views
package wrong?
thanks!
it doesn't telling express serve public folder @ all. you'll need explicitly let express know public folder should serve static files, so:
app.use(express.static('public'))
docs here: https://expressjs.com/en/starter/static-files.html
Comments
Post a Comment