私がするときはいつでもjshint.comで
var this_hold = this;
エラーが発生します。
厳密なエラーの違反が発生します。
アプリケーションは、これ (イベント ハンドラーから渡される) を操作する必要があるか、自分で要素をプルする必要があるようなものです。document.getElementById()
これが、この関数が最もうまく機能する方法です... そうしないと、各ケースに対して 1 回ずつ 2 回記述する必要があります。
エラーをなくしたい..オフにしたくない. jshint.com を 100% 幸せにしたい。
違反がコメントされた問題の関数は次のとおりです
/**
*vFlipBP - eliminate select_element in favor of 'this'
*/
function vFlipBP( element_or_string ) {
var previous_page_element,
previous_tag_element,
current_page_element,
select_element;
console.log( 'element_or_string ' + element_or_string );
if( typeof ( element_or_string ) === 'string' ) {
select_element = document.getElementById( element_or_string );
} else {
select_element = this; // violation of strict here
}
if( vFlipBP.previous_id === undefined ) {
var probe_id = select_element.parentElement.firstChild.id;
if ( ( probe_id === select_element.id ) && ( select_element.parentElement.firstChild.nextSibling ) ) {
probe_id = select_element.parentElement.firstChild.nextSibling.id;
vFlipBP.previous_id = probe_id;
} else {
vFlipBP.previous_id = select_element.id;
}
}
current_page_element = document.getElementById( select_element.id + '_page' );
current_page_element.style.display = '';
select_element.style.background = "#eeeeee";
if( vFlipBP.previous_id !== select_element.id ) {
previous_page_element = document.getElementById( vFlipBP.previous_id + '_page' );
previous_tag_element = document.getElementById( vFlipBP.previous_id );
if( ( ( previous_page_element !== current_page_element ) ) && ( previous_page_element !== null ) ) {
previous_page_element.style.display = 'none';
previous_tag_element.style.background = "#ffffff";
}
}
vFlipBP.previous_id = select_element.id;
}