Как обрабатывать события нажатия кнопки в jQuery?

129

Мне нужно иметь кнопку и обрабатывать ее событие в jQuery. Я пишу этот код, но он не работает. Я что-то пропустил?

<!-- Begin Button -->  
<div class="demo">
<br> <br> <br>   
<input id = "btnSubmit" type="submit" value="Release"/>
<br> <br> <br>  
</div>
<!-- End Button -->

И в файле javascript

function btnClick()
{
    //    button click
    $("#btnSubmit").button().click(function(){
        alert("button");
    });    
}
Ахмад Фарид
источник
1
Почему бы просто не вынуть его из закрывающей btnClickфункции? Я не понимаю, что это добавляет
CodyBugstein

Ответы:

249

Вы должны поместить обработчик события в событие $ (document) .ready ():

$(document).ready(function() {
    $("#btnSubmit").click(function(){
        alert("button");
    }); 
});
Давиде Гуалано
источник
25
$(document).ready(function(){

     $('your selector').bind("click",function(){
            // your statements;
     });

     // you can use the above or the one shown below

     $('your selector').click(function(e){
         e.preventDefault();
         // your statements;
     });


});
Лоуренс Гандхар
источник
5
Хорошо, потому что это единственный, кто вставляет preventDefault ()
Габрер
12
Начиная с jQuery 1.7, этот .on()метод является предпочтительным методом прикрепления обработчиков событий к документу. Поэтому было бы лучше:$('your selector').on("click", ...);
Tinynumbers
11
$('#btnSubmit').click(function(){
    alert("button");
});

или

//Use this code if button is appended in the DOM
$(document).on('click','#btnSubmit',function(){
    alert("button");
});

См. Документацию для получения дополнительной информации:
https://api.jquery.com/click/

Брюс Филлип Перес
источник
Кнопка, добавленная в объект dom, всегда является проблемой при использовании уведомления, такого как sweetalert. Спасибо, что указали на это
Дипеш Тхапа
6
 $("#btnSubmit").click(function(){
        alert("button");
    });    
Али Тархини
источник
5

Попробуй это:

$(document).on('click', '#btnClick', function(){ 
    alert("button is clicked");
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
 <button id="btnClick">Click me</button> 

Рафикуль Ислам
источник
Преимущество этой версии в том, что она по-прежнему работает, если после запуска этого скрипта создается #btnClick.
Джимбали
3
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>

<script>
$(document).ready(function(){
  $("#button").click(function(){
    alert("Hello");
  });
});
</script>

<input type="button" id="button" value="Click me">
Nivediny
источник
1

<script type="text/javascript">

    $(document).ready(function() {

    $("#Button1").click(function() {

        alert("hello");

    });

    }
    );

</script>
Ануп Ганшала
источник
1
$('#btnSubmit').click(function(event){
    alert("Button Clicked");
});

или когда вы используете кнопку отправки, чтобы вы могли написать свой код в событии проверки формы, например

$('#myForm').validate(function(){
    alert("Hello World!!");
});
Hiren
источник
0

Работает для меня

<script src="//ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js" type="text/javascript"></script>
<script type="text/javascript">

$("#btn").click(function() {
    alert("email")
});

</script>
navyad
источник