0

我已经开始从事相当大的项目了。概念:Some1 向 mysql 插入数据。其他人在他们的屏幕(表格)上实时获取数据我的代码可以正常工作,但我正在用 php 填充表格,据我所知这对带宽不利,所以我试图用 php 代码从 mysql 捕获数据,将其发送到 js,然后它将格式化/填充表格(setinterval 正在运行)。但是我的桌子没有填满,我没有想法。我是 js 新手,所以如果您发现任何问题,请告诉我!谢谢你!

PHP:

<?php
$rows = array();
$con = mysql_connect("where","who","pass");
if (!$con)
  {
  die('Could not connect: ' . mysql_error());
  }
mysql_select_db("dbname", $con);
$result = mysql_query("SELECT * FROM Brokers");
$rows = array();
while($r = mysql_fetch_assoc($result)){
    $rows[] = $r;
}
mysql_close();
print json-encode($rows);
?>

JS:

    function fetchData()
{
    $.ajax({
         url: 'brokers.php',
        dataType: 'json',
        success: createTable(rows)
    })

}
function createTable(rows)
{
    var flowTable = '<table id="resultTable">'
    for (var i=0; i< rows.length; i++){
        flowTable += '<tr class="filterthis height20">',
        flowTable += '<td class="companyname width120">',
        flowTable += rows[i].company_name + '</td>',
        flowTable += '<td class="width180">' ,
        flowTable += rows[i].address + '</td>',
        flowTable += '<td class="width70">' ,
                .........SOME MORE...........
        flowTable += '</tr>';
    }
    flowTable += '</table>';
    $("#here").innerHTML = flowTable;
}
function starttimer(){
  interval = setInterval("fetchData()",1000);
}

启动定时器();

4

3 回答 3

1

json_encode有一个下划线而不是破折号json-encode

也可以使用:

interval = setInterval(fetchData, 1000);

代替:

interval = setInterval("fetchData()",1000);
于 2012-06-22T20:14:36.100 回答
0

一个问题是您实际上将“成功”处理程序设置为“未定义”。这是因为您success: createTable(rows)实际上正在调用该函数并将其返回值(“未定义”)设置为处理程序。

相反,你会想要更多类似的东西:

success: function(data) {
    createTable(data);
}

当然,由于处理程序(我认为)将数据作为第一个参数传递,您可以通过以下方式完成相同的操作:

success: createTable
于 2012-06-22T20:19:54.707 回答
0

好吧,我找到了解决方案。

对脚本 JS 的更正:

function fetchData(){
    $.ajax({
        url: 'brokers.php', //where are we sending request
        dataType: 'json',
        success: createTable //where are we transfering data from php ajax request
    })
}

var createTable = function(data){
    rows = jQuery.parseJSON(data) //creates object from information sent from php
    $.each(rows, function(key,value){  //for each row from php does things You want
        $("#Somediv").html = value.owner_name
        //and etc.
    }
}

经纪人.php:

$con = mysql_connect();    
if (!$con) {
   die('Could not connect: ' . mysql_error());
}

mysql_select_db('somedb');
$result = mysql_query("SELECT * FROM sometable WHERE something=66");
while($row= mysql_fetch_assoc($result)){ //for each row which = our $result query
   $rows[]=$row;
}

echo json_encode($rows);
mysql_close($con);
于 2012-08-03T19:42:43.993 回答