- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在创建我的第一个 nodejs/sails.js 项目,我想为 3 种不同的场合使用 3 种不同的布局:
frontend_layout.ejs
admin_layout.ejs
mobile_layout.ejs
我在 sailsProject/views/中创建了 3 个文件夹,分别是 admin_pages、mobile_pages 和 frontend_pages,这 3 个 layout.ejs 文件分别驻留在这些文件夹中,但无论我加载哪个布局,它总是包含所有 css/assets/js 和 assets/styles 中的 js 文件。我知道我需要对 pipeline.js 做些什么,但具体怎么做呢?我在 grunt 方面效率不高,所以如果有人能指出我需要修改哪些配置文件以及如何修改,我将不胜感激……谢谢!
最佳答案
我希望在我的项目中有一些非常相似的东西,除了我还想利用 Sail 很酷的内置功能自动最小化/丑化 javascript 文件以在各种布局中使用不同的 javascript 文件集.此答案仅涉及 JS 文件,但您可以进行类似的更改以支持 CSS 文件的相同概念。
在我的项目中,我有 2 个不同的布局——layout.ejs 和 layoutadmin.ejs。我创建了一个新的/assets/jsadmin 文件夹,其中包含我的管理 javascript 文件。我保留了 sails 现有的/assets/js 文件夹,以保存公共(public)网页的 javascript 文件。
我的目标是将/assets/js 文件夹内容插入到这些标签之间(sails 默认执行此操作,这些标签用于 layout.ejs 文件):
<!--SCRIPTS-->
<!--SCRIPTS END-->
虽然/assets/jsadmin 文件夹内容被插入到这些标签之间(我编造了这些“自定义”标签名称,它们用于 layoutadmin.ejs 文件中。我将在这个答案的其余部分):
<!--SCRIPTS_ADMIN-->
<!--SCRIPTS_ADMIN END-->
我创建了这个 here 的完整代码示例演示.
为了发展...(风 sails 升降机),我进行了修改,以便风 sails 在升降时使用 assets/jsadmin js 文件填充我的自定义标签。
我通过添加一个名为 jsAdminFilesToInject 的新变量修改了 tasks/pipeline.js,它与现有的 jsFilesToInject 非常相似,只是它从 jsAdmin 文件夹中收集 js 文件。
var jsAdminFilesToInject = [
// Load sails.io before everything else
//'jsAdmin/dependencies/sails.io.js',
// Dependencies like jQuery, or Angular are brought in here
'jsAdmin/dependencies/**/*.js',
// All of the rest of your client-side js files
// will be injected here in no particular order.
'jsAdmin/**/*.js'
];
注意:我还必须在 pipeline.js 文件的底部导出这个新变量。
module.exports.jsAdminFilesToInject = jsAdminFilesToInject.map(function(path) {
return '.tmp/public/' + path;
});
我修改了 tasks/config/sails-linker.js,添加了一个新的 devJsAdmin 任务,它在其中查找标签并调用在上面的 pipeline.js 文件中添加的新 .jsAdminFilesToInject。
devJsAdmin: {
options: {
startTag: '<!--SCRIPTS_ADMIN-->',
endTag: '<!--SCRIPTS_ADMIN END-->',
fileTmpl: '<script src="%s"></script>',
appRoot: '.tmp/public'
},
files: {
'.tmp/public/**/*.html': require('../pipeline').jsAdminFilesToInject,
'views/**/*.html': require('../pipeline').jsAdminFilesToInject,
'views/**/*.ejs': require('../pipeline').jsAdminFilesToInject
}
},
我在 tasks/register/linkAssets.js 文件中添加了一个新的任务步骤,它调用上面添加的 devJsAdmin。
'sails-linker:devJsAdmin',
要测试,请在演示模式下运行 sails:
sails lift
浏览到 http://localhost:1337/home - 你会看到它正在使用 layout.ejs 模板,查看源代码会在底部显示以下内容(从 js 文件夹中提取的文件):
<!--SCRIPTS-->
<script src="/js/dependencies/sails.io.js"></script>
<script src="/js/jquery-1.10.2.js"></script>
<!--SCRIPTS END-->
浏览到 http://localhost:1337/admin - 你会看到它正在使用 layoutadmin.ejs 模板,查看源代码将在源代码底部显示以下内容(从 jsAdmin 文件夹中提取的文件):
<!--SCRIPTS_ADMIN-->
<script src="/jsAdmin/dependencies/jquery-1.10.2.js"></script>
<script src="/jsAdmin/knockout-3.3.0.debug.js"></script>
<!--SCRIPTS_ADMIN END-->
用于生产...(sails lift --prod),我想做与开发相同的事情,除了我首先想连接和丑化我的新 SCRIPTS_ADMIN 标签中的生产 javascript。
我在 grunt tasks/config/concat.js 文件中添加了一个新的 jsAdmin 部分,该部分从之前添加的 jsAdminFilesToInject 中拉入 pipeline.js 中的文件以生成 concat/productionAdmin.js 输出文件。
jsAdmin: {
src: require('../pipeline').jsAdminFilesToInject,
dest: '.tmp/public/concat/productionAdmin.js'
},
我在 grunt tasks/config/uglify.js 文件中添加了一个新的 distAdmin 部分,它通过生成一个新的 min/productionAdmin.min.js 文件使 concat/productionAdmin.js “丑陋”。
distAdmin: {
src: ['.tmp/public/concat/productionAdmin.js'],
dest: '.tmp/public/min/productionAdmin.min.js'
}
我在 tasks/config/sails-linker.js 文件中添加了一个新的 prodJSAdmin 部分,它在 SCRIPTS_ADMIN 标签之间添加了 min/productionAdmin.min.js 文件。
prodJsAdmin: {
options: {
startTag: '<!--SCRIPTS_ADMIN-->',
endTag: '<!--SCRIPTS_ADMIN END-->',
fileTmpl: '<script src="%s"></script>',
appRoot: '.tmp/public'
},
files: {
'.tmp/public/**/*.html': ['.tmp/public/min/productionAdmin.min.js'],
'views/**/*.html': ['.tmp/public/min/productionAdmin.min.js'],
'views/**/*.ejs': ['.tmp/public/min/productionAdmin.min.js']
}
},
最后,我通过在 prod.js 文件中添加一行来从 prod grunt 任务中调用这个新的 prodJSAdmin。
'sails-linker:prodJsAdmin',
在生产模式下运行 sails:
sails lift --prod
浏览到 http://localhost:1337/home - 你会看到它正在使用布局模板,查看源代码将在底部显示以下内容(使用 production.min.js):
<!--SCRIPTS-->
<script src="/min/production.min.js"></script>
<!--SCRIPTS END-->
浏览到 http://localhost:1337/admin - 你会看到它正在使用 layoutadmin.ejs 模板,查看源代码将在源代码底部显示以下内容(使用 productionAdmin.min.js):
<!--SCRIPTS_ADMIN-->
<script src="/min/productionAdmin.min.js"></script>
<!--SCRIPTS_ADMIN END-->
关于node.js - sails.js 使用不同的布局和不同的 js 库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28080944/
根据文档,sails lift 将始终尝试使用本地安装的 Sails 模块(即 app/node_modules/sails)运行您的应用。 但是当我运行 sails console 时,我可以从堆栈
在我的sails.js我正在尝试关闭服务和模型的默认全局变量,如下所示: sails: true, services: false, models: false 作为一种风格偏好,我想明确使用 sai
我正在用 sails 框架编写一些 api。我有一个 api 需要从两个表中获取数据,所以我想使用这样的 sql 查询: select * from table1 union select * fro
根据 this , 在创建与其他记录关联的新记录时,响应应包含填充的关联记录。 POST /pony { "name": "Pinkie Pie", "pet": 1 } 响应应该是这样的 {
我已经开始从事一个项目,并决定使用 Sails.js 构建 API。我以前没有使用 Sails 的经验,这就是为什么我需要您的推荐。 我需要为许多模型实现行级权限。例如,假设我只想允许对该记录的创建者
我在一个使用 sail.js 的项目中工作,一切正常,但每次我修改某些内容时,我都必须重新启动“sails lift”。是否没有一个选项可以让我在服务器在线时工作并查看我所做的所有更改? 据了解,问题
当sails.js 模块上的电子邮件验证规则失败时,服务器正在崩溃。 这是我的模块的片段: //用户的电子邮件地址 email: { type: 'string', email: true,
我正在尝试在客户端使用 Sails.js 和 sails.io.js 创建一对一聊天。 我可以让 io.socket.get 和 io.socket.post 工作,但是我无法从任何一个 收到任何东西
我刚刚开始使用 Sails.js,它是一个了不起的框架。但是我遇到了一些情况,我找不到谷歌的解决方案,所以我来这里寻求帮助。 我有一个 Controller 连接到另一个远程服务,该服务使用非常旧的
我已经使用 npm install sails -g 成功安装了 sails我运行的是 Windows 7。当我尝试运行“sails”命令时,收到错误消息“找不到命令”。然后我将相应的 bin 文件夹
我正在使用带有船长-s3适配器的船长来处理我的 sails 应用程序中的文件上传。 当文件正常发送时它工作正常,但是当请求中止时我收到未处理的错误消息并且 sails 崩溃。 events.js:85
像 Rails 一样,有什么方法可以向验证器添加自定义错误消息吗? 喜欢: if(this.password != this.passwordConfirmation){ this.errors
我已经使用 npm install sails -g 成功安装了 sails我运行的是 Windows 7。当我尝试运行“sails”命令时,收到错误消息“找不到命令”。然后我将相应的 bin 文件夹
我需要查询关联表(由 sails 创建),所以我不能使用“Model.query”,因为我没有这个表的模型。我找不到解决方案。谢谢 最佳答案 您可以使用其他模型对象,例如 User.query(sql
仅当满足某些条件时,我才需要加密密码。 beforeUpdate: function (value, cb) { User.findOne(value.id) .exec(function (er
在我的风帆应用程序中,我按如下方式编辑 config/models.js 文件以在提升应用程序时清理数据库。 migrate: 'drop', connection: 'mongodb' 但是
我将sails 升级到@^1.0.0 版本,在开发API 时,我想使用Service,但Sails 文档建议现在使用Helper。而且我并没有真正习惯于使用新的方法来识别助手、构建脚本或 Action
我试图弄清楚如何禁用 Sails.js 中模型的自动数据库迁移。 我知道你可以设置migrate: 'safe'在模型中,但是有没有办法为所有模型指定这个? 最佳答案 实际上,有办法做到这一点。 OR
我正在开始一个新项目,我想使用 AngularJS 作为前端,使用 SailsJS 作为后端。我需要为不同的客户分离数据库。因此,每个客户端都必须有自己的数据库。 我没有找到如何在帆和水线中制作这个。
我从 SailsJS 开始和 MySQL ,我的数据库中有很多表。所以,我不知道 SailsJS有一个工具可以从数据库中生成模型,比如 Database First在 Entity Framework
我是一名优秀的程序员,十分优秀!