0

我正在编写一些 javascript 代码,它首先从数据库中检索一些数据(函数 $.get()),然后对数据执行一些计算 - 使用具有静态属性的 CalcModule() 将数据传递给函数 Test() . 通过控制台,我看到静态属性(productname、productid)已设置(在 $.get() 内),但通过控制台我还看到这些值对于函数 Test() 仍然不可访问(可见)?

我究竟做错了什么?(我检查了一些关于静态属性的网站,例如http://elegantcode.com/2011/01/19/basic-javascript-part-7-static-properties-and-methods/,但我仍然无法解决问题)

编码:

$(document).ready(function () {


    function CalcModule() {};

    //static variables
    CalcModule.nrofeproducts;
    CalcModule.productid = [];
    CalcModule.productname = [];


    //get the product data from the database
    $.get("getdata.php",
        function (msg) {
            //some code here...

            //load CalcModule with retrieved db values for calculation
            for (var i = 0; i < msg.nrofeproducts; i++) {
                CalcModule.productid[i] = msg.productid[i];
                CalcModule.productname[i] = msg.productname[i];
            }

            //for debugging purposes
            console.log(CalcModule.productname);
            console.log(CalcModule.productid);

        }, "json"); //$.get()

    function Test() {
        var x = [];
        x = CalcModule.productname;
        console.log(CalcModule.productname);
    }

    Test();
})
4

1 回答 1

0
 $.get("getdata.php",
    function (msg) {
        //some code here...

        //load CalcModule with retrieved db values for calculation
        for (var i = 0; i < msg.nrofeproducts; i++) {
            CalcModule.productid[i] = msg.productid[i];
            CalcModule.productname[i] = msg.productname[i];
        }

        //for debugging purposes
        console.log(CalcModule.productname);
        console.log(CalcModule.productid);

        // We are guaranteed that $.get is done
        Test();

    }, "json"); //$.get()

    function Test() {
      var x = [];
      x = CalcModule.productname;
      console.log(CalcModule.productname);
    }

    // If we call Test() here, $.get will not be done yet.
于 2013-08-06T16:31:48.707 回答