将LoDash与EmberCLI一起使用
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了将LoDash与EmberCLI一起使用相关的知识,希望对你有一定的参考价值。
有没有人有一个使用Ember-CLI使用LoDash构建的(简单)ember-app项目的工作示例? (例如:我想在我的路由和控制器中使用lodash,_.someLodashFunc)。
我没有在网上看到任何关于如何做到这一点的明确,逐步解释的线索/文章。
如果可能的话,使用lodash v3.0.0(我使用的是最新的ember-cli,v0.1.9)。
谢谢,拉卡
我发现了如何,你需要生成一个自定义的lodash(“lodash modern”)。使用lodash-cli:https://lodash.com/custom-builds
在命令控制台上输入:lodash modern ...,然后你会得到一个生成的javascript文件:lodash.custom.js
将该文件放在ember-cli项目的“vendor”目录下。
修改Brocfile,添加:
app.import('vendor/lodash.custom.js', {
'lodash': [
'default'
]
});
就是这样......你不必在你的任何js文件中执行“import _ from'loodash'”。事实上,不要这样做(你会得到一个错误)。 _ var很容易获得。
例如,我有一个这样的Route对象:
import Ember from 'ember';
export default Ember.Route.extend({
model: function() {
console.log('hohoho: ' + _.chunk(['a', 'b', 'c', 'd'], 2));
return Ember.Object.create({name: 'Raka'});
}
});
我可以看到hohoho:,b,c,当我访问那条路线时,我在javascript控制台中打印出来。
更正
你真的不需要那个lodash-cli。
我试过这种方式(我想更合适):
- 凉亭安装lodash --save
- 在Brocfile.js中,有这一行:app.import('bower_components / lodash / lodash.js');
而已。 _在路由器/控制器中自动可用。
我对d3做了同样的事情:
- 凉亭安装d3 - 保存
- 在Brocfile.js中,有这一行:app.import('bower_components / d3 / d3.js');
名为'd3'的变量可自动使用。
新增相关链接:
- Import custom library in ember-cli
- http://tiku.io/questions/2866484/how-to-include-a-local-javascript-im-ember-cli-application(引用:如果您不需要在vendor.js文件中缩小它们,可以将它们放在public / js中,然后将其作为普通脚本文件包含在app / index.html中。我将此方法用于某些像moment.js这样的库。在构建期间,公用文件夹会直接复制到您的站点根目录。)
- Proper way to access third party libs such as D3 in Ember CLI?
您可以使用现成的东西:https://github.com/levanto-financial/ember-lodash或手动完成。
我没有任何示例,但它应该像修改这3个文件一样简单:
bower.json
只需添加该行
"lodash": "4.16.4",
到您的dependencies
并在命令行中运行bower install
。
或者,您可以通过bower
安装它:
$ bower install lodash --save
Brocfile.js
为了被Broccoli包括在内:
app.import('bower_components/lodash/lodash.js');
在var app = new EmberApp();
之后添加这个
.jshint.rc
添加行:
"_": true,
在predef
部分的某个地方(如果你不想看到像_ is undefined
这样的警告)。
我没有测试过,但我希望它有帮助:)
您可以使用Bower安装最新的稳定版本。在项目的根目录中,运行:
bower install lodash --save
然后使用Brocolli导入它,在Brocfile.json
之后的var app = new EmberApp( ...
中添加这一行:
app.import('bower_components/lodash/lodash.js');
ember-lodash addon将是最好的宠物。(https://www.npmjs.com/package/ember-lodash)
安装插件:ember install ember-lodash
仅包含字符串函数
import _string from 'lodash/string';
let truncatedString = _string.trunc(rawString);
要包含整个lodash库,
import _ from 'lodash/lodash';
let truncatedString = _.trunc(rawString);
以上是关于将LoDash与EmberCLI一起使用的主要内容,如果未能解决你的问题,请参考以下文章
Android:将 savedInstanceState 与片段一起使用
将 GraphQL 片段与 Apollo Hooks 一起使用时出错