Как нажать нужную кнопку?

Есть много кнопок, надо определить нужную. То есть при нажатие данной кнопки появлялся голос для этой кнопки.

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <link rel="stylesheet" href="style.css">
    <script src="javascript.js"></script>
</head>
<body>
    <div class="pole">
        <div class="vote">
            <p>Vote</p>
        </div>
        <span class="count">0</span>
    </div>
    
    <div class="pole">
        <div class="vote">
            <p>Vote</p>
        </div>
        <span class="count">0</span>
    </div>
    
    <div class="pole">
        <div class="vote">
            <p>Vote</p>
        </div>
        <span class="count">0</span>
    </div>
    
    <div class="pole">
        <div class="vote">
            <p>Vote</p>
        </div>
        <span class="count">0</span>
    </div>
    
</body>
</html>

window.onload = function() {
	var btnVote = document.querySelector('.vote'); 
    var vote  = document.querySelectorAll('.count');
    var pole = document.querySelectorAll('.pole');
    
    
    var arr = []; 
    
    if(window.XMLHttpRequest) {
    	var request = new XMLHttpRequest();
    } else {
    	var request = new ActiveXObject("Microsoft.XMLHTTP");
    }
    
    request.open('GET', 'file.txt', true);
    request.onreadystatechange = function() {
    	if(request.status === 200 && request.readyState === 4) {
			
            //...
            
    	} else {
    		vote.innerHTML = "Error AJAX";
    	}
    }; 
    request.send(null);
    
    
}

*{
    margin: 0px;
    padding: 0px;
}

.pole {
    width: 200px;
    height: 50px;
    float: left;
    margin: 20px;
    font: 20px Arial,sans-serif;
}
.pole::after {
    content: '';
    display: block;
    clear: both;
}

.vote {
    width: 150px;
    height: 50px;
    background: #a88d8d;
    float: left;
    text-align: center;
    cursor: pointer;
    line-height: 50px;
    
}


.voted {
    width: 150px;
    height: 50px;
    background: #f70000;
    float: left;
    text-align: center;
    cursor: pointer;
    line-height: 50px;  
}

.count {
    width: 50px;
    margin-left: 150px;
    height: 50px;
    display: block;
    background: #caddbb;
    text-align: center;
    line-height: 50px;
}


8e722292104d4923953cf68714f85170.PNG
  • Вопрос задан
  • 2337 просмотров
Пригласить эксперта
Ответы на вопрос 2
@IceJOKER
Web/Android developer
А как с этим делом обстоят дела в реале?
Людям дают имена, идентификаторы и т.д.
тоже самое и тут, нужно дать кнопкам имена/классы/идентафикаторы
Ответ написан
Комментировать
@Bushizzle
$('.pole').each(function(){
var $this = $(this),
$count = $this.find('.count');

$(this).bind('click', function(){

...

if(request.status === 200 && request.readyState === 4) {
var num = $this.find('.count').text() - 0;
$count.text(num + 1);
} else {
$count.text('Error');
}
});
});

Не? Для любителей чистоты добавлю:

var poles = document.getElementsByClassName('pole');

for(var i = 0; i < poles.length; i++){
poles[i].addEventListener('click', function(){
var count = this.childNodes[3],
num = count.innerHTML - 0;
count.innerHTML = num + 1;
});
}
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы