杏坛餐饮网站建站/百度发广告怎么发
1.jquery介绍
jQuery是目前使用最广泛的javascript函数库。据统计,全世界排名前100万的网站,有46%使用jQuery,远远超过其他库。微软公司甚至把jQuery作为他们的官方库。
jQuery的版本分为1.x系列和2.x、3.x系列,1.x系列兼容低版本的浏览器,2.x、3.x系列放弃支持低版本浏览器,目前使用最多的是1.x系列的。
jquery是一个函数库,一个js文件,页面用script标签引入这个js文件就可以使用。
<script type="text/javascript" src="js/jquery-1.12.2.js"></script>
jquery的口号和愿望 Write Less, Do More(写得少,做得多)
1、jQuery 官方网站
2、jQuery CDN 版本下载
2.jquery加载
将获取元素的语句写到页面头部,会因为元素还没有加载而出错,jquery提供了ready方法解决这个问题,它的速度比原生的 window.onload 更快。
<!DOCTYPE html>
<html><head><meta charset="utf-8"><title></title></head><script type="text/javascript" src="./js/jquery-1.12.4.min.js"></script><script type="text/javascript">window.onload=function(){var odiv=document.getElementById('div1');alert('原生弹出的'+odiv);}// ready 比window.onload要快:// 原因四,window.onload是等标签加载完后,再渲染zhi后运行,ready是等标签加载完后就运行// ready的完整写法:$(document).ready(function(){var div=$('#div1');alert('jquery弹出的'+div);})// read的简写$(function(){var div=$('#div1')alert('jquery弹出的'+div);})</script><body><div id="div1">这是一个div元素</div></body>
</html>
3.jquery选择器
3.1 jquery用法思想一
选择某个网页元素,然后对它进行某种操作
3.2 jquery选择器
jquery选择器可以快速地选择元素,选择规则和css样式相同,使用length属性判断是否选择成功。
$('#myId') //选择id为myId的网页元素
$('.myClass') // 选择class为myClass的元素
$('li') //选择所有的li元素
$('#ul1 li span') //选择id为为ul1元素下的所有li下的span元素
$('input[name=first]') // 选择name属性等于first的input元素
3.3 对选择集进行过滤
$('div').has('p'); // 选择包含p元素的div元素
$('div').not('.myClass'); //选择class不等于myClass的div元素
$('div').filter('.myClass'); //选择class等于myClass的div元素
$('div').eq(5); //选择第6个div元素
3.4 选择集转移
$('div').prev(); //选择div元素前面紧挨的同辈元素
$('div').prevAll(); //选择div元素之前所有的同辈元素
$('div').next(); //选择div元素后面紧挨的同辈元素
$('div').nextAll(); //选择div元素后面所有的同辈元素
$('div').parent(); //选择div的父元素
$('div').children(); //选择div的所有子元素
$('div').siblings(); //选择div的同级元素
$('div').find('.myClass'); //选择div内的class等于myClass的元素
3.5 判断是否选择到了元素
jquery有容错机制,即使没有找到元素,也不会出错,可以用length属性来判断是否找到了元素,length等于0,就是没选择到元素,length大于0,就是选择到了元素。
var $div1 = $('#div1');
var $div2 = $('#div2');
alert($div1.length); // 弹出1
alert($div2.length); // 弹出0
......
<div id="div1">这是一个div</div>
4.jquery样式操作
4.1 jquery用法思想二
同一个函数完成取值和赋值
4.2 操作行间样式
// 获取div的样式
$("div").css("width");
$("div").css("color");//设置div的样式
$("div").css("width","30px");
$("div").css("height","30px");
$("div").css({fontSize:"30px",color:"red"});
特别注意
选择器获取的多个元素,获取信息获取的是第一个,比如:$("div").css("width"),获取的是第一个div的width
4.3 操作样式类名
$("#div1").addClass("divClass2") //为id为div1的对象追加样式divClass2
$("#div1").removeClass("divClass") //移除id为div1的对象的class名为divClass的样式
$("#div1").removeClass("divClass divClass2") //移除多个样式
$("#div1").toggleClass("anotherClass") //重复切换anotherClass样式
5.绑定click时间
给元素绑定click事件,可以用如下方法:
$('#btn1').click(function(){// 内部的this指的是原生对象// 使用jquery对象用 $(this)})
例子:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><script type="text/javascript" src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function(){// 绑定click事件$('#btn').click(function(){$('.box').toggleClass('col01');})})</script>
</head>
<style type="text/css">.box{width:200px;height:200px;background-color:gold;}.col01{background-color:green;}</style>
<body><input type="button" name="" value="切换样式" id="btn"><div class="box">div元素</div>
</body>
</html>
5.1 获取元素的索引值
有时候需要获得匹配元素相对于同胞元素的索引位置,此时可以用index()方法获取
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><script type="text/javascript" src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function(){var $li = $('.list li');alert( $li.filter('.myli').index() );})</script>
</head>
<body><ul class="list"><li>1</li><li>2</li><li>3</li><li>4</li><li class="myli">5</li><li>6</li><li>7</li><li>8</li></ul>
</body>
</html>
6.jquery特效效果
fadeOut() 淡出
fadeToggle() 切换淡入淡出
hide() 隐藏元素
show() 显示元素
toggle() 切换元素的可见状态
slideDown() 向下展开
slideUp() 向上卷起
slideToggle() 依次展开或卷起某个元素
例子:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><style type="text/css">.box{width:300px;height:300px;background-color:gold;display:none;}</style><script type="text/javascript" src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function(){$('#btn').click(function(){/*$('.box').fadeIn(1000,function(){alert('动画完了!');});*//*$('.box').fadeToggle(1000,function(){alert('动画完了!');});*/// $('.box').show();//$('.box').toggle();//$('.box').slideDown();$('.box').slideToggle(1000,function(){alert('动画完了')});})})</script>
</head><body><input type="button" name="" value="动画" id="btn"><div class="box"></div>
</body>
</html>
7.jquery链式调用
jquery对象的方法会在执行完后返回这个jquery对象,所有jquery对象的方法可以连起来写:
$('#div1') // id为div1的元素
.children('ul') //该元素下面的ul子元素
.slideDown('fast') //高度从零变到实际高度来显示ul元素
.parent() //跳到ul的父元素,也就是id为div1的元素
.siblings() //跳到div1元素平级的所有兄弟元素
.children('ul') //这些兄弟元素中的ul子元素
.slideUp('fast'); //高度实际高度变换到零来隐藏ul元素
层级菜单案例:
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>层级菜单</title><style type="text/css">body {font-family: 'Microsoft Yahei';}body,ul {margin: 0px;padding: 0px;}ul {list-style: none;}.menu {width: 200px;margin: 20px auto 0;}.menu .level1,.menu li ul a {display: block;width: 200px;height: 30px;line-height: 30px;text-decoration: none;background-color: #3366cc;color: #fff;font-size: 16px;text-indent: 10px;}.menu .level1 {border-bottom: 1px solid #afc6f6;}.menu li ul a {font-size: 14px;text-indent: 20px;background-color: #7aa1ef;}.menu li ul li {border-bottom: 1px solid #afc6f6;}.menu li ul {display: none;}.menu li ul.current {display: block;}.menu li ul li a:hover {background-color: #f6b544;}</style><script type="text/javascript" src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function() {$('.level1').click(function() {//当前点击的元素紧挨的同辈元素向下展开,再跳到此元素的父级(li),再跳到此父级的其他的同辈元素(li),选择其他同辈元素(li)的子元素ul,然后将它向上收起。// 通过stop() 可以修正反复点击导致的持续动画的问题$(this).next().stop().slideToggle().parent().siblings().children('ul').slideUp();})})</script></head><body><ul class="menu"><li><a href="#" class="level1">水果</a><ul class="current"><li><a href="#">苹果</a></li><li><a href="#">梨子</a></li><li><a href="#">葡萄</a></li><li><a href="#">火龙果</a></li></ul></li><li><a href="#" class="level1">海鲜</a><ul><li><a href="#">蛏子</a></li><li><a href="#">扇贝</a></li><li><a href="#">龙虾</a></li><li><a href="#">象拔蚌</a></li></ul></li><li><a href="#" class="level1">肉类</a><ul><li><a href="#">内蒙古羊肉</a></li><li><a href="#">进口牛肉</a></li><li><a href="#">野猪肉</a></li></ul></li><li><a href="#" class="level1">蔬菜</a><ul><li><a href="#">娃娃菜</a></li><li><a href="#">西红柿</a></li><li><a href="#">西芹</a></li><li><a href="#">胡萝卜</a></li></ul></li><li><a href="#" class="level1">速冻</a><ul><li><a href="#">冰淇淋</a></li><li><a href="#">湾仔码头</a></li><li><a href="#">海参</a></li><li><a href="#">牛肉丸</a></li></ul></li></ul></body>
</html>
8.jquery动画
通过animate方法可以设置元素某属性值上的动画,可以设置一个或多个属性值,动画执行完成后会执行一个函数。
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><script type="text/javascript" src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function(){$('#btn').click(function(){$('.box').animate({'width':600},1000,function(){$('.box').animate({'height':400},1000,function(){$('.box').animate({'opacity':0});});});})$('#btn2').click(function(){$('.box2').stop().animate({'width':'+=100'});})})</script><style type="text/css">.box,.box2{width:100px;height:100px;background-color:gold;}</style>
</head>
<body><input type="button" name="" value="动画" id="btn"><div class="box"></div><br /><br /><input type="button" name="" value="动画" id="btn2"><div class="box2"></div>
</body>
</html>
滑动选项卡案例:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><style type="text/css">.btns input{width:100px;height:40px;background-color:#ddd;border:0;outline:none;}.btns .current{background-color:gold;}.cons{width:500px;height:300px;overflow:hidden;position:relative;}.slides{width:1500px;height:300px;position:absolute;left:0;top:0;}.cons .slides div{width:500px;height:300px;background-color:gold;text-align:center;line-height:300px;font-size:30px;float:left;}.cons .active{display: block;}</style><script type="text/javascript" src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function(){var $btn = $('.btns input');var $slides = $('.cons .slides');$btn.click(function(){// this 指的是原生的this,它表示当前点击的对象,使用jquery的对象需要用$(this)// 当前点击的按钮加上current样式后,除了当前,其他的按钮去掉current样式$(this).addClass('current').siblings().removeClass('current');$slides.stop().animate({'left':-500*$(this).index()});})})</script>
</head>
<body><div class="btns"><input type="button" name="" value="01" class="current"><input type="button" name="" value="02"><input type="button" name="" value="03"></div> <div class="cons"><div class="slides"><div>选项卡一的内容</div><div>选项卡二的内容</div><div>选项卡三的内容</div></div></div>
</body>
</html>
9.尺寸相关、滚动事件
1、获取和设置元素的尺寸
width()、height() 获取元素width和height
innerWidth()、innerHeight() 包括padding的width和height
outerWidth()、outerHeight() 包括padding和border的width和height
outerWidth(true)、outerHeight(true) 包括padding和border以及margin的width和height
2、获取元素相对页面的绝对位置
offset()
加入购物车案例:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><style type="text/css">.chart{width:150px;height:50px;border:2px solid #000;text-align:center;line-height:50px;float:right;margin-right:100px;margin-top:50px;}.chart em{font-style: normal;color:red;font-weight:bold;}.add{width:100px;height:50px;background-color:green;border:0;color:#fff;float:left;margin-top:300px;margin-left:300px;}.point{width:16px;height:16px;background-color:red;position:fixed;left:0;top:0;display:none;z-index:9999;border-radius:50%;}</style><script type="text/javascript" src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function(){var $chart = $('.chart');var $count = $('.chart em');var $btn = $('.add');var $point = $('.point');var $w01 = $btn.outerWidth();var $h01 = $btn.outerHeight();var $w02 = $chart.outerWidth();var $h02 = $chart.outerHeight();$btn.click(function(){var oPos01 = $btn.offset();var oPos02 = $chart.offset();$point.css({'left':oPos01.left+parseInt($w01/2)-8,'top':oPos01.top+parseInt($h01/2)-8});$point.show();$point.stop().animate({'left':oPos02.left+parseInt($w02/2)-8,'top':oPos02.top+parseInt($h02/2)-8},800,function(){$point.hide();var iNum = $count.html();$count.html(parseInt(iNum)+1);});})});</script>
</head>
<body><div class="chart">购物车<em>0</em></div><input type="button" name="" value="加入购物车" class="add"><div class="point"></div>
</body>
</html>
3、获取浏览器可视区宽度高度
$(window).width();
$(window).height();
4、获取页面文档的宽度高度
$(document).width();
$(document).height();
5、获取页面滚动距离
$(document).scrollTop();
$(document).scrollLeft();
6、页面滚动事件
$(window).scroll(function(){ ......
})
置顶菜单案例
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><style type="text/css">body{margin:0;}.banner{width:960px;height:200px;background-color:cyan;margin:0 auto;}.menu{width:960px;height:80px;background-color:gold;margin:0 auto;text-align:center;line-height:80px;}.menu_back{width:960px;height:80px;margin:0 auto;display:none;}p{text-align:center;color:red;}.totop{width:60px;height:60px;background-color:#000;color:#fff;position:fixed;right:20px;bottom:50px;line-height:60px;text-align:center;font-size:40px;border-radius:50%;cursor:pointer;display:none;}</style><script type="text/javascript" src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function(){$menu = $('.menu');$menu_back = $('.menu_back');$totop = $('.totop');$(window).scroll(function(){//console.log('abc');var iNum = $(document).scrollTop();//document.title = iNum;if(iNum>200){$menu.css({'position':'fixed','left':'50%','top':0,'marginLeft':-480});$menu_back.show();}else{$menu.css({'position':'static', 'marginLeft':'auto'});$menu_back.hide();}if(iNum>400){$totop.fadeIn();}else{$totop.fadeOut();}})$totop.click(function(){$('html,body').animate({'scrollTop':0});})})</script>
</head>
<body><div class="banner"></div><div class="menu">菜单</div><div class="menu_back"></div><div class="totop">↑</div><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><p>文档内容</p><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /></body>
</html>
10.jquery属性操作
1、html() 取出或设置html内容
// 取出html内容var $htm = $('#div1').html();// 设置html内容$('#div1').html('<span>添加文字</span>');
2、prop() 取出或设置某个属性的值
// 取出图片的地址var $src = $('#img1').prop('src');// 设置图片的地址和alt属性$('#img1').prop({src: "test.jpg", alt: "Test Image" });
11.jquery循环
对jquery选择的对象集合分别进行操作,需要用到jquery循环操作,此时可以用对象上的each方法:
例子:
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><script type="text/javascript" src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function(){var $li = $('.list li');//$li.css({'backgroundColor':'gold'});$li.each(function(a){//alert(a);//alert( $(this).html() );//alert($(this).index());if($(this).index()%2==0){$(this).css({'backgroundColor':'gold'});}})})</script>
</head>
<body><ul class="list"><li>1</li><li>2</li><li>3</li><li>4</li><li>5</li><li>6</li><li>7</li><li>8</li></ul>
</body>
</html>
效果图:
12.jquery事件
12.1 事件函数列表:
blur() 元素失去焦点
focus() 元素获得焦点
click() 鼠标单击
mouseover() 鼠标进入(进入子元素也触发)
mouseout() 鼠标离开(离开子元素也触发)
mouseenter() 鼠标进入(进入子元素不触发)
mouseleave() 鼠标离开(离开子元素不触发)
hover() 同时为mouseenter和mouseleave事件指定处理函数
ready() DOM加载完成
resize() 浏览器窗口的大小发生改变
scroll() 滚动条的位置发生变化
submit() 用户递交表单
12.2 绑定事件的其他方式
$(function(){$('#div1').bind('mouseover click', function(event) {alert($(this).html());});
});
12.3 取消绑定事件
$(function(){$('#div1').bind('mouseover click', function(event) {alert($(this).html());// $(this).unbind();$(this).unbind('mouseover');});
});
13.事件冒泡
13.1 什么是事件冒泡
在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理程序或者事件返回true,那么这个事件会向这个对象的父级对象传播,从里到外,直至它被处理(父级对象所有同类事件都将被激活),或者它到达了对象层次的最顶层,即document对象(有些浏览器是window)
13.2 事件冒泡的作用
事件冒泡允许多个操作被集中处理(把事件处理器添加到一个父级元素上,避免把事件处理器添加到多个子级元素上),它还可以让你在对象层的不同级别捕获事件。
13.2 阻止事件冒泡
事件冒泡机制有时候是不需要的,需要阻止掉,通过 event.stopPropagation()来阻止
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><script type="text/javascript" src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function(){// event 是发生事件的时候的事件对象,使用的时候,通过第一个参数传进来$('.son').click(function(event){alert(1);//通过event对象上的stopPropagation的方法阻止事件冒泡// event.stopPropagation();})$('.father').click(function(event){alert(2);event.stopPropagation();}) $('.grandfather').click(function(){alert(3);// 阻止事件冒泡和阻止默认行为的统一写法:return false;})$(document).click(function(){alert(4);})})</script><style type="text/css">.grandfather{width:300px;height:300px;background-color:green;position:relative;}.father{width:200px;height:200px;background-color:gold;}.son{width:100px;height:100px;background-color: red;position:absolute;left:0;top:400px;}</style>
</head>
<body><div class="grandfather"> <div class="father"> <div class="son"></div></div></div>
</body>
</html>
阻止默认行为
阻止表单提交
$('#form1').submit(function(event){event.preventDefault();
})
合并阻止操作
实际开发中,一般把阻止冒泡和阻止默认行为合并起来来,合并写法可以用
// event.stopPropagation();
// event.preventDefault();// 合并写法:
return false;
案例:弹框
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><script type="text/javascript" src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function(){$('#btn').click(function(){$('.pop_con').fadeIn();return false;})$(document).click(function(){$('.pop_con').fadeOut();})$('.pop').click(function(){return false;})$('#close').click(function(){$('.pop_con').fadeOut();})})</script><style type="text/css">.pop_con{display:none;} .pop{position:fixed;width:500px;height:300px;background-color:#fff;border:3px solid #000;left:50%;top:50%;margin-left:-250px;margin-top:-150px;z-index:9999;}.mask{position:fixed;width:100%;height:100%;background-color:#000;opacity:0.3;filter:alpha(opacity=30);left:0;top:0;z-index:9990;}.close{float:right;font-size:30px;}</style>
</head>
<body><input type="button" name="" value="弹出" id="btn"><div class="pop_con"><div class="pop">弹框里面文字投资金额:<input type="text" name=""><a href="#" id="close" class="close">×</a></div><div class="mask"></div></div>
</body>
</html>
效果图:
14.事件原委
事件委托就是利用冒泡的原理,把事件加到父级上,通过判断事件来源的子集,执行相应的操作,事件委托首先可以极大减少事件绑定次数,提高性能;其次可以让新加入的子元素也可以拥有相同的操作。
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><style type="text/css">.list{background-color:gold;list-style:none;padding:10px;}.list li{height:30px;background-color:green;margin:10px;}</style><script type="text/javascript" src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function(){//事件委托,将li要发生的事件委托给li的父级$('.list').delegate('li','click',function(){//$(this) 指的是委托的子元素$(this).css({'backgroundColor':'red'});})var $li = $('<li>9</li>');$('.list').append($li);})</script>
</head><body><ul class="list"><li>1</li><li>2</li><li>3</li><li>4</li><li>5</li><li>6</li><li>7</li><li>8</li></ul>
</body>
</html>
点击就会变红
15.jquery元素节点操作
创建节点
var $div = $('<div>');
var $div2 = $('<div>这是一个div元素</div>');
插入节点
1、append()和appendT0():在现存元素的内部,从后面插入元素
var $span = $('<span>这是一个span元素</span>');
$('#div1').append($span);
......
<div id="div1"></div>
2、prepend()和prependTo():在现存元素的内部,从前面插入元素
3、after()和insertAfter():在现存元素的外部,从后面插入元素
4、before()和insertBefore():在现存元素的外部,从前面插入元素
删除节点
$('#div1').remove();
16.滚轮事件与函数节流
16.1 jquery.mousewheel插件使用
jquery中没有鼠标滚轮事件,原生js中的鼠标滚轮事件不兼容,可以使用jquery的滚轮事件插件jquery.mousewheel.js。
16.2 函数节流
javascript中有些事件的触发频率非常高,比如onresize事件(jq中是resize),onmousemove事件(jq中是mousemove)以及上面说的鼠标滚轮事件,在短事件内多处触发执行绑定的函数,可以巧妙地使用定时器来减少触发的次数,实现函数节流。
17.json
json是JavaScript Object Notation 的首字母缩写,单词的意思是javascript对象表示法,这里说的json指的是类似于javascript对象的一种数据格式,目前这种数据格式比较流行,逐渐替换掉了传统的xml数据格式。
javascript自定义对象:
var owomen={name:'pxy',age:'27,talk:function(s){alert('我会说'+s);}
}
json格式的数据:
{"name":"pxy","age":27
}
与json对象不同的是,json数据格式的属性名称和字符串值需要用双引号引起来,用单引号或者不用引号会导致读取数据错误。
json的另外一个数据格式是数组,和javascript中的数组字面量相同。
["pxy",27,"beauty"]
18.ajax与jsonp
ajax技术的目的是让javascript发送http请求,与后台通信,获取数据和信息。ajax技术的原理是实例化xmlhttp对象,使用此对象与后台通信,ajax通信的过程不会影响后续javascript的执行,从而实现异步。
18.1 同步和异步
现实生活中,同步指的是同时做几件事情,异步指的是做完一件事后再做另外一件事,程序中的同步和异步是把现实生活中的概念对调,也就是程序中的异步指的是现实生活中的同步,程序中的同步指的是现实生活中的异步。
18.2 局部刷新和无刷新
ajax可以实现局部刷新,也叫做无刷新,无刷新指的是整个页面不刷新,只是局部刷新,ajax可以自己发送http请求,不用通过浏览器的地址栏,所以页面整体不会刷新,ajax获取到后台数据,更新页面显示数据的部分,就做到了页面局部刷新。
18.3 同源策略
ajax请求的页面或资源只能是同一个域下面的资源,不能是其他域的资源,这是在设计ajax时基于安全的考虑。特征报错提示:
XMLHttpRequest cannot load https://www.baidu.com/. No
'Access-Control-Allow-Origin' header is present on the requested resource.
Origin 'null' is therefore not allowed access.
18.4 $.ajax使用方法
常用参数:
1、url请求地址
2、type请求方式,默认是 ‘GET’,常用的还有'POST'
3、dataType 设置返回的数据格式,常用的是'json'格式,也可以设置为’html’
4、data 设置发送给服务器的数据
5、success 设置请求成功后的回调函数
6、error 设置请求失败后的回调函数
7、async 设置是否异步,默认值是'true',表示异步
以前的写法:
$.ajax({url:'js/data.json',type:'GET',dataType:'json',data:{'aa;:1},success:function(data){alert(data.name);},error:function(){alert('服务器超时,请重试!')}})
新的写法(推荐):
$.ajax({url:'js/data.json',type:'GET',dataType:'json',data:{'aa':1}
}).done(function(data){alert(data.name);
}).fail(function(){alert('服务器超时,请重试!';
})
// data.json里面的数据: {"name":"tom","age":18}
18.5 案例:首页用户信息读取
18.6 jsonp
ajax只能请求同一个域下的数据域或资源,有时候需要跨域请求数据,就需要用到jsonp技术,jsonp可以跨域请求数据,它的原理主要是利用了<script>标签可以跨域链接资源的特性。jsonp和ajax原理完全不一样,不过jquery将它们封装成同一个函数。
$.ajax({url:'js/data.js',type:'get',dataType:'jsonp',jsonpCallback:'fnBack'
});.done(function(data){alert(data.name);
});.fail(function(){alert('服务器超时,请重试!');
});// data.js里面的数据: fnBack({"name":"tom","age":18});
案例:获取360搜索关键词联想数据
19.本地存储
本地存储分为cookie,以及新增的localStorage和sessionStorage
1、cookie存储在本地,容量最大4k,在同源的http请求时携带传递,损耗带宽,可以设置访问路径,只有此路径及此路径的子路径才能访问cookie,在设置的过期时间之前有效。
2、localStorage 存储在本地,容量为5M或者更大,不会再请求时候携带传递,在所有同源窗口中共享,数据一直有效,除非人为删除,可作为长期数据。
//设置:
localStorage.setItem("dat", "456");
localStorage.dat = '456';//获取:
localStorage.getItem("dat");
localStorage.dat//删除
localStorage.removeItem("dat");
3、sessionStorage存储在本地,容量为5M或者更大,不会在请求时候携带传递,在同源的当前窗口关闭前有效。
localStorage和sessionStorage 合称为Web Storage,Web Storage支持事件通知机制,可以将数据更新的通知监听者,Web Storage的api接口使用更方便。
iPhone的无痕浏览不支持Web Storage,只能用cookie。
20.jquery UI
jquery ui 是以jquery为基础的代码库。包含底层用户交互、动画、特效和可更换主题的可视空间。我们可以直接用它来构建具有很好交互性的web应用程序。
jqueryUI 网址
jQuery UI