第二十篇 jQuery 初步学习2

来源:互联网 发布:浙江省人口数据 编辑:程序博客网 时间:2024/06/07 01:38

jQuery 初步学习2


前言:
  老师这里啰嗦一下,因为考虑到一些同学,不太了解WEB前端这门语言。老师就简单的说一下,写前端,需要什么:一台笔记本、一个文本编辑器。就没啦!当然,写这门语言,我们要遵守它的规则,文本的后缀得是html,里面的编写格式当然也要遵守它的规则。
  如果有同学没有好的编辑器,写代码很打脑壳,记不住单词等等,老师推荐一个编辑工具:WebStorm 。老师用的就是这个来写的前端,版本用的是8.0.3,还是挺好用的。

上节课我们初步学习了jQuery,那么这节课,我们再深入了解一点。

本节课学习内容:jQuery里的this;jQuery里的css,jQuery的事件(移入移出)。

老规矩,看代码,看注释,再解释:

<!DOCTYPE html><html><head lang="en">    <meta charset="UTF-8">    <title>jQuery 第二阶段,事件和css</title>    <script src="../js/jquery-1.12.2.min.js"></script></head><body><!--a标签里href是url指向,会做跳转,老师这里面给的javascript:;是给了一个JS运行而里面没有给其他的代码,直接跟一个分号结束,所以这个a标签不会做跳转效果--><a href="javascript:;">第一个</a><a href="javascript:;">第二个</a><a href="javascript:;">第三个</a><a href="javascript:;">第四个</a><script>    //鼠标移入事件,找到元素a    $("a").mouseover(function (){        //这里面是,鼠标移入到a元素,就运行        //将a元素的css 背景颜色,改成红色        $("a").css("background-color","red");    });</script></body></html>

以上,这是一个简单的鼠标移入事件,改变a元素的css样式,同学们要注意它的写法。那么这里老师说一下,$("a").css();  里面的属性值,要给引号,否则会出错,但是老师上面这些,它只能完成一个css样式,就是老师写的背景颜色,那么我要改变它的字体大小又怎么写呢?看看代码:

<script>    //鼠标移入事件,找到元素a    $("a").mouseover(function (){        //这里面是,鼠标移入到a元素,就运行        //将a元素的css 背景颜色,改成红色        //$("a").css("background-color","red");        //以下是第二种css样式写法,可写多个css        $("a").css({"background-color":"red","font-size":"21px"});    });</script>

看到区别了吗?原来的是$("a").css(),里面只能写一个属性值改变样式,而现在老师多加了一个花括号:$("a").css({}) ,书写方式是一样的,都要加引号,但是有一点不同,它的属性值配对,是用的冒号,一对属性值用一个逗号区分开,注意老师的写法。

那么,以上,鼠标移入改变a元素的css样式,像以前用js就特别不方便,莫非一个一个的给id?即使使用class也要找到某一个,所以jQuery的强大,这里就会体现出来,this关键字:

<script>    //鼠标移入事件,找到元素a    $("a").mouseover(function (){        //这里面是,鼠标移入到a元素,就运行        //将a元素的css 背景颜色,改成红色        //$("a").css("background-color","red");        //以下是第二种css样式写法,可写多个css//        $("a").css({"background-color":"red","font-size":"21px"});        $(this).css({"background-color":"red","font-size":"21px"});    });</script>

上面这一段代码很简单,就是将$("a")换成了$(this),因为this是一个关键字,不需要加引号的哦。否则就不对了,this是指本身,那么我们再来刷新页面,鼠标移出a元素,则会发现,不会改变所有的a元素,而是只会改变我鼠标移入的当前a元素。
这段代码就非常的简单了吧。网上我们经常看到的一堆一样的元素块,鼠标移入的话,改变样式,移出又改变样式,就是用这种,一行代码就能解决,用纯JS的话,可能for循环是避免不了的,而且还会增加复杂的逻辑和更多的代码。
同学们就看看以下的代码,运行成功之后的效果,然后自己再扩展以下,就OK的了:

<!DOCTYPE html><html><head lang="en">    <meta charset="UTF-8">    <title>jQuery 第二阶段,事件和css</title>    <script src="../js/jquery-1.12.2.min.js"></script></head><body><!--a标签里href是url指向,会做跳转,老师这里面给的javascript:;是给了一个JS运行而里面没有给其他的代码,直接跟一个分号结束,所以这个a标签不会做跳转效果--><a href="javascript:;">第一个</a><a href="javascript:;">第二个</a><a href="javascript:;">第三个</a><a href="javascript:;">第四个</a><script>    //鼠标移入事件,找到元素a    $("a").mouseover(function (){        //这里面是,鼠标移入到a元素,就运行        //将a元素的css 背景颜色,改成红色        //$("a").css("background-color","red");        //以下是第二种css样式写法,可写多个css//        $("a").css({"background-color":"red","font-size":"21px"});        //this指向本身的元素,它的本身则是上面的$("a")元素        $(this).css({"background-color":"red","font-size":"21px"});    });    //鼠标移出事件,    $("a").mouseout(function (){        $(this).css({"background-color":"black","font-size":"21px","color":"#fff"});    });</script></body></html>

这里老师演示的是a元素,this也可以在class里使用,因为页面上id是唯一的,咱先不考虑id,但是元素和class则可能会很多,所以this关键字指向本身,是非常好用的。

附加:用jQuery一定要引用它的脚本,老师开始就忘记引用了,写了半天jQuery没反应,我还以为我写错了,所以同学们一定要注意很多的细节,不然着急,是很难受的


原创粉丝点击