Javascript の機能についての私の理解にはギャップがあるため、匿名ラッパーを使用せずにイベント ハンドラーを定義すると、イベント ハンドラーが自動的に起動される理由を理解するのに苦労しています。
HTML
<a href="#" id="change-html">Change HTML</a>
Javascript #1
var btn = $('#change-html');
btn.click(bindClick(btn)); // bindClick gets executed right away and only once
function bindClick(source){
console.log('get here');
}
Javascript #2
var btn = $('#change-html');
btn.click(function(){
bindClick(btn); // bindClick is only executed on the anchor's click event
});
function bindClick(source){
console.log('get here');
}