Webpack
Узнайте, как включить Bootstrap в свой проект с помощью Webpack.
Установка
Установка Bootstrap как модуль Node.js с использованием npm.
Импорт JavaScript
Импортируйте Bootstrap JavaScript, добавив эту строку в точку входа Вашего приложения (обычно index.js
или app.js
):
import 'bootstrap';
Или можете импортировать плагины по отдельности по мере необходимости:
import 'bootstrap/js/dist/util';
import 'bootstrap/js/dist/alert';
...
Bootstrap зависит от jQuery и Popper, которые указаны в свойстве peerDependencies
; это означает, что Вам нужно будет обязательно добавить их оба в Ваш package.json
, используя npm install --save jquery popper.js
.
Импорт стилей
Импорт предварительно скомпилированного Sass
Для полного функционала и возможности настройки Bootstrap используйте исходные файлы при «сборке» вашего проекта.
Сперва создайте файл _custom.scss
и переопределите значения встроенных переменных. Затем используйте свой основной файл sass для импорта пользовательских переменных, за которым следует Bootstrap:
@import "custom";
@import "~bootstrap/scss/bootstrap";
Для компиляции удостоверьтесь, что установлены все требуемые загрузчики: sass-loader, postcss-loader с Autoprefixer. С минимальными настройками, ваша конфигурация вебпака должна включать подобное правило:
...
{
test: /\.(scss)$/,
use: [{
loader: 'style-loader', // вставить CSS на страницу
}, {
loader: 'css-loader', // переводит CSS в модули CommonJS
}, {
loader: 'postcss-loader', // Выполнить действия postcss
options: {
plugins: function () { // плагины postcss, можно экспортировать в postcss.config.js
return [
require('autoprefixer')
];
}
}
}, {
loader: 'sass-loader' // компилирует Sass в CSS
}]
},
...
Импорт скомпилированного CSS
В качестве альтернативы Вы можете использовать готовый к использованию CSS Bootstrap, просто добавив эту строку в точку входа Вашего проекта:
import 'bootstrap/dist/css/bootstrap.min.css';
В этом случае Вы можете использовать существующее правило для css
без каких-либо специальных изменений в конфигурации webpack, за исключением того, что Вам не нужен sass-loader
только style-loader и css-loader.
...
module: {
rules: [
{
test: /\.css$/,
use: ['style-loader', 'css-loader']
}
]
}
...