Gui*_*uil 79 twitter-bootstrap ember.js bower ember-cli
我正在尝试在我当前的ember-cli项目中正确安装Twitter Bootstrap.我用凉亭安装了bootstrap:
bower install --save bootstrap
Run Code Online (Sandbox Code Playgroud)
现在这个库已下载到/ vendor/bootstrap/dist /(css | js | fonts) 我试过这里提到的:http : //ember-cli.com/#managing-dependencies 替换路径和css文件名但我得到了有关Brocfile.js文件的错误.我认为与示例相比,brocfile格式发生了太大的变化.
移动/ app/styles /目录中的样式表后,我还尝试使用/app/styles/app.css文件@import :
@import url('/assets/bootstrap.css');
@import url('/assets/bootstrap-theme.css');
Run Code Online (Sandbox Code Playgroud)
但它没有用.文件是可见的真正的dev服务器:http://localhost:4200/assets/bootstrap.css
有人可以在这扔我一块骨头吗?
谢谢
编辑:
ember -v
ember-cli 0.0.23
Run Code Online (Sandbox Code Playgroud)
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 });
};
Run Code Online (Sandbox Code Playgroud)
dre*_*ovi 68
BASH:
bower install --save bootstrap
Run Code Online (Sandbox Code Playgroud)
Brocfile.js:
app.import('vendor/bootstrap/dist/js/bootstrap.js');
app.import('vendor/bootstrap/dist/css/bootstrap.css');
Run Code Online (Sandbox Code Playgroud)
JS将被添加到默认链接的app.js中,并且将添加CSS assets/vendor.css
,截至5月14日,默认情况下也会添加.
供参考:http://www.ember-cli.com/#managing-dependencies
为了回应@ Joe关于字体和其他资产的问题,我无法获得推荐的app.import()方法来处理字体.我改为选择了merge-trees和static-compiler方法:
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]);
Run Code Online (Sandbox Code Playgroud)
Pat*_*tar 45
BASH:
bower install --save bootstrap
Run Code Online (Sandbox Code Playgroud)
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();
Run Code Online (Sandbox Code Playgroud)
小智 37
您可能需要查看ember-bootstrap,它将自动导入引导程序资产.
ember install ember-bootstrap
Run Code Online (Sandbox Code Playgroud)
此外,它还为您的应用程序添加了一套原生ember组件,这使得在ember中使用引导程序功能变得更加容易.看看,虽然我有点偏颇,因为我是它的作者!;)
Sam*_*off 23
加上ça更改...我现在使用ember-cli-bootstrap-sassy,它似乎带来了最小的瑕疵,同时仍让我自定义Bootstrap的变量.
您应该使用上面的Johnny解决方案而不是我最初提到的lib.我也喜欢ember-cli-bootstrap-sass,因为我可以直接在我的项目中自定义Bootstrap的变量.
如果您使用的是支持插件的ember-cli版本(我相信0.35+),您现在可以使用ember-cli-bootstrap包.从您应用的根目录开始,
npm install --save-dev ember-cli-bootstrap
Run Code Online (Sandbox Code Playgroud)
而已!
注意:正如@poweratom指出的那样,
ember-cli-bootstrap
是别人的库选择也包括bootstrap-for-ember.因此,这个lib可能与官方bootstrap版本不同步.但是,我仍然发现在新项目上快速进行原型设计是一个很好的方法!
ras*_*sta 15
$> bower install --save bootstrap
Run Code Online (Sandbox Code Playgroud)
随后添加以下两行到您的余烬-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');
Run Code Online (Sandbox Code Playgroud)
瞧,准备好了!
2015年8 月18日更新:适应Ember.js 1.13中引入的新计划
这就是我用Broccoli(支持Ember-cli)打包供应商CSS文件的方法.
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'
});
Run Code Online (Sandbox Code Playgroud)
当vendor
文件夹是我的包鲍尔住的地方.这assets
是我期待我的CSS生活的地方.我假设您已经使用Bower安装了Bootstrap,这是Ember-cli方式.
然后在我的index.html中,我只是引用该vendor.css
文件:
<link href="/assets/css/vendor.css" rel="stylesheet" type="text/css" media="all">
Run Code Online (Sandbox Code Playgroud)
干杯.
如果您正在使用SASS(可能是通过ember-cli-sass
),bower_components
则会自动添加到查找路径中.这意味着您可以只使用Bower并完全避免使用Brocfile/ember-cli-build文件.
使用Bower安装官方SASS版本的Bootstrap
bower install --save bootstrap-sass
Run Code Online (Sandbox Code Playgroud)
然后导入lib app.scss
.关于这个的好处是你可以在导入bootstrap之前自定义变量:
$brand-primary: 'purple';
@import 'bower_components/bootstrap-sass/assets/stylesheets/bootstrap';
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
44784 次 |
最近记录: |