recherche

Maison  >  Questions et réponses  >  le corps du texte

javascript - acquisition de la valeur de retour jquery ajax

`var a =1;

function setA(){
$.get('http://localhost/','a=2',function(ret){

  return ret.a;

});
}`
Comment faire en sorte que la fonction setA renvoie la valeur de ret.a obtenue en utilisant ajax ?

怪我咯怪我咯2793 Il y a quelques jours732

répondre à tous(4)je répondrai

  • 怪我咯

    怪我咯2017-06-26 10:52:25

    Deux façons
    1 : changez ajax en synchronisation et vous pourrez directement obtenir la valeur de retour correcte.
    2 : Ajoutez votre logique de traitement directement au rappel ajax

    répondre
    0
  • 怪我咯

    怪我咯2017-06-26 10:52:25

    Ajoutez un rappel de paramètre de fonction à getA, puis utilisez callback(set.a) dans la valeur de retour ajax.
    zAccess set.a comme ceci lors de l'utilisation de getA : getA(function(a){console.log(a)})

    Les exemples sont les suivants :

        var a =1;
    
        function setA(callback){
            $.get('http://localhost/','a=2',function(ret){
                callback(ret.a);
            });
        }
        
        setA(function(a) {
            console.log('a:' + a)
        })

    répondre
    0
  • 仅有的幸福

    仅有的幸福2017-06-26 10:52:25

    var a;
    
    $.get('http://localhost/','a=2',function(ret){
        setA(ret.a); });
    function setA(value){
        a=value;
    }
    
    function getA(){
        return a;
        }

    répondre
    0
  • 高洛峰

    高洛峰2017-06-26 10:52:25

    renvoie la variable temporaire dans setA里使用一个临时变量存储,setA里面的AJAX使用同步请求,成功后将值存在临时变量中,然后由setA

    setA() {
        var temp = '';
    
        $.get({
            url: 'http://localhost/',
            data: {a: 2},
            async: false,
            success: function(ret) {
                temp = ret.a;
                return ;
            }
        });
        
        return temp;
    }

    répondre
    0
  • Annulerrépondre