Рекомендуемый способ включения бутстрап-библиотеки в приложение Ember.JS ember-cli
Я пытаюсь правильно установить Twitter Bootstrap в моем текущем проекте ember-cli.
Я установил бутстрап с беседкой:
bower install --save bootstrap
Теперь библиотека сглажена в /vendor/bootstrap/dist/ (css | js | fonts)
Я попробовал то, что упоминается здесь: http://ember-cli.com/#managing-dependencies
заменяя пути и имена файлов css, но я получаю ошибки в файле Brocfile.js. Я думаю, что формат brocfile слишком сильно изменился по сравнению с примером.
Я также попытался @import с файлом /app/styles/app.css после перемещения таблиц стилей в каталоге /app/styles/:
@import url('/assets/bootstrap.css');
@import url('/assets/bootstrap-theme.css');
Но это не сработало. Файлы видны истинным сервером dev: http://localhost:4200/assets/bootstrap.css
Может кто-то бросить мне кость здесь?
спасибо
Изменить:
ember -v
ember-cli 0.0.23
brocfile.js
/* global require, module */
var uglifyJavaScript = require('broccoli-uglify-js');
var replace = require('broccoli-replace');
var compileES6 = require('broccoli-es6-concatenator');
var validateES6 = require('broccoli-es6-import-validate');
var pickFiles = require('broccoli-static-compiler');
var mergeTrees = require('broccoli-merge-trees');
var env = require('broccoli-env').getEnv();
var getEnvJSON = require('./config/environment');
var p = require('ember-cli/lib/preprocessors');
var preprocessCss = p.preprocessCss;
var preprocessTemplates = p.preprocessTemplates;
var preprocessJs = p.preprocessJs;
module.exports = function (broccoli) {
var prefix = 'caisse';
var rootURL = '/';
// index.html
var indexHTML = pickFiles('app', {
srcDir: '/',
files: ['index.html'],
destDir: '/'
});
indexHTML = replace(indexHTML, {
files: ['index.html'],
patterns: [{ match: /\{\{ENV\}\}/g, replacement: getEnvJSON.bind(null, env)}]
});
// sourceTrees, appAndDependencies for CSS and JavaScript
var app = pickFiles('app', {
srcDir: '/',
destDir: prefix
});
app = preprocessTemplates(app);
var config = pickFiles('config', { // Don't pick anything, just watch config folder
srcDir: '/',
files: [],
destDir: '/'
});
var sourceTrees = [app, config, 'vendor'].concat(broccoli.bowerTrees());
var appAndDependencies = mergeTrees(sourceTrees, { overwrite: true });
// JavaScript
var legacyFilesToAppend = [
'jquery.js',
'handlebars.js',
'ember.js',
'ic-ajax/dist/named-amd/main.js',
'ember-data.js',
'ember-resolver.js',
'ember-shim.js',
'bootstrap/dist/js/bootstrap.js'
];
var applicationJs = preprocessJs(appAndDependencies, '/', prefix);
applicationJs = compileES6(applicationJs, {
loaderFile: 'loader/loader.js',
ignoredModules: [
'ember/resolver',
'ic-ajax'
],
inputFiles: [
prefix + '/**/*.js'
],
legacyFilesToAppend: legacyFilesToAppend,
wrapInEval: env !== 'production',
outputFile: '/assets/app.js'
});
if (env === 'production') {
applicationJs = uglifyJavaScript(applicationJs, {
mangle: false,
compress: false
});
}
// Styles
var styles = preprocessCss(appAndDependencies, prefix + '/styles', '/assets');
// Bootstrap Style integration
var bootstrap = pickFiles('vendor', {
srcDir: '/bootstrap/dist/css',
files: [
'bootstrap.css',
'bootstrap-theme.css'
],
destDir: '/assets/'
});
//var bootstrap = preprocessCss(appAndDependencies, '/vendor/bootstrap/dist/css', '/assets');
// Ouput
var outputTrees = [
indexHTML,
applicationJs,
'public',
styles,
bootstrap
];
// Testing
if (env !== 'production') {
var tests = pickFiles('tests', {
srcDir: '/',
destDir: prefix + '/tests'
});
var testsIndexHTML = pickFiles('tests', {
srcDir: '/',
files: ['index.html'],
destDir: '/tests'
});
var qunitStyles = pickFiles('vendor', {
srcDir: '/qunit/qunit',
files: ['qunit.css'],
destDir: '/assets/'
});
testsIndexHTML = replace(testsIndexHTML, {
files: ['tests/index.html'],
patterns: [{ match: /\{\{ENV\}\}/g, replacement: getEnvJSON.bind(null, env)}]
});
tests = preprocessTemplates(tests);
sourceTrees = [tests, 'vendor'].concat(broccoli.bowerTrees());
appAndDependencies = mergeTrees(sourceTrees, { overwrite: true });
var testsJs = preprocessJs(appAndDependencies, '/', prefix);
var validatedJs = validateES6(mergeTrees([app, tests]), {
whitelist: {
'ember/resolver': ['default'],
'ember-qunit': [
'globalize',
'moduleFor',
'moduleForComponent',
'moduleForModel',
'test',
'setResolver'
]
}
});
var legacyTestFiles = [
'qunit/qunit/qunit.js',
'qunit-shim.js',
'ember-qunit/dist/named-amd/main.js'
];
legacyFilesToAppend = legacyFilesToAppend.concat(legacyTestFiles);
testsJs = compileES6(testsJs, {
// Temporary workaround for
// https://github.com/joliss/broccoli-es6-concatenator/issues/9
loaderFile: '_loader.js',
ignoredModules: [
'ember/resolver',
'ember-qunit'
],
inputFiles: [
prefix + '/**/*.js'
],
legacyFilesToAppend: legacyFilesToAppend,
wrapInEval: true,
outputFile: '/assets/tests.js'
});
var testsTrees = [qunitStyles, testsIndexHTML, validatedJs, testsJs];
outputTrees = outputTrees.concat(testsTrees);
}
return mergeTrees(outputTrees, { overwrite: true });
};
Ответы
Ответ 1
Возможно, вы захотите проверить ember-bootstrap, который автоматически импортирует загрузочные ресурсы.
ember install ember-bootstrap
Кроме того, он добавляет в приложение набор собственных компонентов ember, которые значительно упрощают работу с функциями бутстрапа в ember. Проверьте это, хотя я немного предвзятый, так как я автор этого!;)
Ответ 2
BASH:
bower install --save bootstrap
Brocfile.js:
app.import('vendor/bootstrap/dist/js/bootstrap.js');
app.import('vendor/bootstrap/dist/css/bootstrap.css');
JS будет добавлен в app.js, связанный по умолчанию, и CSS будет добавлен в assets/vendor.css
, который с 14 мая также добавляется по умолчанию.
Для справки: http://www.ember-cli.com/#managing-dependencies
В ответ на вопрос @Joe, окружающий шрифты и другие активы, мне не удалось заставить рекомендуемый метод app.import() работать с шрифтами. Вместо этого я выбрал метод слияния и статический компилятор:
var mergeTrees = require('broccoli-merge-trees');
var pickFiles = require('broccoli-static-compiler');
var extraAssets = pickFiles('vendor/bootstrap/dist/fonts',{
srcDir: '/',
files: ['**/*'],
destDir: '/fonts'
});
module.exports = mergeTrees([app.toTree(), extraAssets]);
Ответ 3
BASH:
bower install --save bootstrap
Brocfile.js:
/* global require, module */
...
app.import('bower_components/bootstrap/dist/css/bootstrap.css');
app.import('bower_components/bootstrap/dist/css/bootstrap.css.map', {
destDir: 'assets'
});
app.import('bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.eot', {
destDir: 'fonts'
});
app.import('bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.ttf', {
destDir: 'fonts'
});
app.import('bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.svg', {
destDir: 'fonts'
});
app.import('bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.woff', {
destDir: 'fonts'
});
app.import('bower_components/bootstrap/dist/fonts/glyphicons-halflings-regular.woff2', {
destDir: 'fonts'
});
app.import('bower_components/bootstrap/dist/js/bootstrap.js');
module.exports = app.toTree();
Ответ 4
Обновление 3/30/15
plus ça change... Теперь я использую ember-cli-bootstrap-sassy, он, как представляется, приносит минимум минимума, хотя и позволяет мне настраивать переменные Bootstrap.
Обновление 1/22/15
Вероятно, вы должны использовать решение Johnny выше, а не lib, о котором я упоминал ранее. Мне также нравится ember-cli-bootstrap-sass, потому что я могу настраивать переменные Bootstrap непосредственно в моем проекте.
Оригинал 7/11/14
Если вы используете версию ember-cli, поддерживающую аддоны (на мой взгляд, 0.35+), теперь вы можете использовать ember-cli-bootstrap. Из корня вашего приложения,
npm install --save-dev ember-cli-bootstrap
Что это!
Примечание: как указывает @poweratom, ember-cli-bootstrap
- это некоторая библиотека, в которую также входит bootstrap-for-ember. Таким образом, эта библиотека может выйти из синхронизации с официальной версией бутстрапа. Тем не менее, я по-прежнему считаю это отличным способом быстрого прототипирования нового проекта!
Ответ 5
$> bower install --save bootstrap
Затем добавьте следующие две строки в ember-cli-builds.js (или Brocfile.js, если вы используете более старую версию Ember.js):
app.import(app.bowerDirectory + '/bootstrap/dist/js/bootstrap.js');
app.import(app.bowerDirectory + '/bootstrap/dist/css/bootstrap.css');
И вуаля, готов к работе!
обновлено 08/18/2015: адаптировано к новой схеме, введенной в Ember.js 1.13
Ответ 6
Вот как я упаковываю файлы CSS поставщика с помощью Broccoli (который лежит в основе Ember-cli).
var vendorCss = concat('vendor', {
inputFiles: [
'pikaday/css/pikaday.css'
, 'nvd3/nv.d3.css'
, 'semantic-ui/build/packaged/css/semantic.css'
]
, outputFile: '/assets/css/vendor.css'
});
Где находится папка vendor
, где хранятся мои пакеты Bower. И assets
- это то место, где я ожидаю, что мой CSS будет жить. Я предполагаю, что вы установили Bootstrap, используя Bower, который является способом Ember-cli.
Затем в моем index.html я просто ссылаюсь на файл vendor.css
:
<link href="/assets/css/vendor.css" rel="stylesheet" type="text/css" media="all">
Приветствия.
Ответ 7
Если вы используете SASS (возможно, через ember-cli-sass
), bower_components
автоматически добавляется к пути поиска. Это означает, что вы можете просто использовать Bower и вообще избегать файла Brocfile/ember-cli-build.
Установите официальную версию Bootstrap SASS с Bower
bower install --save bootstrap-sass
затем импортируйте lib в app.scss
. Самое приятное в этом - вы можете настроить переменные перед импортом bootstrap:
$brand-primary: 'purple';
@import 'bower_components/bootstrap-sass/assets/stylesheets/bootstrap';
Ответ 8
bower install --save bootstrap
в brocfile.js
:
app.import('bower_components/bootstrap/dist/js/bootstrap.js');
app.import('bower_components/bootstrap/dist/css/bootstrap.css');
Ответ 9
На терминале (для тех, кто использует Node Package Manager)
npm install bootstrap --save
Использование ember-cli для импорта установленного загрузчика
Откройте файл ember-cli-build.js
module.exports = function(defaults) {
let app = new EmberApp(defaults, {
// Add options here
});
app.import('node_modules/bootstrap/dist/css/bootstrap.min.css');
app.import('node_modules/bootstrap/dist/js/bootstrap.min.js');
Это будет сделано, если загрузчик установлен через установщик NPM.
Не делайте этого:
app.import('./node_modules/bootstrap/dist/css/bootstrap.min.css');
app.import('./node_modules/bootstrap/dist/js/bootstrap.min.js');