ฉันมีสคริปต์ที่ตรวจพบข้อผิดพลาดของ Javascript บนเว็บไซต์ของฉันและส่งไปยังส่วนแบ็คเอนด์เพื่อการรายงาน โดยจะรายงานข้อผิดพลาดแรกที่พบหมายเลขบรรทัดที่ควรและเวลา
แก้ไขเพื่อรวม doctype:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en" xmlns:fb="http://www.facebook.com/2008/fbml">
...
<script type="text/javascript">
//<![CDATA[
// for debugging javascript!
(function(window){
window.onerror = function(msg, url, ln) {
//transform errors
if (typeof(msg) === 'object' && msg.srcElement && msg.target) {
if(msg.srcElement == '[object HTMLScriptElement]' && msg.target == '[object HTMLScriptElement]'){
msg = 'Error loading script';
}else{
msg = 'Event Error - target:' + msg.target + ' srcElement:' + msg.srcElement;
}
}
msg = msg.toString();
//ignore errors
if(msg.indexOf("Location.toString") > -1){
return;
}
if(msg.indexOf("Error loading script") > -1){
return;
}
//report errors
window.onerror = function(){};
(new Image()).src = "/jserror.php?msg=" + encodeURIComponent(msg) + "&url=" + encodeURIComponent(url || document.location.toString().replace(/#.*$/, "")) + "&ln=" + parseInt(ln || 0) + "&r=" + (+new Date());
};
})(window);
//]]>
</script>
เนื่องจากสคริปต์นี้ฉันตระหนักถึงข้อผิดพลาดจาวาสคริปต์ที่เกิดขึ้นบนเว็บไซต์ของฉัน หนึ่งในผู้กระทำผิดที่ใหญ่ที่สุดคือ "ข้อผิดพลาดของสคริปต์" ที่บรรทัด 0ใน Chrome 10+ และ Firefox 3+ ข้อผิดพลาดนี้ไม่มีอยู่ (หรืออาจเรียกว่าอย่างอื่น) ใน Internet Explorer
การแก้ไข (5/23/2013):ข้อผิดพลาด "Script Error, Line 0" นี้แสดงขึ้นใน IE7 และ IE เวอร์ชันอื่น ๆ อาจเป็นผลมาจากแพตช์รักษาความปลอดภัย IE ล่าสุดเนื่องจากพฤติกรรมนี้ไม่เคยมีมาก่อน
ไม่มีใครมีความคิดว่าข้อผิดพลาดนี้หมายถึงอะไรหรือสาเหตุอะไร มันเกิดขึ้นประมาณ 0.25% ของเจดีย์โดยรวมของฉันและแสดงถึงข้อผิดพลาดที่รายงานครึ่งหนึ่ง
application/xhtml+xml
เพื่อเรียกใช้ในตัวแยกวิเคราะห์ XHTML (เช่นข้อกำหนด XHTML บอกว่า) มีเนื้อหาจำนวนมากที่อ้างว่าเป็น XHTML แต่ส่งประเภทเอกสาร HTML ปกติ เนื่องจากผู้สร้างเนื้อหาใช้ XHTML ไม่ถูกต้องเบราว์เซอร์จึงตัดสินใจใช้ตัวแยกวิเคราะห์ XML บนเท่านั้นapplication/xhtml+xml
(เป็นตัวแยกวิเคราะห์ที่เข้มงวดจริงๆ) hixie.ch/advocacy/xhtmlและwebdevout.net/articles/beware-of-xhtmlพูดว่าทำไมไม่ใช้ HTML parser กับ XHTML