开发者

Error url is not useful for dynamically injected javascript functions. Need user supplied reference

javascript which is introduced from a string instead of a .js file is difficult to debug because errors reference the url of the script file containing the error. If many strings are introduced, it is difficult to tell which string(script) is the source of the error.

I have a large number of objects. Each object has a string which will dynamically define its javascript functions. Once the functions have been defined, I need a way for errors that occur during the execution of these dynamically defined functions to report some kind of information that ind开发者_如何学Cicates which string/object is the source of the error.

EXAMPLE 1: Inject functions using eval()

If you use eval() to insert the string as javascript, the error url is undefined.

str = "test_fn = function(){undefined_fn();}";
eval(str);
test_fn();

will yield the following error:

message: "ReferenceError: Can't find variable: undefined_fn"
url: undefined
line: 1

So in this case, the error url is undefined.

EXAMPLE 2: Inject functions using a script tag

If instead of eval, you use a script tag to insert the string as javascript, the error url references the html file.

str = "test_fn = function(){undefined_fn();}";
if(!document.head) document.head = document.getElementsByTagName('head')[0];
var elem = document.createElement('script');
elem.text = str;
document.head.appendChild(elem);
test_fn();

will yield the following error:

message: "ReferenceError: Can't find variable: undefined_fn"
url: "testpage.html"
line: 1

So in this case, the error url is the html page.

I need a way for errors that occur during the execution of these dynamically defined functions to report to the developer some kind of information that indicates which string is the source of the error. I know that I could use the server to dynamically generate a large number of source files and then set script.src for each file, however I would like to avoid referencing hundreds of script files. I would rather prefer to understand how to perhaps modify the url that is reported, or pass some additional information that could be reported to the developer.

I would prefer a cross browser solution, but since this is for development only, it is not necessary.

Errors in these examples were reported using: window.onerror = function(message, url, line) {}


What about this:

function SuperError(msg, location) {
   this.message = msg;
   this.url = location;
}

str = "test_fn = function(){try { undefined_fn(); } catch(e) {throw new SuperError('undefined_fn is undefined', 'in dynamic script head')}}";
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜