2017-08-01 78 views
0

我有我試圖傳遞一個字符串出來,創造出新的變量的函數 - 見下:從函數傳遞字符串變量的Javascript

function networks(networkGroupId) { 
    jQuery.ajax({ 
     type: 'GET' 
     , url: apiURL + 'api/v4/networkGroups/' + networkGroupId + '/countries?count=500' 
     , dataType: 'json' 
     , success: function (networkGroup) { 
      var regionList = []; // temporary array 
      jQuery.each(networkGroup.countryList, function (i, countryList) { 
       regionList.push(countryList.code + ": 'NORTH AMERICA'") 
      }); 
      var regionListOutput = '{' + regionList + '}'; 
      console.log(regionListOutput); 
     } 
    }); 
}; 

var networkList = networks('15001'); 
console.log('Network List = ' + networkList); 

我是,當我運行這個問題我得到的

Network List = undefined 

{AG: 'NORTH AMERICA',AI: 'NORTH AMERICA',AR: 'NORTH AMERICA',AW: 'NORTH AMERICA',BB: 'NORTH AMERICA',BM: 'NORTH AMERICA',BO: 'NORTH AMERICA',BR: 'NORTH AMERICA',CL: 'NORTH AMERICA',CO: 'NORTH AMERICA',CR: 'NORTH AMERICA',CW: 'NORTH AMERICA',DM: 'NORTH AMERICA',DO: 'NORTH AMERICA',EC: 'NORTH AMERICA',GD: 'NORTH AMERICA',GF: 'NORTH AMERICA',GT: 'NORTH AMERICA',HT: 'NORTH AMERICA',JM: 'NORTH AMERICA',KN: 'NORTH AMERICA',KY: 'NORTH AMERICA',LC: 'NORTH AMERICA',PA: 'NORTH AMERICA',PE: 'NORTH AMERICA',PY: 'NORTH AMERICA',TC: 'NORTH AMERICA',TT: 'NORTH AMERICA',UY: 'NORTH AMERICA',VC: 'NORTH AMERICA',VE: 'NORTH AMERICA',VG: 'NORTH AMERICA',MQ: 'NORTH AMERICA',GP: 'NORTH AMERICA',SV: 'NORTH AMERICA',HN: 'NORTH AMERICA',NI: 'NORTH AMERICA',BS: 'NORTH AMERICA',BZ: 'NORTH AMERICA',GY: 'NORTH AMERICA',MF: 'NORTH AMERICA',MS: 'NORTH AMERICA',SR: 'NORTH AMERICA',BQ: 'NORTH AMERICA',BL: 'NORTH AMERICA',SX: 'NORTH AMERICA'} 

控制檯輸出當我實際上需要雙方的日誌爲字符串{...}

我想我明白,networkList正在恢復,因爲它爲未定義沒有等待networks('15001')的結果,但我不知道如何去糾正這個問題。任何人都可以幫忙嗎?

編輯

爲了進一步增加一些澄清,設置networkList的變量是字符串{AG: 'NORTH AMERICA',AI: 'NORTH AMERICA'...}那麼我想它傳遞給變量regionStyling見下文後(控制檯日誌只爲我檢查正確的字符串正在通過):

function networks(networkGroupId, callback) { 
     jQuery.ajax({ 
      type: 'GET' 
      , url: apiURL + 'api/v4/networkGroups/' + networkGroupId + '/countries?count=500' 
      , dataType: 'json' 
      , success: function (networkGroup) { 
       var regionList = []; // temporary array 
       jQuery.each(networkGroup.countryList, function (i, countryList) { 
        regionList.push(countryList.code + ": 'NORTH AMERICA'") 
       }); 
       var regionListOutput = '{' + regionList + '}'; 
       console.log(regionListOutput); 
       callback(regionListOutput); 
      } 
     }); 
    }; 
    var networkList = []; 
    networks('15001', function (regionListGottenFromTheNetworksFunction) { 
     networkList = regionListGottenFromTheNetworksFunction; 
     console.log('Network List = ' + networkList); 
    }); 

    console.log(networkList); 


    var regionStyling = { 
     regions: [{ 
      values: networkList //this should be the string {AG: 'NORTH AMERICA',AI:...} 
      , scale: { 
       "NORTH AMERICA": "#2761ad" 
       , "EUROPE": "#d58aa3" 
       , "ASIA": "#ee549f" 
       , "LATIN AMERICA": "#15bbba" 
       , "AFRICA & MIDDLE EAST": "#8864ab" 
      } 
    }] 
    };` 
+1

您的函數'networks'沒有'return'語句,因此函數的返回值總是'undefined'。 – BoltKey

回答

3

歡迎來到異步世界!

首先,你沒有在你的方法中返回任何東西。 然後,發生了什麼內部的方法是異步的,這意味着它可能需要一段時間基於許多因素外,另一方面以下行是一個接一個:

VAR networkList =網絡(「15001」 );

console.log('Network List ='+ networkList);

所以同時這兩行正在執行,也許AJAX paart沒有完全執行,因此將沒有值被返回。

有兩件事情可以做:

1 - 使用回調

當前效果完成後執行的回調函數。

function networks(networkGroupId, callback) { 
    jQuery.ajax({ 
     type: 'GET' 
     , url: apiURL + 'api/v4/networkGroups/' + networkGroupId + '/countries?count=500' 
     , dataType: 'json' 
     , success: function (networkGroup) { 
      var regionList = []; // temporary array 
      var regionListOutput = '{'; 

       jQuery.each(networkGroup.countryList, function (i, countryList) { 
        regionList.push(countryList.code + ": 'NORTH AMERICA'"); 
        regionListOutput += countryList.code + ":'NORTH AMERICA',"; 
       }); 

       regionListOutput = regionListOutput.replace(/,\s*$/, ""); //Remove last comma 
       regionListOutput += "}"; 

      callback(regionListOutput); 
     } 
    }); 
}; 

var networkList = []; 
networks('15001', function(regionListString){ 
    networkList = regionListString; 
    console.log('Network List = ' + networkList); 
}); 

2使用的承諾(我喜歡這種過度回調)

所以一旦事情變得真的很有趣,你還在使用回調,你可以很容易地進入一個Callback hell

function networks(networkGroupId, callback) { 
    return new Promise(function(resolve, reject){ 
     jQuery.ajax({ 
      type: 'GET' 
      , url: apiURL + 'api/v4/networkGroups/' + networkGroupId + '/countries?count=500' 
      , dataType: 'json' 
      , success: function (networkGroup) { 
       var regionList = []; // temporary array 
       var regionListOutput = '{'; 

       jQuery.each(networkGroup.countryList, function (i, countryList) { 
        regionList.push(countryList.code + ": 'NORTH AMERICA'"); 
        regionListOutput += countryList.code + ":'NORTH AMERICA',"; 
       }); 

       regionListOutput = regionListOutput.replace(/,\s*$/, ""); //Remove last comma 
       regionListOutput += "}"; 

       resolve(regionListOutput); 
      } 
     });  
    }) 

}; 

var networkList; 
networks('15001').then(function(regionListString){ 
    networkList = regionListString; 
}) 

將異步部分放在一邊,您試圖在此處實現的功能實際上沒有太大意義:

var regionListOutput ='{'+ regionList +'}';

因爲您串聯字符串和數組。你需要做的是在你已經擁有的foreach循環中進行連接。我編輯了這兩種方法。

這是一個JS小提琴,你可以測試。 https://jsfiddle.net/ggderas/67f7p2rb/1/

+0

儘管使用callbacks方法對console.log有效,但它仍然沒有將networkList的變量設置爲字符串'{AG:'NORTH AMERICA',AI:'NORTH AMERICA'...}'我想要這個變量是該字符串,所以我可以將它用作另一個函數中的變量。 –

+0

@JodySergison再次檢查回調方法,在答案 – ggderas

+0

上有一個版本,這仍然沒有將networkList的可配置字符串設置爲字符串'{AG:'NORTH AMERICA',AI:'NORTH AMERICA'...}。看到我的編輯原始帖子。並感謝您的幫助。 –

相關問題