V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
CodingPuppy
V2EX  ›  程序员

前端小白求帮助

  •  
  •   CodingPuppy · 2017-07-13 19:37:33 +08:00 · 1945 次点击
    这是一个创建于 2681 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我在做一个 React library,通过 webpack 打包。在 webpack.config 中配置不打包 react 和 react-dom。

    var webpackConfig = {
      entry: './components',
      output: { 
        path: path.resolve(__dirname, 'dist'),
        filename: 'react-table.js',
        library: 'ReactReport',
        libraryTarget: 'umd'
      },
      module: {
        loaders: [
          {
            test: /.js?$/,
            loader: 'babel-loader',
            exclude: /node_modules/,
            query: {
              presets: ['es2015', 'react']
            }
          }
        ]
      },
      externals: {
        react: {
          root: 'React',
          commonjs2: 'react',
          commonjs: 'react',
          amd: 'react'
        },
        'react-dom': {
          root: 'ReactDOM',
          commonjs2: 'react-dom',
          commonjs: 'react-dom',
          amd: 'react-dom'
        }
      },
    

    在 webpack 中,暴露 react-table 中的 ReactReport 对象到全局。 然后在 html 中这么写,

    <body>
      <div id="root">
      </div>
    
      <script src="../dist/react-table.js"></script>
      <script src="https://cdn.bootcss.com/react/15.6.1/react.min.js"></script>
      <script src="https://cdn.bootcss.com/react/15.6.1/react-dom.min.js"></script>
      <script>
        var ReactReport = ReactReport.ReactReport;
        var serverData = {someData};
        var App = React.createElement(
          ReactReport,
          { data: serverData }
        );
        ReactDOM.render(App, document.getElementById('root'));
      </script>
    
    </body>
    

    运行会报错,找不到 React.Component,

    Cannot read property 'Component' of undefined
    

    我在 html 中不是写了 cdn 的 React 了吗?有朋友知道为什么么? google 一下午了。。

    完全前端新手,webpack 基本是混沌状态

    2 条回复    2017-07-13 20:01:35 +08:00
    CodingPuppy
        1
    CodingPuppy  
    OP
       2017-07-13 19:50:52 +08:00
    查了一下午,v 站提完问题,休息了一会。发现是这个问题:
    ```
    <script src="../dist/react-table.js"></script>
    <script src="https://cdn.bootcss.com/react/15.6.1/react.min.js"></script>
    <script src="https://cdn.bootcss.com/react/15.6.1/react-dom.min.js"></script>
    ```
    要把 react 和 react-dom 写到最前面。。。

    唉,幸亏我不是前端工程师,这个领域的坑比 Android 什么的多到不知道哪里去了
    tnaxismdc
        2
    tnaxismdc  
       2017-07-13 20:01:35 +08:00 via Android
    是的,引用顺序很重要
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2618 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 15:53 · PVG 23:53 · LAX 07:53 · JFK 10:53
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.