ฉันจึงสร้างวิดเจ็ต jqueryui นี้ขึ้นมา มันสร้าง div ที่ฉันสามารถสตรีมข้อผิดพลาดได้ รหัสวิดเจ็ตมีลักษณะดังนี้:
$.widget('ui.miniErrorLog', {
logStart: "<ul>", // these next 4 elements are actually a bunch more complicated.
logEnd: "</ul>",
errStart: "<li>",
errEnd: "</li>",
content: "",
refs: [],
_create: function() { $(this.element).addClass( "ui-state-error" ).hide(); },
clear: function() {
this.content = "";
for ( var i in this.refs )
$( this.refs[i] ).removeClass( "ui-state-error" );
this.refs = [];
$(this.element).empty().hide();
},
addError: function( msg, ref ) {
this.content += this.errStart + msg + this.errEnd;
if ( ref ) {
if ( ref instanceof Array )
this.refs.concat( ref );
else
this.refs.push( ref );
for ( var i in this.refs )
$( this.refs[i] ).addClass( "ui-state-error" );
}
$(this.element).html( this.logStart + this.content + this.logEnd ).show();
},
hasError: function()
{
if ( this.refs.length )
return true;
return false;
},
});
ฉันสามารถเพิ่มข้อความแสดงข้อผิดพลาดและการอ้างอิงถึงองค์ประกอบของเพจที่จะทำให้เกิดข้อผิดพลาด ฉันใช้มันเพื่อตรวจสอบกล่องโต้ตอบ ในเมธอด "addError" ฉันสามารถส่งผ่านรหัสเดียวหรืออาร์เรย์ของรหัสได้ดังนี้:
$( "#registerDialogError" ).miniErrorLog(
'addError',
"Your passwords don't match.",
[ "#registerDialogPassword1", "#registerDialogPassword2" ] );
แต่เมื่อฉันผ่านอาร์เรย์ของ id มันไม่ได้ผล ปัญหาอยู่ในบรรทัดต่อไปนี้ (ฉันคิดว่า):
if ( ref instanceof Array )
this.refs.concat( ref );
else
this.refs.push( ref );
ทำไม concat ไม่ทำงาน this.refs และ ref เป็นทั้งอาร์เรย์ แล้วทำไม concat ไม่ทำงาน?
โบนัส: ฉันทำอะไรโง่ ๆ ในวิดเจ็ตนี้หรือไม่? มันเป็นคนแรกของฉัน