【问题标题】:Webpack and Bootstrap problemsWebpack 和 Bootstrap 问题
【发布时间】:2016-12-01 14:28:50
【问题描述】:

我对 Webpack 和 NodeJS 还很陌生,所以我做一些简单的测试只是为了学习。我正在开发一个新网站,这是我的想法:

我有一个 vendor.ts 文件,我可以将所有供应商的 js 和 css 放入其中:

    // Angular 2
import '@angular/platform-browser';
import '@angular/platform-browser-dynamic';
import '@angular/core';
import '@angular/common';
import '@angular/http';
import '@angular/router';

// RxJS
import 'rxjs';

// Bootstrap
import 'bootstrap';
import '../node_modules/bootstrap/dist/css/bootstrap.css';

//jQuery
import 'jquery';

所以,这是我的 webpack 配置:

var webpack = require('webpack');
var HtmlWebpackPlugin = require('html-webpack-plugin');
var ExtractTextPlugin = require('extract-text-webpack-plugin');
var helpers = require('./helpers');


module.exports = {
  entry: {
    'polyfills': './src/polyfills.ts',
    'vendor': './src/vendor.ts',
    'app': './src/app/main.ts'
  },

  output: {
    path: './src/public/',
    publicPath: 'http://localhost:3000/',
    filename: '[name].js',
    chunkFilename: '[id].chunk.js'
  },

  devtool: 'cheap-module-eval-source-map',

  resolve: {
    extensions: ['', '.js', '.ts']
  },

  module: {
    loaders: [
      {
        test: /\.ts$/,
        loaders: ['ts', 'angular2-template-loader']
      },
      {
        test: /\.html$/,
        loader: 'html'
      },
      {
        test: /\.(png|jpe?g|gif|svg|woff|woff2|ttf|eot|ico)$/,
        loader: 'file?name=assets/[name].[hash].[ext]'
      },
      { 
        test: /\.css$/, 
        loader: ExtractTextPlugin.extract({fallbackLoader: "style-loader", loader: "css-loader?souceMap"}) 
      },
    ],
    plugins: [
        new ExtractTextPlugin("[name].css")
    ]
  },

  plugins: [
    new webpack.optimize.CommonsChunkPlugin({
      name: ['app', 'vendor', 'polyfills']
    }),

    new HtmlWebpackPlugin({
      template: './src/index.html'
    }),

    new webpack.ProvidePlugin({
        $: "jquery",
        jQuery: "jquery",
        "window.jQuery": "jquery"
    })  
  ]
};

当我运行“webpack”命令时,它会抛出错误:

./src/vendor.ts 中的错误未找到模块:错误:无法解析 /home/xxxxx/xxxx/xxxxx-xxxx/src @ 中的模块'[object Object]' ./src/vendor.ts 13:0-59

有人可以帮助我吗?

谢谢!

编辑:可以在https://github.com/webpack/extract-text-webpack-plugin/issues/215找到解决方案

【问题讨论】:

    标签: node.js angular webpack


    【解决方案1】:

    这样做是错误的import '../node_modules/bootstrap/dist/css/bootstrap.css'。 对于非代码文件,您必须改用require,例如require( '../node_modules/bootstrap/dist/css/bootstrap.css')

    这篇文章可能会有所帮助https://webpack.github.io/docs/stylesheets.html

    【讨论】:

    • 但是 webpack 尝试导入的每个 css 文件都会出现此错误。我的 app.component.ts 使用 app.component.css 并得到同样的错误..
    • 在尝试为 require 更改导入后,仍然出现错误:(
    • 我想我找到了原因 - 您应该将配置中的 new ExtractTextPlugin("[name].css") 行移动到所有插件(new webpack.optimize.CommonsChunkPlugin 所在的位置),因为现在您正在尝试将 'plugins' 属性添加到 ' module' 属性而不是 config 的所有插件
    • Oleg,感谢您的回复,但修改后仍然报错:-(
    • 最后我得到了它的工作:github.com/webpack/extract-text-webpack-plugin/issues/215 刚刚将我的 css 加载器更改为:loader: ExtractTextPlugin.extract('style', 'css-loader!postcss-loader') 如问题中所述。
    【解决方案2】:

    【讨论】:

    • 你能具体说明你做了什么吗?
    猜你喜欢
    • 2021-08-21
    • 2018-02-16
    • 1970-01-01
    • 2022-01-09
    • 2019-05-30
    • 1970-01-01
    • 1970-01-01
    • 2014-08-10
    • 2013-09-28
    相关资源
    最近更新 更多