当我在node.js中调用ajax作为返回undefined时

时间:2014-04-22 06:56:04

标签: javascript jquery ajax node.js

我的node.js代码

index.js

var mysql = require('mysql');
var fs = require('fs');
var ejs = require('ejs');
var client = mysql.createConnection({
    user : 'root',
    password : '1234',
    database : 'company'
});
exports.index = function(req, res) {
fs.readFile('views/index.html','utf-8',function(error,data){
    client.query('select * from spa',function(error,result){
        if(error){
            console.log('error:'+error);
        }else{
            res.send(ejs.render(data,{
                title:'Express',
                result:result
            }));
        }//end else
    });//end query
});//end fs
};

我的index.html代码

 <script>
$(document).ready(function() {
    function listView() {
        $('#output').empty();
        $.ajax({
            url : '/',
            type : 'GET',
            success : function(result) {
                alert('success');
                alert(typeof (result));
                $(result).each(function(index, item) {
                    var output = '';
                    output += '<tr>';
                    output += '<td>' + item.file_no + '</td>';
                    output += '<td>' + item.file_name + '</td>';
                    output += '<td>' + item.file_content + '</td>';
                    output += '<td>' + item.file_model + '</td>';
                    output += '</tr>';
                    $('#output').append(output);
                });//end each
            }//end success
        });//end ajax
    }//end listView();
   });//end document
 </script>

<table id="output"></table>

当我运行代码直到成功完成。警报('成功') - &gt;工作!

alert(typeof(result)) - &gt; string&gt;工作!但是未定义的所有数据表。

我不知道情况..请帮助我..

2 个答案:

答案 0 :(得分:1)

假设您只想迭代结果对象,而不是:

$(result).each(function(index, item) {

我想你可能想要:

$.each(result, function(index, item) {

如果仍然无法找到您想要的地方,请添加

console.log(result);

准确检查ajax调用的结果是什么,并确保您具有预期的数据,并且您正在迭代它的正确部分。

答案 1 :(得分:0)

你说typeof (result)string,希望JSON。但是如果想迭代它,那么你必须解析为javascript数组

var resultArray = JSON.parse(result);

然后迭代数组

$.each(resultArray, function(index, item) {