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>

  

  

 

  

原文地址:https://www.cnblogs.com/xiao-apple36/p/10116906.html