javascript - React 项目中的 Bootstrap 需要 jQuery

标签 javascript jquery reactjs twitter-bootstrap-3

我正在开发一个 React.js 项目,我没有使用 React-Bootstrap,而是将 Bootstrap 的 CSS 加载到我的项目中。我现在需要导入 jQuery,以便我可以使用下拉菜单等。

入口点文件 (index.js) - 希望它能工作

'use strict'
import React from 'react'
import { Route, Router, IndexRoute, browserHistory } from 'react-router'
import { render } from 'react-dom'

// Pages
import Main from './pages/main/main'
import Home from './pages/home/home'
import About from './pages/about/about'
window.jQuery = window.$ = require('jquery/dist/jquery.min')
import '../node_modules/bootstrap/dist/css/bootstrap.min.css'
import '../node_modules/bootstrap/dist/js/bootstrap.min.js'

render((
  <Router history={browserHistory}>
    <Route name='home' path='/' component={Main}>
      <IndexRoute component={Home} />
      <Route name='about' path='about' component={About} />
    </Route>
  </Router>), document.getElementById('app'))

网页包文件

'use strict'
const path = require('path')
const webpack = require('webpack')

module.exports = {
  entry: [
    './browser/index'
  ],
  output: {
    path: path.join(__dirname, 'public', 'js'),
    filename: 'bundle.js',
    publicPath: '/public/js/'
  },
  plugins: [
    new webpack.ProvidePlugin({
      $: 'jquery',
      jQuery: 'jquery'
    }),
    new webpack.NoErrorsPlugin()
  ],
  module: {
    loaders: [
      { test: /\.js$/,
        loader: 'babel-loader',
        query: {
          presets: [ 'es2015', 'react' ]
        },
        include: path.join(__dirname, 'browser')
      },
      { test: /\.css$/, loader: 'style-loader!css-loader' },
      {test: /\.eot(\?v=\d+\.\d+\.\d+)?$/, loader: 'file'},
      {test: /\.(woff|woff2)$/, loader: 'url?prefix=font/&limit=5000'},
      {test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/, loader: 'url?limit=10000&mimetype=application/octet-stream'},
      {test: /\.svg(\?v=\d+\.\d+\.\d+)?$/, loader: 'url?limit=10000&mimetype=image/svg+xml'},
      { test: require.resolve('jquery'), loader: 'imports?jQuery=jquery' }
    ]
  }
}

错误出现在 Chrome 开发工具中:“Bootstrap 的 Javascript 需要 jQuery”。我想知道我是否在 webpack 文件中遗漏了一些关于加载器的内容,或者是否需要在入口文件中添加 import 语句?

最佳答案

请确保您已安装“imports-loader”(npm install --save imports-loader)。在 module.exports 中试试这个:

{ test: /bootstrap.+\.(jsx|js)$/, loader: 'imports?jQuery=jquery,$=jquery,this=>window' }

我在这里找到了关于它的非常好的帖子:http://reactkungfu.com/2015/10/integrating-jquery-chosen-with-webpack-using-imports-loader/

关于javascript - React 项目中的 Bootstrap 需要 jQuery,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37932454/

相关文章:

javascript - 为什么 "new Image()"会立即触发网络请求,而 "createElement('脚本')”却不会?

javascript - 从嵌入的 IFRAME 内的嵌入 IFRAME 转到主浏览器窗口

javascript - 如何使用正确的缩进打印 error.stack,而不使用换行符

javascript - 调用 Google maps infowindow.open 会导致网站向下滚动到 infowindow

javascript - 即使已经有一个监听器,我也可以在函数中放置一个开关吗?

javascript - Jquery 无法处理以下代码 :

jQuery:元素偏移量()坐标相对于另一个元素

javascript - 将无状态组件拆分为更小的部分

javascript - 访问React中的chart.js组件实例

javascript - NextJS 项目中使用的 ReactJS 库表示不是构造函数