zoukankan      html  css  js  c++  java
  • jQuery

    一、jQuery

    1、定义

    • jQuery 是JS的类库
    • jQuery是为了让JS的开发更简单
    • jQuery的目的: 写得少,干得多

    2、jQuery优势

    • 兼容性问题 (jquery2.以上的不兼容IE8、 兼容IE8以及以下,jquery1-.
    • 便捷的选择器
    • 方便的事件体系
    • 方便的dom元素
    • 方便的动画体系
    • 易用的ajax
    • 开源、免费

    二、jQuery 基础

    1、ready 事件

    • 用法

        $(document).ready(function(){
        })
        //简写
        $(function(){
        })
      
    • 与onload的区别

      • onload 事件 等到页面的一切加载完毕,才能触发
      • ready事件等页面中所有的dom加载完毕,就能触发

    2、jquery dom 和 原生 dom

    • 通过$() 获取的对象,是jquery dom

    • jquery dom 本质上是由 原生dom 组成的集合,通过取下标就可以获取原生dom

    • $()方法可以把 原生dom 变为 jquery dom $(document)

        //把jquery dom 变成原生dom
        $dom[0].style.border="2px solid orange";
      
        //原生dom转换为jquery dom
        
        $(dom).css("background-color","yellow");
      

    3、jquery 中绑定事件

    	//jquery给一组元素绑定事件不需要遍历
    	$("ul li").click(function(){
    		$(this).css("background-color","yellow");
    	})
    

    三、jquery 选择器

    1、基本选择器

        <h1>选择器</h1>
        <h4>过滤选择器</h4>
        <ul id="firstList">
    	    <li>小丽丽</li>
    	    <li lang="zh">小丽丽</li>
    	    <li>小丽丽
    		    <ul>
    			    <li>小翠翠</li>
    			    <li>小翠翠</li>
    			    <li class="item">小翠翠</li>
    			    <li>小翠翠</li>
    			    <li>小翠翠</li>
    		    </ul>
    	    </li>
    	    <li>小丽丽</li>
    	    <li>小丽丽</li>
    	    <li>小丽丽</li>
        </ul>
    
        <ul id="secondList">
    	    <li>嘿嘿嘿</li>
    	    <li>嘿嘿嘿</li>
    	    <li>嘿嘿嘿</li>
    	    <li>嘿嘿嘿</li>
    	    <li>嘿嘿嘿</li>
        </ul>
    
    • ID

    • .className
    • tagName
    • *
    • selecter,selecter

    2、层级选择器

    • selecter seclter
    • selecter>selecter
    • selecter+selecter
    • selecter~selecter

    3、过滤选择器

    • :first

        $("#firstList li:first").css("border","3px solid red");
      
    • :last

         $("#firstList li:last").css("border","3px solid red");
      
    • :eq(index)等于

        $("#firstList li:eq(3)").css("border","3px solid red")
      
    • :lt(index)小于

        $("#firstList li:lt(5)").css("border","3px solid red");
      
    • :gt(index)大于

    • :odd 奇数

    • :even 偶数

        $("#secondList li:even").css("background-color","orange")
      
    • :not(selecter) 排除(除了它以外的符合范围的)

        $("#firstList li li:not(.item)").css("background-color","#999")
      
    • :lang()

        $("#firstList>li:lang(zh)").css("border","5px solid green");
      
    • :header 所有的标题标签(hn)

        $(":header").css("color","red");
      
    • :root

        $(":root").css("border","1px solid red");
      
    • :focus

        $("input").focus(function(){
        			$("input:focus").css("border","3px solid red");
        		})
      
    • :target
      添加锚点出效果
      $(document).ready(function(){
      $("ul:target").css("border","10px solid green");
      })

    4、内容选择器

        <ul>
    	    <li>丽丽</li>
    	    <li>丽丽</li>
    	    <li>丽丽
    		    <ul>
    			    <li>翠翠</li>
    			    <li>翠翠</li>
    			    <li></li>
    			    <li class="item">翠翠</li>
    			    <li style="visibility:hidden;">翠翠</li>
    			    <li>翠翠</li>
    		    </ul>
    	    </li>
    	    <li>丽丽</li>
    	    <li></li>
    	    <li>丽丽</li>
    </ul>
    
    • :contains(text)

        $("li:contains('翠翠')").css("border","1px solid red");
      
    • empty

    • parent

        $("li:parent").css("border","5px solid red");
      
    • has(selecter)

        $("li:has(.item)").css("border","5px solid red");
      

    5、可见性选择器

    • :hidden

    • :visible

        $("li:visible").css("border","1px solid red");
      

    6、属性选择器

    • [attrName]
    • [attrName=value]
    • [attrName!=value]
    • [attrName^=value]
    • [attrName$=value]
    • [attrName*=value]

    7、子元素选择器

    • :first-child
    • :last-child
    • :nth-child()
    • :nth-last-child()
    • :only-child
    • :first-of-type
    • :last-of-type
    • :nth-of-type()
    • :nth-last-of-type()
    • :only-of-type

    8、表单选择器

    • :input 所有的表单控件(inputselect extarea)

        $(":input").css("border","1px solid red");
      
    • :text

    • :radio

    • :checkbox

    • :password

    • :image

    • :submit

    • :reset

    • :button

    • :file

    9、表单对象选择器

    • :diabled

    • :enable

        $(":enabled").css("border","1px solid red");
      
    • :checked

    • :selected

    四、筛选


    1、过滤

           <ul>
    	    <li>丽丽</li>
    	    <li>丽丽</li>
    	    <li>丽丽
    		    <ul>
    			    <li>霞霞</li>
    			    <li>霞霞</li>
    			    <li></li>
    			    <li class="crrent item">霞霞item</li>
    			    <li style="visibility:hidden;">霞霞</li>
    			    <li>霞霞</li>
    
    		    </ul>
    	    </li>
    	    <li>丽丽</li>
    	    <li>丽丽</li>
    	    <li></li>
    	    <li>丽丽</li>
        </ul>
    
    • .eq(index)

    • .first()

        $("li").first().css("border","5px solid red");
      
    • .last()

    • not(selcter)

    • filter(selecter)
      只是selecter

        $("li").filter(".item").css("border","5px solid red");
      

    • has(selecter)
      selecter的父元素

      $("li").has(".item").css("border","5px solid red");

    • slice(start, end)
      start<=数<end

        $("li").slice(2,6).css("border","5px solid red");
      
    • is(selecter) true/false

    • hasClass(className) /true/false

    • map(fn)
      将一组元素转换成其他数组(不论是否是元素数组)

        var arr=$("li").map(function(index,item){
        	return item.innerHTML;
        })
      

    2、查找

    • find(selcter) 后代元素

        $("#myList").find("li").css("border","1px solid red");
      
    • children(selcter) 子元素

        $("#myList").children("li").css("border","1px solid red");
      
    • parent() 父元素

    • parents(selcter) 所有的祖先元素

    • parentsUntil(selecter) 所有祖先素直到

        $(".item").parentsUntil("html").css("border","5px solid red");
      
    • closest(selecter) 从自身和祖先元素中 找到第一个满足条件

        $(".item").closest("li").css("border","5px solid red");
      
    • next() 下一个

        $(".item").next().css("border","5px solid red");
      
    • nextAll()

    • nextUntil()

    • prev()

    • prevAll()

    • prevUntil()

    • siblings() 所有的兄弟元素

        $(".item").siblings("p").css("border","5px solid red");
      

    3、串联

    • add(selcter) 把选中的元素加入到当前集合

    • addBack() 把最近的堆栈中元素加入当前集合

    • end() 返回最近一次破坏性操作之前的元素

    • contents() 所有子节点的集合(不是jquery dom)

        <script>
        	$(document).ready(function(){
        		//$("li").add("p").css("background-color","orange");
      
        		//$("ul").find("li").addBack().css("border","5px solid red");
      
        		$("ul").find("li").end().css("border","5px solid red");
      
        		console.log($("ul").contents());
        		console.log($("ul").contents()[1]);
        		console.log($("ul").contents()[0]);
        	})
        </script>
      

    五、属性操作

    1、属性操作的方法

    • prop(attr [,val]) 只能操作内置属性

        	//获取某个属性的值
        	console.log($("img").prop('src'));
        	console.log($("img").prop('width'));
      
        	//修改某个的属性的值
        	$("img").prop("title","哈哈哈");
        	$("img").prop("alt","哈哈哈");
      
    • attr(attr [,va]) 操作自定义属性

        	//获取自定义属性的值
        	console.log($("img").attr("loadpic"));
        	console.log($("img").attr("src"));
      
    • remvoeAttr(attr) 移除属性

        $("img").removeAttr("dddd");
      

    2、class操作

    • addClass() 添加一个类

    • removeClass() 移除一个类

    • toggleClass() 切换

    • hasClass() 判断一个类

        	$("img").click(function(){
        		/*if($(this).hasClass("current")){
        			$(this).removeClass("current");
        		}else{
        			$(this).addClass("current");
        		}*/
        		$(this).toggleClass("current");
        	})
      

    3、HTML代码/文本/值

    • html([val])

        	//获取div内的html内容
        	console.log($(".content").html());   
      
    • text([val])

        $(".content").text("<h1>锄禾日当午</h1>");
      
    • val([val])

    六、CSS

    1、css方法

    • css()

        $("#btn").click(function(){
        	//$(".my-list li").css("border","1px solid red").css("padding","20px");
      
        	$(".my-list li").css({"border":"2px solid green","padding":"20px","margin-bottom":"10px"
        })
      

    2、位置

    • offset()

    • postion()

        $("#btn1").click(function(){
        	console.log($(".my-list li").eq(1).offset());
        	console.log($(".my-list li").eq(1).position())
        })
      
    • scrollLeft([val])

        //获取scrollLeft
        $("#btn3").click(function(){
        	console.log($(".box").scrollLeft());
        })
      
        
        //设置scrollLeft
        $("btn4").click(function(){
        	$(".box").scrollLeft($(".box").scrollleft()+100)
        })
      
    • scrollTop([val])

    3、尺寸

    • width() / height()

    • innerWidth() / innerHeight()

    • outerWidth() / outerHeight()

        console.log($(".box").width(),$(".box").height());
        console.log($(".box").innerWidth(),$(".box").innerHeight());
        console.log($(".box").outerWidth(),$(".box").outerHeight());
      
        //设置尺寸
        $("#btn5").click(function(){
        	//$(".box").width(500);
        	$(".box").outerWidth(500);
        })
      

    七、文档处理(添加删除元素)


    1、内部插入

    • append()后插

        $(function(){
        	//添加
        	$("#btn01").click(function(){
        		//创建一个元素
        		/*var newImg=$("<img>").prop("src","../images/002.jpg");
        		$(".box").append(newImg);*/
      
        		$(".box").append("<img src='../images/002.jpg'>");
        	})
        })
      
    • appendTo()

        $("#btn02").click(function(){
        	$("<img src='../images/003.jpg'>").appendTo(".box");
        })
      
    • prepend()前面插

        $("#btn03").click(function(){
        	$(".box").prepend("<img src='../images/002.jpg'>");
        })
      
    • prependTo()

    2、外部插入

    • after() 前插

        //外部插入
        $("#btn04").click(function(){
        	$(".box").after("<img src='../images/002.jpg'>");
        })
      
    • insertAfter()

        $("#btn05").click(function(){
        	$("<img src='../images/002.jpg'>").insertAfter(".box");
        })
      
    • before()后插

    • insertBefore()

    3、包裹

    • wrap()每一个img包裹一个li

        //包裹
        	$("#btn07").click(function(){
        		$(".box img").wrap("<li>");
        })
      
    • wrapAll()给所有的img包裹一个li

    • wrapInner()
      给所有的img包裹一个li

        $("#btn09").click(function(){
        	$(".box").wrapInner("<li>");
        })
      
    • unwrap()往上删除包裹img的标签

        $("#btn10").click(function(){
        	$(".box img").unwrap();
        })
      

    4、替换

    • replaceWith()

    • replaceAll()

    • 效果没有区别只是写法不同而已
      //替换
      $("#btn11").click(function(){
      $(".box img.current").replaceWith("");
      })

       $("#btn12").click(function(){
       	$("<img src='../images/002.jpg'>").replaceAll(".box img.current");
       	
       })
      
       //给每个img绑定事件
       	$(".box img").click(function(){
       		$(this).toggleClass("current");
       	})
      

    5、删除元素

    • empty() 清空全部

    • remove() 删除(自己)

    • detach() 删除

        //删除
         $("#btn13").click(function(){
         	$(".box").empty();
         })
      
         $("#btn14").click(function(){
         	$("img.current").remove();
         })
      

    6、克隆

    • clone()

    八、事件


    1、ready

    2、事件绑定方式

    • 事件(fn)

    • bind("事件", fn) 指定对象 同时绑定多个事件

        $(".box").dblclick(function(){
        	console.log("啊,我被双击了");
        })
      
        //标准绑定方式
        $(".box").bind("click",function(){
        	console.log("啊,我被单击了");
        })
      
    • on("事件", fn)

    • one("事件", fn)只能用一次

        $(".box").on("mouseover",function(){
        	$(this).css("background","red");
        })
      
        $(".box").one("mouseout",function(){
        	$(this).css("background","");
        })
      

    3、事件解除绑定

    • unbind()

    • off()

        $("#btn").click(function(){
        	//$(".box").unbind("click").unbind("mouseout");
        	//$(".box").unbind("click");
        	$(".box").off();
        })
      

    4、事件委派

    • on(事件, 选择器, fn)

        $(function(){
        	$(".my-list").on("mouseover","li",function(){
        			$(this).css("background","orange");
        		}).on("mouseout","li",function(){
        			$(this).css("background","");
        		})
        })
      
    • delegate(选择器, 事件, fn)

        $(".my-list").delegate("li","click",function(){
        		$(this).css("border-color","red");
        })
      
    • undelegate(选择器)

    5、自动触发事件

    • trigger()

    • triggerHandler()

        //$(".my-list li").trigger("mouseover");
        //$(".my-list li").triggerHandler("dblclick");
        $(".my-list li").trigger("dblclick");
      

    6、jQuery 事件

    • hover

    • mouseenter

    • mouseleave

    • focusin

    • focusout

        <script>
        	$(function(){
        		$(".my-list li").hover(function(){
        			$(this).toggleClass("current");
        		})
        	})
        </script>
      

    九、效果

    1、基本 (width/height/opacity)

    • show()

    • hide()

    • toggle()

        $(document).ready(function(){
        	$("#btn1").click(function(){
        		//$("#box").hide();
        		//$("#box").hide("fast");
        		//$("#box").hide("normal");
        		//$("#box").hide("slow");
        	//	$("#box").hide(3000);
        		//$("#box").hide(3000,"linear");
        		//$("#box").hide(3000,"linear",function(){});
        		$("#box").hide(3000,function(){
        			alert("啊,我隐藏了")
        		})
        	})
        })
      

    2、滑动滑出 (height)

    • slideUp() 隐藏
    • slideDown() 显示
    • slideToggle()

    3、淡入淡出

    • fadeOut() 隐藏

    • fadeIn() 显示

    • fadeToggle()

    • fadeTo()

        $("#btn10").click(function(){
        	$("#box").fadeTo(3000,0.5);
        })
      

    4、自定义动画

    • animate(params, speed, easing, fn)

        $("#btn03").click(function(){
        	$(".box").animate({
        		"width":"toggle","font-size":"toggle"
        	},3000)
        })
      

    5、动画操作

    • stop()

    • finish()

    • delay() 延迟

        	$("#btn1").click(function(){
        		$("#box").slideUp(3000).delay(3000).show(3000);
        	})
      
        	$("#btn2").click(function(){
        		$("#box").stop();
        	})
      
        	$("#btn3").click(function(){
        		$("#box").finish();
        	})
      

    十、工具

    1、浏览器

    • $.support

    2、对象和属性操作

    • $.each()

        	$.each(list,function(index,item){
        	console.log(index+":"+item);
      
    • $.extend()

    十一、核心

    1、jQueryDOM 方法

    • each()
    • size()
    • length

    区别

    • empty()
    • 该方法不仅删除它的子节点,同时也删除该节点的文本域(根据DOM规范,节点的文本域也被认为是子节点)。
    • remove( [selector] )
    • 和empty方法类似,remove方法也是从DOM里删除元素。当你想要删除节点本身和节点里的所有东西的时候,可以使用remove方法。除了节点本身以外,节点绑定的事件 和该节点相关的JQuery数据,也会被同时清除。当需要清除节点本身,但是不需要清除绑定的事件和数据的时候,可以使用detach方法。
    • detach( [selector] )
    • detach方法和remove方法很相似,但是它会保留所有JQuery相关的数据和绑定的事件。当你删除之后,想要在后来的某个时候重新加入时,这个方法将会很有用。
  • 相关阅读:
    I Hate It
    hdu 2112 HDU Today ( Dijkstra )
    hdu 1280 前m大的数
    hdu 4252 A Famous City
    hdu 2647 Reward
    hdu 2845 Beans
    hdu 3548 Enumerate the Triangles ( 优 化 )
    hdu 3552 I can do it! (贪心)
    HDU 3033 I love sneakers!(分组背包变形)
    hdu 1712 ACboy needs your help 分组背包
  • 原文地址:https://www.cnblogs.com/DCL1314/p/7491127.html
Copyright © 2011-2022 走看看