jQuery高级
1. 事件冒泡
-
什么是事件冒泡
在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理程序或者事件返回true,那么这个事件会向这个对象的父级对象传播,从里到外,直至它被处理(父级对象所有同类事件都将被激活),或者它到达了对象层次的最顶层,即document对象(有些浏览器是window)。 -
阻止事件冒泡
事件冒泡机制有时候是不需要的,需要阻止掉,通过 event.stopPropagation() 来阻止,需要在函数定义的时候加上一个参数。 -
阻止默认行为
event.preventDefault();
-
阻止事件冒泡和阻止默认行为可以合并写为 return false;
-
需要注意几个概念:
- 不管事件函数是否绑定,那么它都会在对应的时候触发响应的事件,只是没有处理的动作而已
- 父子关系是在html标签里相对的,而不是他们在网页看到的摆放的位置
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.grandfather{
width: 300px;
height: 300px;
background-color: purple;
}
.father{
width: 200px;
height: 200px;
background-color: gold;
}
.son{
width: 100px;
height: 100px;
background-color: red;
position: absolute;
left: 0px;
top: 400px;
}
</style>
<script src="js/jquery-1.12.4.min.js"></script>
<script>
$(function(){
//var $son = $('.son');
// ev是发生事件时,系统自动产生的事件对象,通过第一个参数传入,需要在函数定义的位置把这个参数加上
$('.son').click(function(ev){
alert(1);
// 阻止事件冒泡往上传
ev.stopPropagation();
});
$('.father').click(function(){
alert(2);
return false;
});
$('.grandfather').click(function(){
alert(3);
});
// $(document)表示顶级标签,相当于<html>标签
$(document).click(function(){
alert(4);
});
})
</script>
</head>
<body>
<!-- .grandfather>.father>.son -->
<div class="grandfather">
<div class="father">
<div class="son"></div>
</div>
</div>
</body>
</html>
2. 事件委托
事件委托就是利用冒泡的原理,把事件加到父级上,通过判断事件来源的子集,执行相应的操作,事件委托首先可以极大减少事件绑定次数,提高性能;其次可以让新加入的子元素也可以拥有相同的操作。
- delegate()方法
-
参数1:代理的选择器
-
参数2:代理的事件
-
参数3:绑定的动作函数
-
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src="js/jquery-1.12.4.min.js"></script>
<script>
$(function(){
var $li = $('.list li');
var $list = $('.list');
// 这样写里面会绑定8次,效率不高
// $li.click(function(){
// $(this).css('color', 'red');
// });
// 使用事件委托,效率高
// 参数1:代理的选择器
// 参数2:代理的事件
// 参数3:绑定的动作函数
$list.delegate('li', 'click', function(){
$(this).css('background', 'gold');
});
})
</script>
</head>
<body>
<ul class="list">
<li>列表文字</li>
<li>列表文字</li>
<li>列表文字</li>
<li>列表文字</li>
<li>列表文字</li>
<li>列表文字</li>
<li>列表文字</li>
<li>列表文字</li>
</ul>
</body>
</html>
3. Dom操作(改变html的结构)
Dom操作也叫做元素节点操作,它指的是改变html的标签结构,它有两种情况:
- 移动现有标签的位置
- 将新创建的标签插入到现有的标签中
创建新标签
var $div = $('<div>'); //创建一个空的div
var $div2 = $('<div>这是一个div元素</div>');
移动或者插入标签的方法
- append()和appendTo():在现存元素的内部,从后面放入元素
var $span = $('<span>这是一个span元素</span>');
$('#div1').append($span);
......
<div id="div1"></div>
-
prepend()和prependTo():在现存元素的内部,从前面放入元素
-
after()和insertAfter():在现存元素的外部,从后面放入元素
-
before()和insertBefore():在现存元素的外部,从前面放入元素
删除标签
$('#div1').remove();
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src="js/jquery-1.12.4.min.js"></script>
<script>
$(function(){
var $h01 = $('#h01');
var $h02 = $('#h02');
var $p01 = $('#p01');
var $div01 = $('#div01');
// 当前元素里面的后面放另外一个元素
// $div01.append($h01);
// 当前元素要放到另外一个元素的里面的后面
$h01.appendTo($div01);
// 当前元素里面的前面要放另外一个元素
// $div01.prepend($h02);
// 当前元素要放到另外一个元素的里面的前面
$h02.prependTo($div01);
// 当前元素外面的后面要放另外一个元素
// $div01.after($p01);
// 当前元素要放到另外一个元素的外面的后面
$p01.insertAfter($div01);
// 创建新标签
// 创建一个空的div
var $newdiv01 = $('<div>');
// 创建一个有内容的div
var $newdiv02 = $('<div>这是新创建的第二个div</div>');
// 当前元素外面的前面要放另外一个元素
$div01.before($newdiv01);
// 当前元素要放到另外一个元素的外面的前面
$newdiv02.insertBefore($div01);
// 删除标签
$newdiv02.remove();
})
</script>
</head>
<body>
<h4 id="h01">这是div01外面的h4</h4>
<h2 id="h02">这是div01外面的h2</h2>
<p id="p01">这是div01上面的p标签</p>
<div id="div01">
<h3>这是div01里面的h3</h3>
<p>这是div01里面的p标签</p>
</div>
</body>
</html>
4. Todolist练习
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>todolist</title>
<style type="text/css">
.list_con{
width:600px;
margin:50px auto 0;
}
.inputtxt{
width:550px;
height:30px;
border:1px solid #ccc;
padding:0px;
text-indent:10px;
}
.inputbtn{
width:40px;
height:32px;
padding:0px;
border:1px solid #ccc;
}
.list{
margin:0;
padding:0;
list-style:none;
margin-top:20px;
}
.list li{
height:40px;
line-height:40px;
border-bottom:1px solid #ccc;
}
.list li span{
float:left;
}
.list li a{
float:right;
text-decoration:none;
margin:0 10px;
}
</style>
<script type="text/javascript" src="js/jquery-1.12.4.min.js"></script>
<script type="text/javascript">
$(function(){
// 1. 选择需要操作的元素
var $txt = $('#txt1');
var $btn = $('#btn1');
var $list = $('#list');
// 2. 给增加按钮绑定click事件
$btn.click(function(){
// 3. 读取输入框里面的值
var sVal = $txt.val();
// 4. 清空输入框的内容
$txt.val("");
// 5. 判断是否为空,空的提示要输入内容
if(sVal == ""){
alert('请输入计划内容!');
return;
}
// 6. 创建一个li标签
var $newli = $('<li><span>'+sVal+'</span><a href="javascript:;" class="up"> ↑ </a><a href="javascript:;" class="down"> ↓ </a><a href="javascript:;" class="del">删除</a></li>');
// 7. 将新创建的li放到ul的里面的后面
$list.append($newli);
// var $del2 = $newli.find('.del');
// $del2.click(function(){
// $(this).parent().remove();
// });
});
// 选择所有删除的标签
// var $del = $('.del');
// 给删除标签绑定事件,来删除计划
// $del.click(function(){
// $(this).parent().remove();
// });
// 上面写法代码冗余且性能不高,使用事件委托
// 8. 给ul绑定委托事件,代理它里面所有a标签的点击操作
$list.delegate('a', 'click', function(){
// 9. 获取当前点击的a标签的class名称,从而判断要做什么操作
var sTr = $(this).prop('class');
// 10.判断sTr如果是del,就做删除操作
if(sTr == 'del'){
$(this).parent().remove();
}else if(sTr == 'up'){
// 11. 判断sTr如果是up,就做上移操作
if($(this).parent().prev().length == 0){
alert('已经是最上面一个啦!');
return;
}
$(this).parent().insertBefore($(this).parent().prev());
}else{
if($(this).parent().next().length == 0){
alert('已经是最下面一个啦!');
return;
}
$(this).parent().insertAfter($(this).parent().next());
}
});
})
</script>
</head>
<body>
<div class="list_con">
<h2>To do list</h2>
<input type="text" name="" id="txt1" class="inputtxt">
<input type="button" name="" value="增加" id="btn1" class="inputbtn">
<ul id="list" class="list">
<li><span>学习html</span><a href="javascript:;" class="up"> ↑ </a><a href="javascript:;" class="down"> ↓ </a><a href="javascript:;" class="del">删除</a></li>
<li><span>学习css</span><a href="javascript:;" class="up"> ↑ </a><a href="javascript:;" class="down"> ↓ </a><a href="javascript:;" class="del">删除</a></li>
<li><span>学习javascript</span><a href="javascript:;" class="up"> ↑ </a><a href="javascript:;" class="down"> ↓ </a><a href="javascript:;" class="del">删除</a></li>
</ul>
</div>
</body>
</html>
5. JavaScript对象直接量
可以类比结构体记忆
javascript中的对象,可以理解成是一个键值对的集合,键是调用每个值的名称,值可以是基本变量,还可以是函数和对象。
创建javascript对象可以用对象直接量的方式直接创建:
var person = {
name:'Rose',
age: 18,
sayName:function(){
alert('My name is' + this.name);
}
}
// 调用属性和方法:
alert(person.age);
person.sayName();
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src="js/jquery-1.12.4.min.js"></script>
<script>
// 通过对象直接量的方式来创建一个对象
var oPerson = {
name:'alin',
age:21,
showname:function(){
alert('我的名字是:'+this.name);
},
showage:function(){
alert('我的年龄是:'+this.age);
}
};
// 调用对象的属性和方法
alert(oPerson.name);
oPerson.showage();
</script>
</head>
<body>
</body>
</html>
6. json数据格式
JavaScript中的json定义时,必须用""
包裹key
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script>
// 定义一个json数据
var sJson = '{\
"name":"alin",\
"age":18,\
"hobby":["study","shopping","basketball"],\
"school":{"name":"tyut","location":"taiyuan"}\
}';
// 将json数据转化成JavaScript对象
var oJson = JSON.parse(sJson);
// alert(oJson.name);
// alert(oJson.hobby[0]);
alert(oJson.school.location);
</script>
</head>
<body>
</body>
</html>
7. ajax
ajax一个前后台配合的技术,它可以让javascript发送http请求,与后台通信,获取数据和信息。ajax技术的原理是实例化xmlhttp对象,使用此对象与后台通信。jquery将它封装成了一个函数$.ajax(),我们可以直接用这个函数来执行ajax请求。
ajax需要在服务器环境下运行。
**$.ajax使用方法 **
常用参数:
1、url 请求地址
2、type 请求方式,默认是’get’,常用的还有’post’
3、dataType 设置返回的数据格式,常用的是’json’格式,也可以设置为’text’
4、data 设置发送给服务器的数据
5、success 设置请求成功后的回调函数
6、error 设置请求失败后的回调函数
7、async 设置是否异步,默认值是’true’,表示异步
<script>
$(function(){
/*
$.ajax({
url:'js/data01.json',
type:'get',
dataType:'json',
success:function(dat){
// alert(dat.name);
$('.login_info').show().children().html(dat.name);
$('.login_btn').hide();
},
error:function(){
alert('服务器超时, 请重试!');
}
});
*/
$.get('js/data01.json', function(dat){
$('.login_info').show().children().html(dat.name);
$('.login_btn').hide();
}, 'json');
})
</script>