Вам нужно использовать именованные функции.
Кроме того, click
переменная должна быть вне обработчика для приращения.
var click_count = 0;
function myClick(event) {
click_count++;
if(click_count == 50) {
// to remove
canvas.removeEventListener('click', myClick);
}
}
// to add
canvas.addEventListener('click', myClick);
РЕДАКТИРОВАТЬ: Вы можете закрыть вокруг click_counter
переменной, как это:
var myClick = (function( click_count ) {
var handler = function(event) {
click_count++;
if(click_count == 50) {
// to remove
canvas.removeEventListener('click', handler);
}
};
return handler;
})( 0 );
// to add
canvas.addEventListener('click', myClick);
Таким образом, вы можете увеличить счетчик по нескольким элементам.
Если вы этого не хотите и хотите, чтобы у каждого был свой счетчик, сделайте следующее:
var myClick = function( click_count ) {
var handler = function(event) {
click_count++;
if(click_count == 50) {
// to remove
canvas.removeEventListener('click', handler);
}
};
return handler;
};
// to add
canvas.addEventListener('click', myClick( 0 ));
РЕДАКТИРОВАТЬ: я забыл назвать имя обработчика, возвращаемого в последних двух версиях. Исправлена.
if(click == 50) {
должно бытьif( click === 50 )
илиif( click >= 50 )
- они не изменят вывод, но по соображениям здравого смысла эти проверки имеют больше смысла.