2017年06月07号 晴 空气质量:中度污染—>良
内容:jQuery第二节:基本选择器,层次选择器,属性选择器,
基本过滤选择器,可见性过滤选择器
备注:代课老师:李老师
一、基本选择器
1)老师代码:
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>My JSP 'index.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <script type="text/javascript" src="js/jquery-1.10.2.min.js"></script> <style type="text/css"> #box { background-color: #FFF; border: 2px solid #000; padding: 5px; } </style> <script type="text/javascript"> $(document).ready(function() { $("#btn1").click(function() {//触发不同的效果按钮点击事件 //标签选择器,获取<h3>元素并为其添加背景颜色 //$("h3").css("background","red"); //类选择器,获取并设置所有class为title的元素的背景颜色 //$(".title").css("background","red"); //ID选择器,获取并设置id为box的元素的背景颜色 //$("#box").css("background","red"); //并集选择器,获取并设置所有<h2>、<dt>、class为title的元素的背景颜色 //$("h2,dt,.title").css("background","red"); //交集选择器,获取并设置所有class为title的<h2>元素的背景颜色 //$("h2.title").css("background","red"); //全局选择器,改变所有元素的字体颜色 $("*").css("color", "red"); }) }); </script> </head> <body> <input type="button" id="btn1" value="显示效果" /> <div id="box"> id为box的div <h2 class="title">class为title的h2</h2> <h3 class="title">class为title的h3</h3> <h3>热门排行</h3> <dl> <dt> <img src="images/case_1.gif" width="93" height="99" alt="斗地主" /> </dt> <dd class="title">斗地主</dd> <dd>休闲游戏</dd> <dd>QQ斗地主是国内同时在线人数最多的棋牌游戏......</dd> </dl> </div> </body> </html>
2)自己代码:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<script src="js/jquery-1.8.3.js"></script>
<script type="text/javascript">
$(function(){
$("h2").click(function(){
/* $("ul li").css("font-size","50px");//标签 空格后是后代
$("#c").css("background","blue");class
$(".Chinese").css("background","red");*///id
/*$("h2,div").css("background","yellow");*/ //并集
$("div.Chinese").css("background","orange");//交集
$("*").css("color","blue");
})
})
</script>
</head>
<body>
<h2>数字</h2>
<ul>
<li class="Chinese">考生加油</li>
<li>two</li>
<li id="c">three</li>
<li>four</li>
</ul>
<h2>打招呼</h2>
<ol>
<li>hello</li>
<li>hi</li>
<li >ola</li>
<li class="Chinese">你好</li>
</ol>
<h2>哪个好看</h2>
<div class="Chinese">海贼王和火影哪个好看?众说纷纭~</div>
<div class="Chinese">科幻和玄幻哪个好看?众说纷纭~</div>
</body>
</html>
二、层次选择器
1)老师代码:
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>My JSP 'index.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <style type="text/css"> * { margin: 0; padding: 0; line-height: 30px; } body { margin: 10px; } #menu { border: 2px solid #03C; padding: 10px; } a { text-decoration: none; margin-right: 5px; } span { font-weight: bold; padding: 3px; } h2 { margin: 10px 0; cursor: pointer; } </style> <script type="text/javascript" src="js/jquery-1.10.2.min.js"></script> <script type="text/javascript"> $(document).ready(function() { $("h2").click(function() { //后代选择器,获取并设置#menu下的<span>元素的背景颜色 //$("#menu span").css("background","red"); //子选择器,获取并设置#menu下的子元素<span>的背景颜色 //$("#menu>span").css("background","red"); //相邻选择器,获取并设置紧接在<h2>元素后的<dl>元素的背景颜色 //$("h2+dl").css("background","red"); //同辈选择器,获取并设置<h2>元素之后的所有同辈元素<dl>的背景颜色 $("h2~dl").css("background","red"); }); }); </script> </head> <body> <div id="menu"> <h2 title="点击看效果">全部旅游产品分类</h2> <dl> <dt> 北京周边旅游<span>特价</span> </dt> <dd> <a href="#">按天数</a> <a href="#">海边旅游</a> <a href="#">草原</a> </dd> </dl> <dl> <dt>景点门票</dt> <dd> <a href="#">名胜</a> <a href="#">暑期</a> <a href="#">乐园</a> </dd> <dd> <a href="#">山水</a> <a href="#">双休</a> </dd> </dl> <span>更多分类</span> </div> </body> </html>
2)自己代码:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<script src="js/jquery-1.8.3.js"></script>
<script type="text/javascript">
$(function(){
$("h2").click(function(){
/*
$("ul>li").css("background","yellow");//子代
*/
// $("h2+div").css("color","blue");//之后紧邻的同辈元素
/* $("h2~div").css("color","orange");//之后所有同辈元素*/
// $(".Chinese span").css("color","orange");//所有span后代
$(".Chinese>span").css("color","orange");//span子代
})
})
</script>
</head>
<body>
<h2>数字</h2>
<ul>
<li class="Chinese">考生加油</li>
<li>two</li>
<li id="c">three</li>
<li>four</li>
</ul>
<h2>打招呼</h2>
<ol>
<li>hello</li>
<li>hi</li>
<li >ola</li>
<li class="Chinese">你好</li>
</ol>
<h2>哪个好看</h2>
<div class="Chinese">
<div><span>孙子</span></div>海贼王和火影哪个好看?</div>
<div class="Chinese"><span>儿子</span>科幻和玄幻哪个好看?</div>
<div class="Chinese">商业片和文艺片哪个好看?</div>
<div>众说纷纭~</div>
</body>
</html>
三、属性选择器
1)老师代码:
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/"; %> <!DOCTYPE HTML> <html> <head> <base href="<%=basePath%>"> <title>My JSP 'index.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <style type="text/css"> #box { background-color: #FFF; border: 2px solid #000; padding: 5px; } h2 { cursor: pointer; } </style> <script type="text/javascript" src="js/jquery-1.10.2.min.js"></script> <script type="text/javascript"> $(document).ready(function() { $("h2").click(function() { //改变含有title属性的<h2>元素的背景颜色 //$("h2[title]").css("background","red"); //改变class属性的值为odds的元素的背景颜色 //$("[class='odds']").css("background","red"); //改变id属性的值不为box的元素的背景颜色 //$("[id!='box']").css("background","red"); //改变title属性的值中以h开头的元素的背景颜色 //$("[title^='h']").css("background","red"); //改变title属性的值中以jp结尾的元素的背景颜色 //$("[title$='jp']").css("background","red"); //改变title属性的值中含有s的元素的背景颜色 //$("[title*='s']").css("background","red"); //改变包含class属性,且title属性的值中含有y的<li>元素的背景颜色 $("li[class][title*='y']").css("background","red"); }); }); </script> </head> <body> <div id="box"> <h2 class="odds" title="cartoonlist">动画列表</h2> <ul> <li class="odds" title="kn_jp">名侦探柯南</li> <li class="evens" title="hy_jp">火影忍者</li> <li class="odds" title="ss_jp">死神</li> <li class="evens" title="yj_jp">妖精的尾巴</li> <li class="odds" title="yh_jp">银魂</li> <li class="evens" title="hm_da">黑猫警长</li> <li class="odds" title="xl_ds">仙履奇缘</li> </ul> </div> </body> </html>
2)自己代码:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<script src="js/jquery-1.8.3.js"></script>
<script type="text/javascript">
$(function(){
$("h2").click(function(){
//$("[href]").css("color","red");//选取含有href属性的元素
//$("[href='#']").css("color","green");//选取href属性值为“#”的元素
//$("[href!='#']").css("color","yellow");//选取href属性值不为“#”的元素
//$("[href^='en']").css("color","orange");//选取href属性值以en开头的元素
//$("[href$='.jpg']").css("color","pink");//选取href属性值以.jpg结尾的元素
//$("[href*='s']").css("color","purple");//选取href属性值中含有s的元素
//选取含有id属性和title属性为sayhello的<li>元素
$("li[id][title=sayhello]").css("background","yellow");
})
})
</script>
</head>
<body>
<h2>属性选择器怎么玩</h2>
<a href="#">我是#字军</a><br/>
<a href="#">我是#字军</a><br/>
<a href="#">我是#字军</a><br/>
<a href="english">hello</a><br/>
<a href="english">brilliant</a><br/>
<a href="images/all.jpg">onepiece</a><br/>
<a href="images/sanji03.jpeg">sanji</a><br/>
<a href="images/sanji05.jpg">juniorsanji</a><br/>
<a href="files/normalWords.txt">normalwords</a><br/>
<ul>
<li class="Chinese">考生加油</li>
<li id="b" title="number">two</li>
<li id="c" title="number">three</li>
<li id="d" title="number">four</li>
</ul>
<h2>打招呼</h2>
<ol>
<li title="sayhello">hello</li>
<li id="english" title="sayhello">hi</li>
<li id="spanish" title="sayhello">ola</li>
<li class="Chinese">你好</li>
</ol>
</body>
</html>
四、基本过滤选择器
1)老师代码:
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/"; %> <!DOCTYPE HTML> <html> <head> <base href="<%=basePath%>"> <title>My JSP 'index.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <script type="text/javascript" src="js/jquery-1.10.2.min.js"></script> <script type="text/javascript"> $(document).ready(function() { $("h2").click(function(){ //改变第1个<li>元素的背景颜色 // $("li:first").css("background","pink"); //改变最后一个<li>元素的背景颜色 // $("li:last").css("background","pink"); //改变class不为three的<li>元素的背景颜色 //$("li:not(.three)").css("background","pink"); //改变索引值为偶数的<li>元素的背景颜色 // $("li:even").css("background","pink"); //改变索引值为奇数的<li>元素的背景颜色 //$("li:odd").css("background","pink"); //改变索引值等于1的<li>元素的背景颜色 // $("li:eq(1)").css("background","pink"); //改变索引值大于1的<li>元素的背景颜色 //$("li:gt(1)").css("background","pink"); //改变索引值小于1的<li>元素的背景颜色 // $("li:lt(1)").css("background","pink"); //改变所有标题元素,例如<h1>,<h2>,<h3>……这些元素的背景颜色 // $(":header").css("background","pink"); }); /* $("input").click(function(){ alert($(this).is(":focus")); //判断元素是否获取焦点 //改变当前获取焦点的元素的背景颜色 $(":focus").css("background","pink"); }) */ $("input").focus(function(){ $(this).css("background","pink"); }) }); </script> </head> <body> 获取焦点:<input type="text"> <h2>网络小说</h2> <ul> <li>王妃不好当</li> <li>致命交易</li> <li class="three">迦兰寺</li> <li>逆天之宠</li> <li>交错时光的爱恋</li> <li>张震鬼故事</li> <li>第一次亲密接触</li> </ul> </body> </html>
2)自己代码:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<script src="js/jquery-1.8.3.js"></script>
<script type="text/javascript">
$(function(){
$("h2").click(function(){
//$("li:first").css("background","#FFB5C5");//选取所有<li>元素中的第一个<li>元素
//$("li:last").css("background","#CD1076");//选取所有<li>元素中的最后一个<li>元素
//$("li:even").css("background","#FFB5C5");//选取索引是偶数的所有<li>元素
//$("li:odd").css("background","#1874CD");//选取索引是奇数的所有<li>元素
//$("li:eq(2)").css("background","#1874CD");//选取索引等于2的<li>元素
//$("li:gt(2)").css("background","#FF7256");//选取索引大于2的<li>元素(注:大于1,不包括1)
//$("li:lt(2)").css("background","#00FF7F");//选取索引小于2的<li>元素(注:小于1,不包括1)
//$("li:not(.Chinese)").css("background","#DDA0DD");//选取class不是Chinese的元素
$(":header").css("background","#EE1289")//选取网页中所有标题元素
})
})
</script>
</head>
<body>
<h2>数字</h2>
<ul>
<li class="Chinese">考生加油</li>
<li id="b" title="number">two</li>
<li id="c" title="number">three</li>
<li id="d" title="number">four</li>
</ul>
<h2>打招呼</h2>
<ol>
<li title="sayhello">hello</li>
<li id="english" title="sayhello">hi</li>
<li id="spanish" title="sayhello">ola</li>
<li class="Chinese">你好</li>
</ol>
</body>
</html>
五、可见性过滤选择器
1)老师代码:
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + path + "/"; %> <!DOCTYPE HTML> <html> <head> <base href="<%=basePath%>"> <title>My JSP 'index.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="cache-control" content="no-cache"> <meta http-equiv="expires" content="0"> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="This is my page"> <script type="text/javascript" src="js/jquery-1.10.2.min.js"></script> <script type="text/javascript"> $(document).ready(function() { $("#show").click(function(){ $("div:hidden").show(); //让所有隐藏的元素 显示 }); $("#hide").click(function(){ $("div:visible").hide(); //让所有可见的元素 隐藏 }); }); </script> </head> <body> <button id="show">show</button> <button id="hide">hide</button> <div>显示1</div> <div>显示2</div> <div style="display:none">显示3</div> </body> </html>
2)自己代码:
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<style type="text/css">
#txt_show{display: none;color:#0000cc;}
#txt_hide{display: none;color:#ff3300;}
#txt_whatever{display: none;color:yellow;}
</style>
<script src="js/jquery-1.8.3.js"></script>
<script type="text/javascript">
$(function(){
$("[name=show]").click(function(){
$("p:hidden").show();//$(":hidden" ) 选取所有隐藏的元素
})
$("[name=hide]").click(function(){
$("p:visible").hide();//$(":visible" )选取所有可见的元素
})
})
</script>
</head>
<body>
<p id="txt_hide">隐藏?</p>
<p id="txt_show">显示?</p>
<p id="txt_whatever">无所谓?</p>
<input type="button" name="show" value="点击显示文字"/>
<input type="button" name="hide" value="点击隐藏文字"/>
</body>
</html>
六、作业
1、看视频
2、练习代码
七、老师辛苦了!
PS:今天是高考第一天,祝福各位考生放平心态,发挥出自己的水准!加油!