使用MySQL求助!
app.js中代码如下
app.locals({
categorys: dao_base.queryAllcategory(function(err, categorys) {})
});
dao_base代码如下
exports.queryAllcategory = function(callback){
mysql.query('select * from cb_category order by seq',function(err, categorys){
callback(err, categorys);
});
};
jade页面代码如下
#{categorys.length}
然后运行 提示错误
> 1| #{categorys.length}
Cannot read property 'length' of undefined
这是为什么啊?
4 回复
mysql没有连接上,看下配置端口用户名密码之类的 https://github.com/ChunMengLu/node_mysql_test 这是我之前的一个mysql的demo
应该是已经连上了的,调试control输出有信息。
你这写法有很大的问题啊,用你这么写的回调是无法给属性赋值的。你调用dao_base.queryAllcategory
这个函数,但是你期待的结果是在异步过程中,所以这个函数的返回值肯定是undefined
。你只能在异步的回调中去给app.locals
赋值。
有时间你先搞明白JS的函数回调和node的异步吧。
嗯,谢谢。我后来已经想明白了,在函数中是可以得到数据的,不过因为异步的原因 app.locals中得不到数据。现在已经换了一个思路来实现了。