0

我正在使用 ReactJS.net(服务器端渲染),当我在 Webpack 中使用 jquery 时出现错误,这是我的错误

将“Components.ToDoListSkeleton”渲染为“react_0LmYYfSk30qdrKJQe4McUQ”时出错:错误:jQuery 需要一个带有 module.exports 文档的窗口(脚本文档 [5]:51:87)-> module.exports=global.document?factory(global ,true):function(w){if(!w.document){throw new Error("jQuery 需要一个带有文档的窗口");}return factory(w);};}else {factory(global);} // 如果尚未在 ReactCompositeComponentMixin._constructComponentWithoutOwner (Script Document [2]:8271:28) at ReactCompositeComponentMixin._constructComponent (Script Document [2]) 处的新 ToDoListSkeleton (Script Document [5]:26:903) 处定义窗口,则传递此参数: 8253:22) 在 ReactCompositeComponentMixin.mountComponent (脚本文档 [2]:8172:22) 在 ReactReconciler.mountComponent (脚本文档 [2]:1977:36) 在脚本文档 [2]:19549:37 在 Mixin.perform (脚本文档 [2]:3788:21) 在 renderToStringImpl (脚本文档 [2]:19544:25) 在 renderToString (脚本文档 [2]:19574 :11) 在脚本文档 [7] [temp]:1:16 行:19549 列:37

这是我的 webpack 配置

"use strict";

var path = require('path');
var WebpackNotifierPlugin = require('webpack-notifier');
var webpack = require("webpack");
module.exports = {
    context: path.join(__dirname, 'Content'),
    entry: {
        server: './server'
    },
    output: {
        path: path.join(__dirname, 'build'),
        filename: '[name].bundle.js'
    },
    module: {
        loaders: [
            // Transform JSX in .jsx files
            { test: /\.jsx$/, loader: 'jsx-loader?harmony' },
            { test: require.resolve("jquery"), loader: "expose?$!expose?jQuery" }
        ]
    },
    resolve: {
        // Allow require('./blah') to require blah.jsx
        extensions: ['', '.js', '.jsx']
    },
    externals: {
        //// Use external version of React (from CDN for client-side, or
        //// bundled with ReactJS.NET for server-side)
        react: "React"
    },
    plugins: [
      new WebpackNotifierPlugin(),
      new webpack.ProvidePlugin({
          $: "jquery", 
          jQuery: "jquery", 
          "window.jQuery": "jquery",    
      })
    ]
};

任何帮助或建议将不胜感激,谢谢。

4

1 回答 1

-1

jQuery 仅设计用于浏览器,支持服务器端渲染。您需要从要在服务器端使用的任何代码中删除 jQuery。

于 2016-08-31T05:20:41.257 回答