try-catch returns 变量未定义

try-catch returns variable as undefined

假设两次尝试都失败,url returns 未定义并且 console.log 在这种情况下不会执行。我的 try-catch 子句堆叠或 url 变量的范围有问题吗?

我正在使用 try-catch,因为在我的上下文中 url1,2,默认值可能不可用。

getURL = function()
{
   var url;
      try{
        url=data.url1;
      }
      catch(err1)
      {
        try{
          url=data.url2;
        }
        catch(err2)
        {
          console.log("Fetching default url");
          url=data.defaulturl;
        }
      }
      finally
      {
        //do something with url
      }
}

我尝试使用 if-else-if 结构,但如果 data.url 1/2/default 不可用,它会 returns 错误。

if('String' === typeof data.url1)
{
}
else if(check for url 2/default etc.){...}

我最后一次尝试重新发明这个问题...但是如果所有键都未定义或 URL 加载不成功,则根本没有成功。

getURL = function() {
  var localData = data || {};
  var keys = ['url1', 'url2', 'defaulturl'];
  var success = false;
  var currentKey;
  while (!success && keys.length > 0) {
    currentKey = keys.shift();
    if (localData.hasOwnProperty(currentKey)
      && 'string' === typeof localData[currentKey]) {
      try {
        url = localData[currentKey];

        // Url loading code may throws an exception,
        // or you can throw it below by hands if needed

        // Emulate loading result...
        if (Math.random() > .5) {
          throw 'Error in ' + localData[currentKey] + ' loading';
        }

        success = true;
      } catch(exception) {
        // Logging or something else here
        console.log(exception.toString());
      }
    }
  }
}