try-catch将变量返回为undefined

时间:2015-11-28 17:01:02

标签: javascript try-catch

假设两次尝试都失败, url 将返回undefined,并且在这种情况下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 不可用,则会返回错误。

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

1 个答案:

答案 0 :(得分:2)

我最后一次尝试重新发明这个问题......但是如果所有的键都未定义或者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());
      }
    }
  }
}