如何将jquery getJSON与局部变量一起使用

时间:2015-06-23 10:57:06

标签: javascript jquery ajax json ace-editor

我想扩展Ace Editor的完成,我需要一个json的字,这是我的代码:

function load_completions() {

        var object = $('#preview').attr('class');

        $.ajax({
            type: "POST",
            url: "test_editor_ajax.php",
            data: {action:'load_completion', object:object},
            cache: false,
            success: function(json){
                var adminCompleter = {
                    getCompletions: function(editor, session, pos, prefix, callback) {
                        if (prefix.length === 0) { callback(null, []); return }
                        $.getJSON(json, function(wordList) {
                            callback(null, wordList.map(function(ea)  {           
                                return {name: ea.word, value: ea.word, meta: "optional text"}
                            }));
                        })
                    }
                }
                langTools.addCompleter(adminCompleter);
            }
        });

        return false;

    }

getJSON函数需要一个json文件的url,但是我已经用ajax在本地创建了json,你在上面的代码中看到,ajax调用返回一个我用这种方式生成的json:

echo json_encode($completions);

$completions是一个数组,所以我的问题是如何在函数中使用它?

1 个答案:

答案 0 :(得分:0)

JSON是JavaScript Object Notation,因此:[]{}是JSON。

我想你只需要:

        getCompletions: function(editor, session, pos, prefix, callback) {
            if (prefix.length === 0) {
              callback(null, []);
              return;
            }
            callback(null, wordList.map(function(ea)  {           
                return {name: ea.word, value: ea.word, meta: "optional text"}
            }));
        }

$.getJSON将使用AJAX调用服务器。它只是一种简短的方法,用于执行在响应中接受application/json的GET请求。