- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用库 StratifiedJS ( http://onilabs.com/stratifiedjs ) 来同步构建一个 api 数据库。
但我对如何包含文件感到困惑。
如文档所述,我以这种方式导入库:
<script type="text/javascript" src="js/stratified.js" main="js/index.sjs"></script>
我的 index.sjs 文件有这段代码:
db = require("mongo");
var data = db.find({collection: "itens"});
你 find
模块 mongo 中的方法具有以下代码:
exports.find = function(params) {
waitfor(var rows) {
$.getJSON("db/find", params, function(result){
resume(result.rows);
});
}
return rows;
}
当我通过文件 index.sjs 或通过标签内的脚本访问 db 模块时:
<script type="text/sjs"> ... code .. </ script>
代码完美运行。但是当我尝试通过 "text/javascript"
类型的文件访问时行为改变。
在这种情况下,如果我将下面的代码运行到一个文件中 .js
:
var data = db.find({collection: "itens"});
数据变量将不包含从 base 返回的数据,因为代码 return rows;
在 getJSON
之前运行要执行的回调函数;
我的问题是:然后如何以 javascript 文件类型运行在 sjs 文件中声明的模块。
最佳答案
这里的问题是普通 JS 不能像分层 JS 那样阻塞和等待异步结果(这当然是我们首先拥有 SJS 的原因!)
所以当你有一个分层函数做一些异步的事情并且你从一个普通的 JS 函数调用它时,后者将不会“看到”分层函数的实际值,而是一种“延续”对象。
JS 不能真正对这个延续对象做任何事情,所以这个想法是,一个典型的 SJS 程序会有分层的顶级代码调用其他分层或非分层代码,但你永远不会(或很少)从调用分层非分层代码。
如果您确实需要从“普通”非分层代码调用分层,您可以安排分层函数采用可选的回调参数:
// SJS file:
exports.find = function(params, callback) {
waitfor (var rows) { ... }
if (callback)
callback(rows);
else
return rows;
}
.
// called from SJS:
var data = db.find({collection:'items'});
... use data ...
.
// called from JS:
db.find({collection:'items'}, function(data) { ... use data ... });
或者,您可以使用“延迟”(https://conductance.io/reference#sjs:function::deferred) 包装 SJS 函数,然后在 JS 中使用回调处理结果:
// SJS file:
exports.find = function(params) { ... };
exports.deferredFind = require('sjs:function').deferred(exports.find);
.
// JS file:
...
db.deferredFind({collection: 'items'}).then(function(data) { ... });
关于javascript - StratifiedJS:如何从 .js 文件调用模块,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22838822/
我是一名优秀的程序员,十分优秀!