0
<html>
<head>
    <title>Group Test</title>
    <script type="text/javascript" src="/static/javascript/jquery-1.8.2.min.js"></script>

</head>
<body>

    <script type="text/javascript">

    var global = new Array();
    $.ajax({
        url: "/json",
        success: function(reports){
            global = reports;
            process(reports);
            return global;
            }
        });


function process(reports){
    for (i=0; i<reports.length; i++) {
        document.write(i + " : "+reports[i].fields.report_name+"<br>");
        }
    }

    </script>

</body>
</html>

OK、私のコードがあります。コード全体で JSON データを使用しようとしていますが、$.ajax() 関数の外でレポート オブジェクトを使用しようとすると、何らかの理由で「レポートは未定義です」というエラーが発生します。

JSLint によると、コードは適切に見え、レポートとグローバル変数の両方がグローバル変数としてリストされます。

それらのいずれかを外部で使用するものを実行しようとすると、機能しません。

'success'(reports)
global
global
line 22
process(reports)
global
document
4

2 に答える 2

1

あらゆる場所からアクセスできる reportsグローバル オブジェクトのみとしてアクセスすることはできません。関数だけでなく、成功へのローカル変数ですglobalreportsprocess

<script type="text/javascript">

    var global = new Array();
    $.ajax({
        url: "/json",
        success: function(reports){
            global = reports;
            process(reports);
            return global;
            }
        });


function process(reports){
    for (i=0; i<reports.length; i++) {
        document.write(i + " : "+reports[i].fields.report_name+"<br>");
        }
    }
        // reports is undefined here. but global can be accessed (will be empty array before success function get called)
    </script>
于 2012-10-05T20:07:44.337 に答える
0

$.ajax非同期であるため、成功コールバック内で関数を呼び出さない限り、値がまだ設定されていない可能性があることに注意してください。

globalまた、 notを使用する必要がありますreports

于 2012-10-05T20:09:50.747 に答える