jQuery事件绑定

2019-03-02  本文已影响0人  原上的小木屋

jquery 如何绑定事件?直接绑定和使用事件代理分别如何使用

在1.7之前的版本中jQuery处理事件有多个方法, ( jquery live bind degelate)作用各不相同,后来统一的使用on/off方法

<div class="box">
    <ul>
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
    </ul>
</div>
<input id="ipt" type="text"> <button id="btn">添加</button>
<div id="wrap">
</div>
$('.box li').on('click', function(){
    console.log(1)
    var str = $(this).text()
    $('#wrap').text(str)
 })
//等同于
$('.box>ul>li').click(function(){
    console.log(2)
    var str = $(this).text()
    $('#wrap').text(str)
 })
//也可以这样写
$('.box li').on('click.hello', function(){
    console.log(3)
    var str = $(this).text()
    $('#wrap').text(str)
})
//命名空间没什么特别的作用,只不过在解绑事件时便于区分绑定的事件
$('.box li').off('click.hello')
//可是用如下方法新增的元素是没绑定事件的
$('#btn').on('click', function(){
    var value = $('#ipt').val()
    $('.box>ul').append('<li>'+value+'</li>')
})
//我们可以用事件代理
$('.box ul').on('click', 'li', function(){
    var str = $(this).text()
    $('#wrap').text(str)
})
//上面代码相当于原生 js 的
document.querySelector('.box ul').addEventListener('click', function(e){
    if(e.target.tagName.toLowerCase() === 'li'){
    //do something
}
})
//绑定事件的时候我们也可以给事件附带些数据,只不过这种用法很少见
$('.box').on('click', {name: 'hunger'}, function(e){
    console.log(e.data)
})

除了on方法之外,jQuery还提供了其他一些方法来处理事件

$('#foo').on('click', function() {
    console.log($(this).text())
    });
$('#foo').trigger('click')

应用jQuery的一个小demo

代码地址
预览地址

jQuery的常用函数

  1. .show()
  1. .hide()
$('.target').hide(); //等同于$('.target').css('display','none')
$('#book').hide(300,function(){alert('Animation complete.')})
$('#book').hide(300,'linear',function(){alert('Animation complete.')})
  1. .slideUp
  1. .slideDown
  1. .slideToggle
  1. .fadeIn
  1. .fadeOut
  1. .animate

jQuery几个重要函数

  1. $.ajax
  1. $.get
$.get('test.php')
$.get('test.php',{name:'John',time:'2pm'})
$.get('test.php' function(data){alert("Data Loaded: " + data)})
$.get("test.cgi", {name: 'John' , time: '2pm'}).done(function(data){alert("data loaded: " + data)})
  1. $.getJSON
上一篇 下一篇

猜你喜欢

热点阅读