Webpack 标准配置

// ${root}/webpack.config.js
module.exports = {
  entry: {
    app: 'app/web/page/app/index.js',  // js 文件需要自己实现 react.render 逻辑
    hello: 'app/web/page/hello/index.jsx'  // 自动使用 react-entry-template-loader 模板 
  }
};

Webpack entry 配置说明

  • *.jsx *文件后缀这种模式可以直接渲染 React Component组件,而无需编写 React.render 初始化代码,统一react-entry-template-loader 插件提供的模板进行 React 页面初始化。也就是如下标准的 React Component

可以直接渲染出完整的 HTM 网页。

//${root}/app/web/page/hello/index.jsx
export default class Hello extends Component {
  render() {
    return <h1>Egg React Server Render</h1>
  }
}
  • *.js *文件后缀这种模式需要自己编写 React.render 代码且需要自己判断 SSR 还是前端渲染
import React, { Component } from 'react';
import ReactDOM from 'react-dom';
import { AppContainer } from 'react-hot-loader';
import Layout from '../../component/layout.jsx';
import List from './componets/list';
import './index.css';

class ListPage extends Component {
  render() {
    return <div className="main">
        <div className="page-container page-component">
          <List list={this.props.list}></List>
        </div>
      </div>
  }
}

class ServerEntry extends Component {
  render() {
    return <Layout><ListPage {...this.props} /></Layout>;
  }
}

const clientEntry = () => {
  const root = document.getElementById('app');
  const state = window.__INITIAL_STATE__ || {};
  const render = () =>{
    ReactDOM.hydrate(EASY_ENV_IS_DEV ? <AppContainer><ListPage {...state}/></AppContainer> : <ListPage />, root);
  };
  if (EASY_ENV_IS_DEV && module.hot) {
    module.hot.accept();
  }
  render();
};

export default EASY_ENV_IS_NODE ? ServerEntry : clientEntry();

Author: sky
Reprint policy: All articles in this blog are used except for special statements CC BY 4.0 reprint polocy. If reproduced, please indicate source sky !
 Previous
服务端渲染模式 服务端渲染模式
目前 egg-view-react-ssr 支持 服务端渲染模式 和 前端渲染模式 两种渲染模式Egg + React 服务端 SSR 渲染模式这里服务端渲染指的是编写的 React 组件在 Node 服务端直接编译成完整的HTML, 然后直接输出给浏览器。MVVM 服务端渲染相比前端渲染,支...
2019-11-02 sky
Next 
社区作品 社区作品
easy-teamhttps://github.com/easy-team/egg-react-webpack-boilerplatehttps://github.com/easy-team/egg-react-typescript-boilerplateReact + Mobx 例子http...
2019-11-02 sky