1

我正在开发一个 chrome 扩展。我将 boostrap 3 用于 UI。

doctype html

html
  head
    meta(charset='UTF-8')
    title (Boilerplate Popup)
    link(rel="stylesheet", href="https://maxcdn.bootstrapcdn.com/bootstrap/latest/css/bootstrap.min.css")
    style.
      body { width: 500px; }

  body
    #root
    script(src=env == 'prod' ? '/js/ext.bundle.js' : 'http://localhost:3000/js/ext.bundle.js')

这是我习惯于包含boostrap的方式。
localhost:3000 是使用 webpack 网络服务器创建的服务器。

此时一切正常,这是一个截图:

在此处输入图像描述

但我不希望我的 chrome 扩展依赖于网络,所以我决定使用以下方式下载 boostrap:

npm install boostrap其中已经下载了boostrap 3。我还决定使用webpack来加载boostrap.min.css。

  module: {
    loaders: [{
      test: /\.js$/,
      loader: 'babel',
      exclude: /node_modules/,
      query: {
        presets: ['react-hmre']
      }
    }, {
      test: /\.css$/,
      loaders: [
        'style',
        'css?modules&sourceMap&importLoaders=1&localIdentName=[name]__[local]___[hash:base64:5]',
        'postcss'
      ]
    },
    {test: /\.(woff|woff2)(\?v=\d+\.\d+\.\d+)?$/, loader: 'url?limit=10000&mimetype=application/font-woff'},
    {test: /\.ttf(\?v=\d+\.\d+\.\d+)?$/, loader: 'url?limit=10000&mimetype=application/octet-stream'},
    {test: /\.eot(\?v=\d+\.\d+\.\d+)?$/, loader: 'file'},
    {test: /\.svg(\?v=\d+\.\d+\.\d+)?$/, loader: 'url?limit=10000&mimetype=image/svg+xml'}]
  }

我没有更改 css 加载程序(来自样板文件),但我添加了 web 字体和 svg 的加载程序。

最后,我在 javascript 入口点中包含了 boostrap.min.css : import 'bootstrap/dist/css/bootstrap.min.css';

现在,这就是我的扩展的样子:

在此处输入图像描述

我认为加载了boostrap的一部分(因为第二版中的链接看起来与第一版中的链接相同。但显然,其他组件没有加载。

我也使用 react-boostrap。

谢谢

4

3 回答 3

3

我在评论中的想法是对的,css?module local load boostrap。我更改了导入:

import '!style!css!bootstrap/dist/css/bootstrap.min.css';

它有效

于 2016-08-17T19:42:15.180 回答
2

对于WEBPACK 2,(即在安装了所有必要的依赖项之后)您可以包括引导程序,如下所示:-

  1. 在 webpack.config.js 中添加 css 加载器

    {
        test: /\.css$/, 
        use: [
            {
                loader: 'style-loader'
            },
            {
                loader: 'css-loader',
                options: {
                    importLoaders: 1
                }
            }
        ]
    }
  2. 然后,在入口点脚本中导入bootstrap(即我项目中的index.js或app.js,index.js)

    import '!style-loader!css-loader!bootstrap/dist/css/bootstrap.css';

需要详细资料!!! 更多细节在这里

于 2017-03-20T08:22:10.120 回答
0
npm install bootstrap ;

和 :

调整css加载器如下:

       {
            test: /\.css$/,
            loaders: ['style', 'css'],
        }

并且,导入引导程序:

import Bootstrap from 'bootstrap/dist/css/bootstrap.css';
于 2016-09-10T00:17:39.210 回答