jquery相关操作--但是高级有些不太明白

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、http://jquery.com/ 官方网站
2、https://code.jquery.com/ 版本下载

jquery文档加载完再执行

将获取元素的语句写到页面头部,会因为元素还没有加载而出错,jquery提供了ready方法解决这个问题,它的速度比原生的 window.onload 更快。

<script type="text/javascript">$(document).ready(function(){......});
可以简写为:
<script type="text/javascript">$(function(){......});</script>

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><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>window.onload = function(){var oDiv = document.getElementById('div01');alert('原生javascript获取div;'+oDiv); //原生javascript获取div;[object HTMLDivElement]}//这个会先执行// $(document).ready(function(){//     var $div = $('#div01');//     alert('jquery获取的div:'+$div); //jquery获取的div:[object Object]// })// 上面ready的写法可以简写成下面的形式:$(function(){var $div = $('#div01');alert('jquery1获取的div:'+$div); //jquery获取的div:[object Object]})</script>
</head>
<body><div id="div01">这是一个div</div>
</body>
</html>

jquery选择器

jquery用法思想一
选择某个网页元素,然后对它进行某种操作

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元素

对选择集进行过滤

$('div').has('p'); // 选择包含p元素的div元素
$('div').not('.myClass'); //选择class不等于myClass的div元素
$('div').eq(5); //选择第6个div元素

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><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(){//id选择器var $div = $('#div01');//类选择器var $div2 = $('.box');// 选择所有的li元素==>标签选择器var $li = $('li');//层级选择器var $span = $('.box span');//属性选择器var $div3 = $('div[class="box2"]');//选择包含span标签的divvar $div4 = $('div').has('span');//选择class并不是box2的divvar $div5 = $('div').not('.box2');// 选择第4个livar $li2 = $('li').eq(3);//设置样式$div.css({'color':'red','font-size':30});$div2.css({'color':'gold','fontSize':'30px'});$li.css({'background':'gold','list-style':'none'});//font-weight加粗$span.css({'color':'red','font-weight':'bold'});$div3.css({'color':'pink','font-size':30});//text-indent 缩进$div4.css({'text-indent':50});//text-decoration 下划线$div5.css({'text-decoration':'underline'});$li2.css({'text-indent':50});})</script>
</head>
<body><div id="div01">这是一个div</div><div class="box">这是第二个<span>div</span></div><div class="box">这是第三个div</div><div class="box2">这是第四个div</div><ul><li>列表文字</li><li>列表文字</li><li>列表文字</li><li>列表文字</li><li>列表文字</li><li>列表文字</li></ul>
</body>
</html>

选择集转移

$('#box').prev(); //选择id是box的元素前面紧挨的同辈元素
$('#box').prevAll(); //选择id是box的元素之前所有的同辈元素
$('#box').next(); //选择id是box的元素后面紧挨的同辈元素
$('#box').nextAll(); //选择id是box的元素后面所有的同辈元素
$('#box').parent(); //选择id是box的元素的父元素
$('#box').children(); //选择id是box的元素的所有子元素
$('#box').siblings(); //选择id是box的元素的同级元素
$('#box').find('.myClass'); //选择id是box的元素内的class等于myClass的元素

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><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(){//id选择器var $div = $('#div01');//$('#box').prev(); //选择id是box的元素前面紧挨的同辈元素$div.prev().css({'color':'red'});//p标签// $('#box').prevAll(); //选择id是box的元素之前所有的同辈元素//text-indent缩进$div.prevAll().css({'text-indent':50});// h2 p// $('#box').next(); //选择id是box的元素后面紧挨的同辈元素$div.next().css({'color':'pink'});//h3// $('#box').nextAll(); //选择id是box的元素后面所有的同辈元素$div.nextAll().css({'text-indent':30}); // h3 p// $('#box').parent(); //选择id是box的元素的父元素$div.parent().css({'background':'#ddd'}); //父级div// $('#box').children(); //选择id是box的元素的所有子元素$div.children().css({'color':'red'});// $('#box').siblings(); //选择id是box的元素的同级元素$div.siblings().css({'text-decoration':'underline'}); // h2 p h3 p// $('#box').find('.myClass'); //选择id是box的元素内的class等于myClass的元素$div.find('.sp02').css({'font-size':70});})</script>
</head>
<body><div><h2>这是一个h2标题</h2><p>这是第一个段落标签</p><div id="div01">这是一个<span>div</span><span class="sp02">第二个span</span></div><h3>这是一个h3标题</h3><p>这是第二个段落标签</p></div>
</body>
</html>

判断是否选择到了元素
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>

jquery样式操作

jquery用法思想二
同一个函数完成取值和赋值

操作行间样式

// 获取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。

操作样式类名

$("#div1").addClass("divClass2") //为id为div1的对象追加样式divClass2
$("#div1").removeClass("divClass")  //移除id为div1的对象的class名为divClass的样式
$("#div1").removeClass("divClass divClass2") //移除多个样式
$("#div1").toggleClass("anotherClass") //重复切换anotherClass样式

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script src="js/jquery-1.12.4.min.js"></script><style>.red{color:red;}.big{font-size:30px;}.noline{text-decoration:none;}</style><script>$(function(){var $div = $('#div01');var $div2 = $('div');var $a = $('#link01');//读取样式属性值var sSize = $div.css('font-size'); //文字大小默认是16px// alert(sSize);//16px//写样式属性,也叫设置样式属性// 设置一个样式属性可以不写成字典的形式$div.css('color','red');//font-weight 加粗$div.css({'font-size':30,'font-weight':'bold'});//读取多个元素样式属性值,得到的是第一个元素的值var sSize2 = $div2.css('font-size');// alert(sSize2);//30px//操作样式类名// $("#div1").addClass("divClass2") //为id为div1的对象追加样式divClass2$a.addClass('red');$a.addClass('big');$a.addClass('noline');// $("#div1").removeClass("divClass")  //移除id为div1的对象的class名为divClass的样式// $("#div1").removeClass("divClass divClass2") //移除多个样式$a.removeClass('red');$a.removeClass('noline');})</script>
</head>
<body><div id="div01">这是一个div</div><div>这是第二个div</div><a href="#" id="link01">这是一个链接</a>
</body>
</html>

绑定click事件

给元素绑定click事件,可以用如下方法:

$('#btn1').click(function(){// 内部的this指的是原生对象// 使用jquery对象用 $(this)})

获取元素的索引值
有时候需要获得匹配元素相对于其同胞元素的索引位置,此时可以用index()方法获取

var $li = $('.list li').eq(1);
alert($li.index()); // 弹出1
......
<ul class="list"><li>1</li><li>2</li><li>4</li><li>5</li><li>6</li>
</ul>

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><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');//选中八个livar $p = $('p');//绑定click事件$li.click(function(){//this表示当前发生的对象,他是一个原生js对象 点哪一个就是哪一个是this// this.style.background = 'red';  //原生对象//$(this)表示当前发生事件的jquery对象$(this).css('background','gold');//获取当前点击的li的索引值// alert($(this).index());})alert($p.eq(0).index()); //0alert($p.eq(1).index()); //0})</script>
</head>
<body><ul class="list"><li>列表文字</li><li>列表文字</li><li>列表文字</li><li>列表文字</li><li>列表文字</li><li>列表文字</li><li>列表文字</li><li>列表文字</li></ul><div><p>这是第一个段落</p></div><div><p>这是第二个段落</p></div>
</body>
</html>

选项卡案例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><style>.tab_con{width:500px;height:350px;margin:50px auto 0;}.tab_btns{height:50px;}.tab_btns input{width:100px;height:50px;background:#ddd;border:0px;/* 轮廓 */outline:none;}.tab_btns .active{background:gold;}.tab_cons{height:300px;background:gold;}.tab_cons div{height:300px;line-height:300px;text-align:center;display:none;font-size:30px;}.tab_cons .current{/* 转换位块元素 */display:block;}</style><script src="js/jquery-1.12.4.min.js"></script><script>$(function(){//选择三个按钮var $btn = $('.tab_btns input');// alert($btn.length);//选择三个divvar $div = $('.tab_cons div');$btn.click(function(){//addClass当前添加class=active//siblings 反选到兄弟节点上//removeClass 移除class = active$(this).addClass('active').siblings().removeClass('active');// alert( $(this).index() );$div.eq($(this).index()).addClass('current').siblings().removeClass('current');})})</script>
</head><body><div class="tab_con"><div class="tab_btns"><input type="button" value="按钮一" class="active"><input type="button" value="按钮二"><input type="button" value="按钮三"></div><div class="tab_cons"><div class="current">按钮一对应的内容</div><div>按钮二对应的内容</div><div>按钮三对应的内容</div></div></div>
</body>
</html>

jquery动画

通过animate方法可以设置元素某属性值上的动画,可以设置一个或多个属性值,动画执行完成后会执行一个函数。

/*animate参数:参数一:要改变的样式属性值,写成字典的形式参数二:动画持续的时间,单位为毫秒,一般不写单位参数三:动画曲线,默认为‘swing’,缓冲运动,还可以设置为‘linear’,匀速运动参数四:动画回调函数,动画完成后执行的匿名函数*/$('#div1').animate({width:300,height:300
},1000,'swing',function(){alert('done!');
});

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script src="js/jquery-1.12.4.min.js"></script><style>.box{width: 200px;height: 200px;background: gold;}</style><script>$(function(){var $btn = $('#btn');var $box = $('.box');$btn.click(function(){// $box.css({'width':1000})// $box.animate({'width':1000});/* animate的参数参数一:要做动画的样式属性,写成字典形式参数二:动画持续的时间,默认是400毫秒,设置时不写单位参数三:动画曲线,默认是'swing',缓冲运动,还有'linear' 匀速运动 可以不写参数四:动画的回调函数,它是一个匿名函数,在动画结束时会自动调用*/// $box.animate({'width':1000},1000,'swing');// $box.animate({'width':1000},1000,'swing',function(){//     alert('动画完毕');// });$box.animate({'width':1000},1000,'swing',function(){$box.animate({'margin-top':400},1000,function(){$box.animate({'width':200,'margin-top':0},1000);});});})})//持续动$(function(){var $btn = $('#btn');var $box = $('.box');$btn.click(function fnMove(){//$box.css({'width':1000});// $box.animate({'width':1000});/* animate的参数参数一:要做动画的样式属性,写成字典形式参数二:动画持续的时间,默认是400毫秒,设置时不写单位参数三:动画曲线,默认是'swing',缓冲运动,还有'linear' 匀速运动参数四:动画的回调函数,它是一个匿名函数,在动画结束时会自动调用*/$box.animate({'width':1000},1000,'swing',function(){                    $box.animate({'margin-top':400},1000,function(){                        $box.animate({'width':200,'margin-top':0},1000,function(){fnMove();})})});                })})</script></head>
<body><input type="button" value="动画" id="btn"><div class="box"></div>
</body>
</html>

jquery特殊效果

fadeIn() 淡入$btn.click(function(){$('#div1').fadeIn(1000,'swing',function(){alert('done!');});});

fadeOut() 淡出
fadeToggle() 切换淡入淡出
hide() 隐藏元素
show() 显示元素
toggle() 切换元素的可见状态
slideDown() 向下展开
slideUp() 向上卷起
slideToggle() 依次展开或卷起某个元素

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head><style>.box{width: 200px;height: 200px;background: gold;display: none;}</style>
<script src="js/jquery-1.12.4.min.js"></script><script>$(function(){var $btn = $('#btn');var $box = $('.box');$btn.click(function(){//元素显示隐藏效果// hide() 隐藏元素//  $box.hide(); //display: none;相当于隐藏// show() 显示元素// $box.show(); //display: block相当于显示// toggle() 切换元素的可见状态// $box.toggle();//元素淡入淡出效果// fadeIn() 淡入// $box.fadeIn(); //先默认隐藏// fadeOut() 淡出// $box.fadeOut(); //先默认是显示// fadeToggle() 切换淡入淡出// $box.fadeToggle();// slideUp() 向上卷起//  $box.slideUp();// slideDown() 向下展开// $box.slideDown();// slideToggle() 依次展开或卷起某个元素// $box.slideToggle();//slideToggle特性 解决这个问题stop记录之前的动画全部停止,保留最后一次$box.stop().slideToggle();})})
</script><body><input type="button" value="动画" id="btn"><div class="box"></div>
</body>
</html>

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 src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function(){var $a = $('.level1');$a.click(function(){// $(this).next().stop().slideToggle();//parent转移到父级 siblings转移到li$(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="#">iPhone X 256G</a></li><li><a href="#">红米4A 全网通</a></li><li><a href="#">HUAWEI Mate10</a></li><li><a href="#">vivo X20A 4GB</a></li></ul></li><li><a href="#" class="level1">笔记本</a><ul><li><a href="#">MacBook Pro</a></li><li><a href="#">ThinkPad</a></li><li><a href="#">外星人(Alienware)</a></li><li><a href="#">惠普(HP)薄锐ENVY</a></li></ul></li><li><a href="#" class="level1">电视</a><ul><li><a href="#">海信(hisense)</a></li><li><a href="#">长虹(CHANGHONG)</a></li><li><a href="#">TCL彩电L65E5800A</a></li>				</ul></li><li><a href="#" class="level1">鞋子</a><ul><li><a href="#">新百伦</a></li><li><a href="#">adidas</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>

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" });

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><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 $a = $('#link01');//读取属性值var sId = $a.prop('id');// alert(sId);//link01//写属性值,也叫做设置属性值$a.prop({'href':'http://www.baidu.com','title':'这是百度的链接'});//读取元素包裹的内容var sTr = $a.html();// alert(sTr); //这是一个链接//设置元素包裹的内容$a.html('百度网');// 不规范,可以这样做$a.html('<ul><li>列表文字</li><li>列表文字</li><li>列表文字</li></ul>')})</script>
</head>
<body><a href="#" id="link01">这是一个链接</a>
</body>
</html>

聊天对话框实现

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Document</title><style type="text/css">.talk_con{width:600px;height:500px;border:1px solid #666;margin:50px auto 0;background:#f9f9f9;}.talk_show{width:580px;height:420px;border:1px solid #666;background:#fff;margin:10px auto 0;overflow:auto;}.talk_input{width:580px;margin:10px auto 0;}.whotalk{width:80px;height:30px;float:left;outline:none;}.talk_word{width:420px;height:26px;padding:0px;float:left;margin-left:10px;outline:none;text-indent:10px;}        .talk_sub{width:56px;height:30px;float:left;margin-left:10px;}.atalk{margin:10px; }.atalk span{display:inline-block;background:#0181cc;border-radius:10px;color:#fff;padding:5px 10px;}.btalk{margin:10px;text-align:right;}.btalk span{display:inline-block;background:#ef8201;border-radius:10px;color:#fff;padding:5px 10px;}</style><script src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">      // 写出对应功能代码  $(function(){var $words = $('#words'), $who = $('#who'),$talkwords = $('#talkwords');$talksub = $('#talksub');$talksub.click(function(){//  // 读取属性值// var sVal01 = $who.prop('value'); //读取下拉框的值// var sVal02 = $talkwords.prop('value'); //读取输入框的值// alert(sVal02);// //清除输入框里面的内容// $talkwords.prop({'value':''});//操作value属性可以改成下面的val方法的写法://读取属性值var sVal01 = $who.val();var sVal02 = $talkwords.val();//清除输入框里面的内容$talkwords.val('');//判断输入框是否为空if(sVal02 == ''){alert('请输入内容!');return;}//拼接字符串var sTr = '';if(sVal01==0){sTr = '<div class="atalk"><span>A说:'+ sVal02 +'</span></div>';}else{sTr = ' <div class="btalk"><span>B说:'+ sVal02 +'</span></div>';}// alert($words.html());$words.html($words.html()+sTr);})})</script>
</head>
<body><div class="talk_con"><div class="talk_show" id="words"><div class="atalk"><span>A说:吃饭了吗?</span></div><div class="btalk"><span>B说:还没呢,你呢?</span></div></div><div class="talk_input"><select class="whotalk" id="who"><option value="0">A说:</option><option value="1">B说:</option></select><input type="text" class="talk_word" id="talkwords"><input type="button" value="发送" class="talk_sub" id="talksub"></div></div>
</body>
</html>

jquery事件

事件函数列表:

blur() 元素失去焦点
focus() 元素获得焦点
change() 当表单元素的值发生改变时
click() 鼠标单击
mouseover() 鼠标进入(进入子元素也触发)
mouseout() 鼠标离开(离开子元素也触发)
mouseenter() 鼠标进入(进入子元素不触发)
mouseleave() 鼠标离开(离开子元素不触发)
ready() DOM加载完成
submit() 用户递交表单

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><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 $input = $('#input01');var $form = $('#from01');// $input.click(function(){//     alert($(this).val());// })//绑定失去焦点的事件$input.blur(function(){// alert($(this).val());})$form.submit(function(){// alert('提交了!');//判断数据是否合法//阻止表单提交return false;})})</script>
</head>
<body><form id="from01"><label>用户名:</label><input type="text" id="input01" name="username"><input type="submit" value="提交"></form>
</body>
</html>

focus和change事件

change() 当表单元素的值发生改变时和focus() 元素获得焦点–不太理解focus

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><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 $input = $('#input01');//绑定获取焦点的事件// $input.focus(function(){//     console.log('aaaa');// alert( $(this).val() );// })// 在focus上绑定函数会反复触发,一般不这么用,可以用click事件代替// focus一般用在让元素起始就获得焦点$input.focus();// 绑定change事件$input.change(function(){console.log( $(this).val() );})})</script>
</head>
<body><input type="text" id="input01">
</body>
</html>

mouseover() 鼠标进入(进入子元素也触发)
mouseout() 鼠标离开(离开子元素也触发)
mouseenter() 鼠标进入(进入子元素不触发)
mouseleave() 鼠标离开(离开子元素不触发)

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.box{width: 200px;height: 200px;background: gold;margin: 50px auto;}.box2{width: 100px;height: 100px;background: green;}</style><script src="js/jquery-1.12.4.min.js"></script><script>$(function(){var $box = $('.box');// //绑定鼠标移入事件// $box.mouseover(function(){//     $(this).animate({'margin-top':100});// })// //绑定鼠标移出事件// $box.mouseout(function(){//     $(this).animate({'margin-top':50});// })// 上面的移入移出事件,移到子元素也会触发,如果不希望触发,可以改成下面的形式://绑定鼠标移入事件$box.mouseenter(function(){$(this).animate({'margin-top':100});})//绑定鼠标移出事件$box.mouseleave(function(){$(this).animate({'margin-top':50});})})</script>
</head>
<body><div class="box"><div class="box2"></div></div>
</body>
</html>

表单验证

1、什么是正则表达式:
能让计算机读懂的字符串匹配规则。

2、正则表达式的写法:

var re=new RegExp('规则', '可选参数');
var re=/规则/参数;

3、规则中的字符

1)普通字符匹配:
如:/a/ 匹配字符 ‘a’,/a,b/ 匹配字符 ‘a,b’2)转义字符匹配:
\d 匹配一个数字,即0-9
\D 匹配一个非数字,即除了0-9
\w 匹配一个单词字符(字母、数字、下划线)
\W 匹配任何非单词字符。等价于[^A-Za-z0-9_]
\s 匹配一个空白符
\S 匹配一个非空白符
. 匹配一个任意字符var sTr01 = '123456asdf';
var re01 = /\d+/;

//匹配纯数字字符串

var re02 = /^\d+$/;
alert(re01.test(sTr01)); //弹出true
alert(re02.test(sTr01)); //弹出false

4、量词:对左边的匹配字符定义个数

? 出现零次或一次(最多出现一次)
+ 出现一次或多次(至少出现一次)
* 出现零次或多次(任意次)
{n} 出现n次
{n,m} 出现n到m次
{n,} 至少出现n次

5、任意一个或者范围

[abc123] : 匹配‘abc123’中的任意一个字符
[a-z0-9] : 匹配a到z或者0到9中的任意一个字符

6、限制开头结尾

^ 以紧挨的元素开头
$ 以紧挨的元素结尾

7、修饰参数:

g: global,执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)
i: ingore case,忽略大小写,默认大小写敏感

8、常用方法
test
用法:正则.test(字符串) 匹配成功,就返回真,否则就返回假

正则默认规则
匹配成功就结束,不会继续匹配,区分大小写

常用正则规则

//用户名验证:(数字字母或下划线6到20位)
var reUser = /^\w{6,20}$/;//邮箱验证:        
var reMail = /^[a-z0-9][\w\.\-]*@[a-z0-9\-]+(\.[a-z]{2,5}){1,2}$/i;//密码验证:
var rePass = /^[\w!@#$%^&*]{6,20}$/;//手机号码验证:
var rePhone = /^1[34578]\d{9}$/;

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script>//定义正则表达式var reTest01 = /a/;var reTest02 = /a/i; //i 忽略大小写var reTest03 = /\d+/; //+出现1次到多次var reTest04 = /^\d+$/; //^开头是数字,$结尾也是数字var sTr01 = 'abc';var sTr02 = 'Abc';var sTr03 = '123456';var sTr04 = '123456abcdef';// alert(reTest01.test(sTr01)); //true// alert(reTest01.test(sTr02)); //false// alert(reTest02.test(sTr02)); //true// alert(reTest03.test(sTr03)); //true// alert(reTest03.test(sTr04)); //true 只要前面有数字就OK了alert(reTest04.test(sTr03)); //truealert(reTest04.test(sTr04)); //false</script>
</head>
<body></body>
</html>

事件冒泡

什么是事件冒泡
在一个对象上触发某类事件(比如单击onclick事件),如果此对象定义了此事件的处理程序,那么此事件就会调用这个处理程序,如果没有定义此事件处理程序或者事件返回true,那么这个事件会向这个对象的父级对象传播,从里到外,直至它被处理(父级对象所有同类事件都将被激活),或者它到达了对象层次的最顶层,即document对象(有些浏览器是window)。

事件冒泡的作用
事件冒泡允许多个操作被集中处理(把事件处理器添加到一个父级元素上,避免把事件处理器添加到多个子级元素上),它还可以让你在对象层的不同级别捕获事件。

阻止事件冒泡
事件冒泡机制有时候是不需要的,需要阻止掉,通过 event.stopPropagation() 来阻止

$(function(){var $box1 = $('.father');var $box2 = $('.son');var $box3 = $('.grandson');$box1.click(function() {alert('father');});$box2.click(function() {alert('son');});$box3.click(function(event) {alert('grandson');event.stopPropagation();});$(document).click(function(event) {alert('grandfather');});
})......<div class="father"><div class="son"><div class="grandson"></div></div>
</div>

阻止默认行为
阻止表单提交

$('#form1').submit(function(event){event.preventDefault();
})

合并阻止操作
实际开发中,一般把阻止冒泡和阻止默认行为合并起来写,合并写法可以用

// event.stopPropagation();
// event.preventDefault();// 合并写法:
return false;

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.grandfather{width:300px;height:300px;background:purple;}.father{width:200px;height:200px;background:gold;/* 相对定位 */position: relative;}.son{width:100px;height:100px;background:red;/* 绝对定位 */position: absolute;left:0px;top:400px;}</style><script src="js/jquery-1.12.4.min.js"></script><script>$(function(){$('.son').click(function(){alert(1);//阻止事件冒泡的简略写法 只会得到1return false;})// 父级阻止事件冒泡$('.father').click(function(ev){alert(2);// 阻止事件冒泡的完整写法:ev.stopPropagation(); //只会得到2});            $('.grandfather').click(function(){alert(3);})// $(document) 代表最顶级的标签$(document).click(function(){alert(4);});})</script><script src="js/jquery-1.12.4.min.js"></script>
</head>
<body><div class="grandfather"><div class="father"><div class="son"></div></div></div>
</body>
</html>

弹框

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><link rel="stylesheet" href="css/main.css"><title>Document</title><script src="js/jquery-1.12.4.min.js"></script><script type="text/javascript">$(function(){$('#btn01').click(function(){alert('1');$('#pop').show();//按钮阻止click的事件冒泡return false;})$('#shutoff').click(function(){alert('2');$('#pop').hide();});// 点击弹框其他的地方,关闭弹框$(document).click(function(){alert('3');$('#pop').hide();});// 点击弹框,弹框不应该隐藏,所以弹框也需要阻止冒泡$('.pop_con').click(function(){alert('4');return false;})})</script>
</head>
<body><input type="button" value="弹出弹框" id="btn01"><div class="pop_main" id="pop"><div class="pop_con"><div class="pop_title"><h3>系统提示</h3><a href="#" id="shutoff">×</a></div><div class="pop_detail"><p class="pop_text">亲!请关注近期的优惠活动!</p></div><div class="pop_footer"></div></div><div class="mask"></div></div>
</body>
</html>

事件委托

事件委托就是利用冒泡的原理,把事件加到父级上,通过判断事件来源的子集,执行相应的操作,事件委托首先可以极大减少事件绑定次数,提高性能;其次可以让新加入的子元素也可以拥有相同的操作。

一般绑定事件的写法

$(function(){$ali = $('#list li');$ali.click(function() {$(this).css({background:'red'});});
})
...
<ul id="list"><li>1</li><li>2</li><li>3</li><li>4</li><li>5</li>
</ul>
事件委托的写法$(function(){$list = $('#list');$list.delegate('li', 'click', function() {$(this).css({background:'red'});});
})
...
<ul id="list"><li>1</li><li>2</li><li>3</li><li>4</li><li>5</li>
</ul>

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><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 $ul = $('.list');// $li.click(function(){//     $(this).css({'background': 'red'});// })//上面的写法性能不高,可以改成下面事件委托的写法$ul.delegate('li','click',function(){$(this).css({'background': 'red'});})})</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>

Dom操作

Dom操作也叫做元素节点操作,它指的是改变html的标签结构,它有两种情况:
1、移动现有标签的位置
2、将新创建的标签插入到现有的标签中

创建新标签

var $div = $('<div>'); //创建一个空的div
var $div2 = $('<div>这是一个div元素</div>');

移动或者插入标签的方法
1、append()和appendTo():在现存元素的内部,从后面放入元素

var $span = $('<span>这是一个span元素</span>');
$('#div1').append($span);

2、prepend()和prependTo():在现存元素的内部,从前面放入元素

3、after()和insertAfter():在现存元素的外部,从后面放入元素

4、before()和insertBefore():在现存元素的外部,从前面放入元素

删除标签

$('#div1').remove();

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><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 $div = $('#div01');var $p01 = $('#p01');var $h01 = $('#h01');var $p02 = $('#p02');//当前元素的里面的后面要放另外一个元素 把<p id="p01">div01外面的p标签</p>放到了// <div id="div01"><h3>div01里面的h3标题</h3><p>div01里面的p标签</p></div> 后面$div.append($p01);// 当前元素里面的前面要放另外一个元素<h2 id="h01">div01外面的h2标签</h2>放到$div.prepend($h01);// 当前元素要放到另外一个元素里面的前面$h01.prependTo($div);// 当前元素外面的后面要放另外一个元素// $div.after($p02);      // 当前元素要放到另外一个元素的外面的后面$p02.insertAfter($div);// 创建一个新的空的div标签var $newdiv01 = $('<div>');// 创建一个有内容的div标签var $newdiv02 = $('<div>新创建的第二个div</div>');// 当前元素的外面的前面要放另外一个元素$div.before($newdiv01);// 当前元素要放到另外一个元素的外面的前面$newdiv02.insertBefore($div);// 删除标签$newdiv01.remove();$h01.remove();})</script>
</head>
<body><p id="p02">div01上面的p标签</p><p id="p01">div01外面的p标签</p><h2 id="h01">div01外面的h2标签</h2><div id="div01"><h3>div01里面的h3标题</h3><p>div01里面的p标签</p></div>
</body>
</html>

javascript对象

javascript中的对象,可以理解成是一个键值对的集合,键是调用每个值的名称,值可以是基本变量,还可以是函数和对象。

创建javascript对象有两种方法,一种是通过顶级Object类来实例化一个对象,然后在对象上面添加属性和方法:

var person = new Object();// 添加属性:
person.name = 'tom';
person.age = '25';// 添加方法:
person.sayName = function(){alert(this.name);
}// 调用属性和方法:
alert(person.age);
person.sayName();

还可以通过对象直接量的方式创建对象:

var person2 = {name:'Rose',age: 18,sayName:function(){alert('My name is' + this.name);}
}// 调用属性和方法:
alert(person2.age);
person2.sayName();

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><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 person = {name: 'Tom',age:18,showName:function(){alert('我的名字是:'+this.name);},showAge:function(){alert('我的年龄是:'+this.age);}}//使用对象//调用对象的属性alert(person.name);//调用对象的方法person.showName();</script>
</head>
<body></body>
</html>

json

json是 JavaScript Object Notation 的首字母缩写,单词的意思是javascript对象表示法,这里说的json指的是类似于javascript对象的字符串,它同时是一种数据格式,目前这种数据格式比较流行,逐渐替换掉了传统的xml数据格式。

json数据类似于JavaScript中的对象,但是它的键对应的值里面是没有函数方法的,值可以是普通变量,但不支持undefined,值还可以是数组或者JavaScript对象。

json写法需要注意的是,json中的属性名称和字符串值需要用双引号引起来,用单引号或者不用引号会导致读取数据错误。

json格式的数据:

{"name":"tom","age":18
}

json的另外一个数据格式是数组,和javascript中的数组字面量相同。

["tom",18,"programmer"]

还可以是更复杂的数据机构:

{"name":"jack","age":29,"hobby":["reading","travel","photography"]"school":{"name":"Merrimack College","location":'North Andover, MA'}
}

json本质上是字符串,如果在js中操作json数据,可以将json字符串转化为JavaScript对象,转化的方式如下:

var sJson = '{"name":"tom","age":18}';
var oPerson = JSON.parse(sJson);// 操作属性
alert(oPerson.name);
alert(oPerson.age);

示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><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>// 定义一个json数据var sJson = '{\"name":"tom",\"age":18,\"hobby":["study","shopping","singing"],\"school":{"name":"beida","location":"beijing"}\}';// 将json数据转化成JavaScript对象var oJson = JSON.parse(sJson);alert( oJson.name );alert( oJson.hobby[0] );alert( oJson.school.location );</script>
</head>
<body></body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/88629.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Leetcode 386. 字典序排数

文章目录 题目代码&#xff08;9.22 首刷看解析&#xff09; 题目 Leetcode 386. 字典序排数 代码&#xff08;9.22 首刷看解析&#xff09; 迭代DFS class Solution { public:vector<int> lexicalOrder(int n) {vector<int> ret(n);int number 1;for(int i 0…

目标检测YOLO实战应用案例100讲-面向路边停车场景的目标检测(中)

目录 3.1.1 特征图相似度计算 3.1.2 特征图相似度实验 3.1.3 基于GhostBlock的网络结构改进

SVN -基础

SVN - 基础 概念操作步骤开发实际经验 概念 带SVN路径 有隐藏文件&#xff0c;记录repo的一些信息&#xff0c;与repo进行关联&#xff0c;可以与repo进行同步 不带SVN路径 只是单纯的文件&#xff0c;与repo独立 操作步骤 checkout 具有路径 URLcheckout dir 输出目标文件夹…

Flink--6、输出算子(连接到外部系统、文件、kafka、MySQL、自定义Sink)

星光下的赶路人star的个人主页 世间真正温煦的春色&#xff0c;都熨帖着大地&#xff0c;潜伏在深谷 文章目录 1、输出算子&#xff08;Sink&#xff09;1.1 连接到外部系统1.2 输出到文件1.3 输出到Kafka1.4 输出到MySQL&#xff08;JDBC&#xff09;1.4 自定义Sink输出 1、输…

【数学建模】2023华为杯研究生数学建模F题思路详解

强对流降水临近预报 我国地域辽阔&#xff0c;自然条件复杂&#xff0c;因此灾害性天气种类繁多&#xff0c;地区差异大。其中&#xff0c;雷雨大风、冰雹、龙卷、短时强降水等强对流天气是造成经济损失、危害生命安全最严重的一类灾害性天气[1]。以2022年为例&#xff0c;我国…

我的python安装在哪儿了?python安装路径怎么查?

对于 Python 开发者来说&#xff0c;Windows 系统中的 Python 安装路径是非常重要的。在本文中&#xff0c;我们将从多个方面探究如何查看 Python 安装路径&#xff0c;并提供代码示例。 一、使用文件浏览器查看 Python 安装路径 在 Windows 系统中&#xff0c;我们可以使用文…

vue_Delete `␍`eslint(prettier/prettier)

Delete ␍eslint(prettier/prettier) 错误的解决方案 问题背景 在Windows笔记本上新拉完代码&#xff0c;在执行pre-commit时&#xff0c;出现如下错误&#xff1a; Delete ␍eslint(prettier/prettier)问题根源 罪魁祸首是git的一个配置属性&#xff1a;core.autocrlf 由于…

MATLAB实战 | 粮食储仓的通风控制问题

粮食储仓的通风控制问题 01、应用实战 【例1】粮食储仓的通风控制问题。在粮食储备中&#xff0c;合适的湿度是保证粮食质量的前提。一般来说&#xff0c;若粮食水分的吸收和蒸发量相等&#xff0c;这个湿度称为平衡点湿度。只有实际湿度处于平衡点湿度以下&#xff0c;粮食质…

CSS笔记——基本语法及相关知识

CSS层叠样式表是用于定义 HTML 或 XML 文档的样式和布局的语言。它可以让开发者更加灵活地控制页面元素的样式和排版&#xff0c;从而提高页面的可读性和用户体验 一、css样式书写顺序和规范 CSS样式的书写顺序和规范是为了让代码更易读、易维护和易扩展。下面是一些常见的规…

【空间-光谱联合注意网络:多时相遥感图像】

A Spatial–Spectral Joint Attention Network for Change Detection in Multispectral Imagery &#xff08;一种用于多光谱图像变化检测的空间-光谱联合注意网络&#xff09; 变化检测是通过比较双时相图像来确定和评估变化&#xff0c;这是遥感领域的一项具有挑战性的任务…

Java基础——运算符表达式

文章目录 算术运算符赋值运算符关系运算符逻辑运算符位运算符三元运算符 算术运算符 运算符说明加-减*乘/除%取模&#xff08;取余&#xff09;自增- -自减 参考代码&#xff1a; //加法运算 int add1 2 3; System.out.println("加法运算 add1 " add1); Strin…

debian中vim的使用

debian使用vi中经常出现m apt install vim vim不能用鼠标粘贴 vim /etc/vim/vimrc 在末尾加入以下内容&#xff1a; let skip_defaults_vim 1 if has(mouse)set mouse-a endif保存文件即可

Git 精简快速使用

安装 Git 忽略&#xff0c;自行搜索 新建项目&#xff0c;或者在仓库拉取项目&#xff0c;进入到项目目录 Github 给出的引导&#xff0c;新项目和旧项目 echo "# testgit" >> README.md git init git add README.md git commit -m "first commit"…

.NET Nuget包推荐安装

文章目录 前言通用WPFWebApiBlazor 前言 我这里的包主要是.NET Core的&#xff0c;.NET Framework可能不支持。 通用 Newtonsoft.Json&#xff1a;最常用的C#和Json对象互转的包。支持匿名对象&#xff0c;但是不支持Enum枚举类型&#xff0c;显示的是Enum的数值&#xff0c…

MySQL强制使用索引的两种方式及优化索引,使用MySQL存储过程创建测试数据。

一、MySQL强制使用索引的两种方式 1、使用 FORCE INDEX 语句&#xff1a; explainselect*fromtbl_test force index (index_item_code)where(item_code between 1 and 1000) and (random between 50000 and 1000000)order byrandomlimit 1; 使用 FORCE INDEX&#xff08;索引…

ARM 和 AMD 架构的区别

ARM 架构和 AMD 架构是两种不同的计算机处理器架构&#xff0c;它们有以下几个主要区别&#xff1a; 设计出发点&#xff1a; ARM 架构&#xff1a;ARM 架构最初是为嵌入式系统设计的&#xff0c;旨在提供低功耗和高效能的解决方案。它主要应用于移动设备、嵌入式系统和物联网设…

链表(单链表、双链表)

前言&#xff1a;链表是算法中比较难理解的部分&#xff0c;本博客记录单链表、双链表学习&#xff0c;理解节点和指针的使用&#xff0c;主要内容包括&#xff1a;使用python创建链表、实现链表常见的操作。 目录 单链表 双链表 单链表 引入链表的背景&#xff1a; 先来看…

使用ElementUI结合Vue完善主页的导航菜单和书籍管理以及后台数据分页查询

目录 动态树 数据表 案列 书籍管理 动态树 动态树&#xff08;Dynamic tree&#xff09;是一种数据结构&#xff0c;它可以在树中动态地插入、删除和修改节点。与静态树不同&#xff0c;静态树的节点是固定的&#xff0c;一旦构建完成就无法再进行修改。而动态树可以在运行时…

Java 8中的Stream API

Java 8引入了一种全新的数据处理方式&#xff1a;Stream。Stream API提供了一种功能强大、高效、可复合、并行处理集合数据的方式。使用Stream API&#xff0c;我们可以轻松地对集合进行筛选、排序、过滤、映射等操作。在本教程中&#xff0c;我们将深入介绍Stream API的原理、…

任意文件的上传和下载

1.任意文件下载&#xff08;高危&#xff09; 定义 一些网站由于业务需求&#xff0c;往往需要提供文件查看或文件下载功能&#xff0c;但若对用户查看或下载的文件不做限制&#xff0c;则恶意用户就能够查看或下载任意敏感文件&#xff0c;这就是文件查看与下载漏洞。 可以下载…