假设两次尝试都失败, 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.){...}
答案 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());
}
}
}
}