• jquery基础


    jQuery的介绍

    jQuery是一个快速,小巧,功能丰富的JavaScript库。它通过易于使用的API在大量浏览器中运行,使得HTML文档遍历和操作,事件处理,动画和Ajax更加简单。

    通过多功能性和可扩展性的结合,jQuery改变了数百万人编写JavaScript的方式。另外它只是封装了js的dom的操作和ajax,其它的未封装。所以js是包含jquery的。

    由此可见,jquery的出现,使我们更加容易操作DOM。

    关于jQuery的相关资料:

    为什么要使用jQuery

    在用js写代码时,会遇到一些问题:

    • window.onload 事件有事件覆盖的问题,因此只能写一个事件。

    • 代码容错性差。

    • 浏览器兼容性问题。

    • 书写很繁琐,代码量多。

    • 代码很乱,各个页面到处都是。

    • 动画效果很难实现。

    jQuery的出现,可以解决以上问题。

    学习jQuery,主要学什么

    初期,主要学习如何使用jQuery操作DOM,其实就是学习jQuery封装好的那些功API。

    这些API的共同特点是:几乎全都是方法。所以,在使用jQuery的API时,都是方法调用,也就是说要加小括号(),小括号里面是相应的参数,参数不同,功能不同。

    jQuery的第一个demo

    先让大家感受一下jquery的强大,为什么是write less ,do more?

    <!DOCTYPE html>
    <html lang="en">
    <head>
    	<meta charset="UTF-8">
    	<title></title>
    	<style type="text/css">
    		*{
    			padding: 0;
    			margin: 0;
    		}
    		ul{
    			 400px;
    			height: 100px;
    			overflow: hidden;
    		}
    		ul li{
    			list-style: none;
    			float: left;
    			 80px;
    			height: 100px;
    			line-height: 100px;
    			text-align: center;
    			background-color: red;
    			margin-right: 10px;
    
    		}
    		ul li a{
    			padding: 20px;
    			/*background-color: green;*/
    			color:#fff;
    		}
    		p{
    			display: none;
    		}
    		p.active{
    			display: block;
    		}
    	</style>
    <body>
    	<ul>
    	    <li>
    	    	<a href="javascript:void(0)">
    	    		alex1
    	    	</a>
    	    </li>
    	    <li>
    	    	<a href="javascript:void(0)">
    	    		alex2
    	    	</a>
    	    </li>
    	    <li>
    	    	<a href="javascript:void(0)">
    	    		alex3
    	    	</a>
    	    </li>
    	    <li>
    	    	<a href="javascript:void(0)">
    	    		alex4
    	    	</a>
    	    </li>
    	</ul>
    	<p>alex1</p>
    	<p>alex2</p>
    	<p>alex3</p>
    	<p>alex4</p>
          
          <!--    	
          	描述:引入jQuery包
          -->
    	<script type="text/javascript" src="js/jquery-3.2.1.js"></script>
    	<script type="text/javascript">
    		$(function(){//入口函数
    			$('ul li a').click(function() {
    				// 选项卡的完整版
    				$(this).css('background','green').parent('li').siblings('li').find('a').css('background','transparent');//链式编程
    
    				// 得获取到点击的 dom的索引 通过 index()方法获取  注意 这个要找的是有兄弟元素的索引
    				var i = $(this).parent('li').index();
    				// addClass()  removeClass()
    				$('p').eq(i).addClass('active').siblings('p').removeClass('active');
    			});
    		})
    	</script>
    	
    	
    </body>
    </html>
    

      

    jQuery的两大特点

    • 链式编程:比如.show().html()可以连写成.show().html()

    • 隐式迭代:隐式 对应的是 显式。隐式迭代的意思是:在方法的内部进行循环遍历,而不用我们自己再进行循环,简化我们的操作,方便我们调用。

    入口函数和window.onload()对比

    原生 js 的入口函数指的是:window.onload = function() {}; 如下:

      //原生 js 的入口函数。页面上所有内容加载完毕,才执行。
            //不仅要等文本加载完毕,而且要等图片也要加载完毕,才执行函数。
           window.onload = function () {
               alert(1);
           }
    

      而 jQuery的入口函数,有以下几种写法:

    写法一:
     //1.文档加载完毕,图片不加载的时候,就可以执行这个函数。
           $(document).ready(function () {
               alert(1);
           })
    写法二:(写法一的简洁版)
    
     //2.文档加载完毕,图片不加载的时候,就可以执行这个函数。
           $(function () {
               alert(1);
           });
    写法三:
    
      //3.文档加载完毕,图片也加载完毕的时候,在执行这个函数。
           $(window).ready(function () {
               alert(1);
           })
    

      

    jQuery入口函数与js入口函数的区别

    区别一:书写个数不同:

    • Js 的入口函数只能出现一次,出现多次会存在事件覆盖的问题。

    • jQuery 的入口函数,可以出现任意多次,并不存在事件覆盖问题。

    区别二:执行时机不同:

    • Js的入口函数是在所有的文件资源加载完成后,才执行。这些文件资源包括:页面文档、外部的js文件、外部的css文件、图片等。

    • jQuery的入口函数,是在文档加载完成后,就执行。文档加载完成指的是:DOM树加载完成后,就可以操作DOM了,不用等到所有的外部资源都加载完成。

    文档加载的顺序:从上往下,边解析边执行。

    jQuery的$符号

    jQuery 使用 $ 符号原因:书写简洁、相对于其他字符与众不同、容易被记住。

    jQuery占用了我们两个变量:$ 和 jQuery。当我们在代码中打印它们俩的时候:

      <script src="jquery-3.3.1.js"></script>
        <script>
    
            console.log($);
            console.log(jQuery);
            console.log($===jQuery);
    
    
        </script>
    

      

    从打印结果可以看出,$ 代表的就是 jQuery。

    那怎么理解jQuery里面的 $ 符号呢?

    $ 实际上表示的是一个函数名 如下:

        $(); // 调用上面我们自定义的函数$
    
        $(document).ready(function(){}); // 调用入口函数
    
        $(function(){}); // 调用入口函数
    
        $("#btnShow") // 获取id属性为btnShow的元素
    
        $("div") // 获取所有的div标签元素
    

      

    js中的DOM对象 和 jQuery对象比较

    二者的区别

    通过 jQuery 获取的元素是一个伪数组,数组中包含着原生JS中的DOM对象。举例:

    针对下面这样一个div结构:

    通过原生 js 获取这些元素节点的方式是:

     var myBox = document.getElementById("app");           //通过 id 获取单个元素
        var boxArr = document.getElementsByClassName("box");  //通过 class 获取的是伪数组
        var divArr = document.getElementsByTagName("div");    //通过标签获取的是伪数组
    

      //获取的是伪数组,里面包含着原生 JS 中的DOM对象。

    console.log($('#app'));
    
    console.log($('.box'));
    
    console.log($('div'));
    

     

    二者的相互准换

    1、 DOM 对象 转为 jQuery对象

      
    $(js对象);

    2、jQuery对象 转为 DOM 对象

      
    jquery对象[index];     //方式1(推荐)

    jquery对象.get(index); //方式2

    jQuery对象转换成了 DOM 对象之后,可以直接调用 DOM 提供的一些功能。如:

      
    $('div')[1].style.backgroundColor = 'yellow';
    $('div')[3].style.backgroundColor = 'green';

    总结:如果想要用哪种方式设置属性或方法,必须转换成该类型。

    举例:

    隔行换色

    <html>
    <head lang="en">
        <meta charset="UTF-8">
        <title></title>
        <style>
        	li{
        		list-style: none;
        	}
        </style>
        <script src="js/jquery-3.2.1.js"></script>
        <script>
            //入口函数
            jQuery(function () {
                var jqLi = $("li");
                for (var i = 0; i < jqLi.length; i++) {
                    if (i % 2 === 0) {
                        //jquery对象,转换成了js对象
                        jqLi[i].style.backgroundColor = "pink";
                    } else {
                        jqLi[i].style.backgroundColor = "yellow";
                    }
                }
            });
        </script>
    </head>
    <body>
    <ul>
        <li>小马哥</li>
        <li>小马哥</li>
        <li>小马哥</li>
        <li>小马哥</li>
        <li>小马哥</li>
        <li>小马哥</li>
    </ul>
    </body>
    </html>
    

      

      

     

      

  • 相关阅读:
    关于session的记录
    关于<input type="hidden"/>标签的记录
    H3C S5120V2-SI 交换机配置
    Windows 系列GVLK密钥
    给因特尔S2600CO服务器主板安装【SAS控制器】驱动
    EMQ消息队列初体验
    泰国佛历的换算问题
    linux下批量查找UTF-8的BOM文件,并去除BOM
    菲律宾Globe/TM卡最省钱的上网方案
    Windows计划任务实现MYSQL冷备份
  • 原文地址:https://www.cnblogs.com/xiao-apple36/p/10116906.html
Copyright © 2020-2023  润新知