【发布时间】:2017-01-18 20:40:09
【问题描述】:
我在代码中有以下场景,我从客户端调用一个函数,在服务器端该函数从 mongodb 集合中获取数据,然后我使用该数据使用 d3 js 生成条形图。但问题是我没有得到服务器到客户端的响应。我尝试了各种方法,例如future和fiber,但仍然没有解决。我对流星很陌生,因此感谢您的帮助。
这里是客户端函数,
Meteor.call("ok", function(error, r) {
if (!error) {
console.log(r.content);
var len = Object.keys(JSON.parse(r.content)).length;
var svg = d3.select("svg")
var mySquare = new Array()
var data = JSON.parse(r.content);
data.forEach(function(d) {
mySquare[d.data] = svg.append("rect").attr("x",60+ (d.data*20)).attr("y",45-d.height).attr("height",d.height).attr("width",15).style("fill","#f7f7f7");
})
svg.selectAll("rect")
.on("click", function(d){
d3.select(this).transition(1000).style("fill", "#ff0000").duration(1000).transition(1000).style("fill", "#f7f7f7").duration(1000);
})
} else {
console.log(error);
};});
这是服务器端代码,
Meteor.methods({
ok: function(options){
Meteor.coll = new Mongo.Collection("test")
return Meteor.coll.find().fetch();
},});
请帮我解决这个问题并解释如何使用它以供进一步使用。
【问题讨论】:
标签: javascript mongodb meteor d3.js