JQuery高级

JQuery

动画

一、默认显示和默认隐藏方式

1.show([speed],[easing],[fn])
	参数:
		1.speed:动画的速度。三个预定义的值("slow","normal","fast")或者标识动画时长的毫秒数值(如:1000)
		2.easing:用来指定切换效果,默认是“swing”,可用参数“linear”
			swing:动画执行时效果是先慢,中间快,最后又慢
			linear:动画执行时速度是匀速的
		3.fn:在动画完成时执行的函数,每个元素执行一次
2.hide([speed],[easing],[fn])
3.toggle([speed],[easing],[fn])
<script>
        function hideFn() {
            $("#showDiv").hide("slow","swing",function () {
                alert("隐藏了..")
            });
        }
        function showFn() {
            $("#showDiv").show("slow","swing",function () {
                alert("显示了..")
            });
        }
        function toggleFn() {
            $("#showDiv").toggle("slow","swing");
        }
    </script>
    <input type="button" value="点击按钮隐藏div" onclick="hideFn()">
    <input type="button" value="点击按钮显示div" onclick="showFn()">
    <input type="button" value="点击按钮切换div显示和隐藏" onclick="toggleFn()">

    <div id="showDiv" style="...">
        div显示和隐藏
    </div>

二、滑动显示和隐藏方式

1.slideDown([speed],[easing],[fn])
2.slideUp([speed],[easing],[fn])
3.slideToggle([speed],[easing],[fn])
    <script>
        function hideFn() {
            $("#showDiv").slideUp("slow","swing");
        }
        function showFn() {
            $("#showDiv").slideDown("slow","swing");
        }
        function toggleFn() {
            $("#showDiv").slideToggle("slow","swing");
        }
    </script>
    <input type="button" value="点击按钮隐藏div" onclick="hideFn()">
    <input type="button" value="点击按钮显示div" onclick="showFn()">
    <input type="button" value="点击按钮切换div显示和隐藏" onclick="toggleFn()">

    <div id="showDiv" style="...">
        div显示和隐藏
    </div>

三、淡入淡出显示和隐藏方式

1.fadeIn([speed],[easing],[fn])
2.fadeOut([speed],[easing],[fn])
3.fadeToggle([speed],[easing],[fn])
    <script>
        function hideFn() {
            $("#showDiv").fadeOut("slow","swing");
        }
        function showFn() {
            $("#showDiv").fadeIn("slow","swing");
        }
        function toggleFn() {
            $("#showDiv").fadeToggle("slow","swing");
        }
    </script>
    <input type="button" value="点击按钮隐藏div" onclick="hideFn()">
    <input type="button" value="点击按钮显示div" onclick="showFn()">
    <input type="button" value="点击按钮切换div显示和隐藏" onclick="toggleFn()">

    <div id="showDiv" style="...">
        div显示和隐藏
    </div>
遍历

一、js的遍历方式

for(初始化值;循环结束条件;步长)

二、jq的遍历方式

1.	jq对象.each(callback)
2.	$.each(object,[callback])
3.	for...of:jq3.0版本之后提供的方式
    <script>
        $(function () {

            //1.获取所有的ul下的li
            var citys=$("#city li");
            //一、JS方式遍历
            //2.遍历li
            for (var i = 0; i < citys.length; i++) {
                if("上海"==citys[i].innerHTML){
                    //break;//结束循环
                    //continue;//结束本次循环,继续下次循环
                }
                //获取内容
                alert(i+":"+citys[i].innerHTML);
            }

            //二、jq对象.each(callback)
            citys.each(function (index,element) {
                //3.1获取li对象 第一种方式 this
                alert(this.innerHTML);

                //3.2获取li对象 第二种方式 在回调函数中定义参数 index(索引) element(元素对象)
                //alert(index+":"+element.innerHTML);
                //alert(index+":"+$(element).html());

                //判断,如果是上海则结束循环
                if("上海"==$(element).html()){
                    //如果当前回调函数返回为false,则结束循环(break)。
                    // 如果返回true,则结束本次循环继续下次循环(continue)
                    return false;
                }
                alert(index+":"+$(element).html());

            })

            //三、$.each(object,[callback])
            $.each(citys,function () {
                alert($(this).html());
            });

            //四、	for...of:jq3.0版本之后提供的方式
            for(li of citys){
                alert($(li).html());
            }


        });
    </script>

    <ul id="city">
        <li>北京</li>
        <li>上海</li>
        <li>天津</li>
        <li>重庆</li>
    </ul>
事件绑定

一、jq标准事件绑定方式

jq对象.事件方法(回调函数);
<script>
        $(function () {
            //获取name对象,绑定click事件
            $("#name").click(function () {
                alert("我被点击了");
            });

            //给name绑定鼠标移动到元素之上事件。绑定鼠标移出事件
            $("#name").mouseover(function () {
               alert("鼠标来了...");
            });
            $("#name").mouseout(function () {
                alert("鼠标走了...");
            });
            //简化操作,链式编程
            $("#name").mouseover(function () {
                alert("鼠标来了...");
            }).mouseout(function () {
                alert("鼠标走了...");
            });

            $("#name").focus();//不传递回调函数,那么触发浏览器默认行为,让文本输入框获得焦点
        });
    </script>

    <input id="name" type="text" value="绑定点击事件">

二、on绑定事件/off接触绑定

jq对象.on("事件名称",回调函数);
jq对象.off("事件名称");
<script>
        $(function () {
            // 1.使用on绑定单击事件
            $("#btn").on("click",function () {
                alert("我被点击了")
            });
            //2.使用off解绑单击事件
            $("#btn2").click(function () {
                //接触btn按钮的点击事件
                $("#btn").off("click");
                $("#btn").off();//如果不传递参数,会将组件上的所有事件全部解绑

            });
        });
    </script>

    <input id="btn" type="text" value="使用on绑定单击事件">
    <input id="btn2" type="text" value="使用off解绑单击事件">

三、事件切换:toggle

jq对象.toggle(fn1,fn2);
	当点击jq对象对应的组件后,会执行fn1,第二次点击会执行fn2...
<script type="text/javascript">
        $(function () {
           $("#btn").toggle(function () {
               //改变div背景色为绿色
               $("#myDiv").css("backgroundColor","green");
           },function () {
               //改变div背景色为红色
               $("#myDiv").css("backgroundColor","red");
           });
        });
    </script>

    <input id="btn" type="text" value="事件切换">
    <div id="myDiv" style="width: 300px; height: 300px;background: pink">
        点击按钮变成绿色,再次点击红色
    </div>
广告案例
<script>
        //入口函数
        $(function () {
            //定义定时器,调用adShow方法.3秒后执行
            setTimeout(adShow,3000);
            //定义定时器,调用adHide方法.5秒后执行
            setTimeout(adHide,8000);
        });
        //显示广告
        function adShow() {
            //获取广告div,调用show方法
            $("#ad").show("slow");
        }
        //隐藏广告
        function adHide() {
            //获取广告div,调用隐藏方法
            $("#ad").hide("slow");
        }
    </script>
    <div>
        <!--广告div-->
        <div id="ad" style="display: none;">
            <img src="img/2.png" style="width:100%">
        </div>

        <!--下方正文-->
        <div id="content">
            正文部分
        </div>
    </div>
抽奖案例

在这里插入图片描述

   <script>

        var imgs=["img/1.png","img/2.png","img/3.png","img/body1.png","img/body2.png","img/body6.png"];
        var startId;//开始定时器的id
        var index;
        $(function () {
            //处理按钮是否可以使用的效果
            $("#startID").prop("disabled",false);
            $("#stopID").prop("disabled",true);


           //1.给开始按钮绑定单击事件
            $("#startID").click(function () {
                //1.1定义循环定时器 20毫秒执行一次
                startId=setInterval(function () {
                    $("#startID").prop("disabled",true);
                    $("#stopID").prop("disabled",false);


                    //1.2生成随机角标 0-5
                    index=Math.floor(Math.random()*6)//0.000--0.999-->*6--->0.0--5.999
                    //1.3设置小相框的src属性
                    $("#img1ID").prop("src",imgs[index]);
                },20);
            });

            //2.给结束按钮绑定单击事件
            $("#stopID").click(function () {
                $("#startID").prop("disabled",false);
                $("#stopID").prop("disabled",true);


                //2.1停止定时器
                clearInterval(startId)
                //2.2给大相框设置src属性
                $("#img2ID").prop("src",imgs[index]);

            });
        });
    </script>
   <!--小相框-->
    <div style="border-style: dotted;width: 160px;height: 100px">
        <img id="img1ID" src="img/1.png" style="width: 160px;height: 100px"/>
    </div>

    <!--大相框-->
   <div style="border-style: double;width: 800px;height: 500px;position: absolute;left: 500px;top: 10px">
       <img id="img2ID" src="img/2.png" width="800px" height="500px" />
   </div>

    <!--开始按钮-->
    <input id="startID" type="button" value="点击开始" style="width:150px;height: 150px;font-size: 22px">

    <!--停止按钮-->
   <input id="stopID" type="button" value="点击停止" style="width:150px;height: 150px;font-size: 22px">
插件

增强jq的功能
一、实现方式

1.$.fn.extend(object)
	增强通过jq获取的对象的功能 $("#id")
2.$.extend(object)
	增强jq对象自身的功能 $/JQuery
    <script>
        //使用jq插件 给jq对象添加2个方法 check()选中所有的复选框,uncheck()取消选中所有复选框

        //1.定义就jq的对象插件
        $.fn.extend({
            //定义了一个check方法。所有的jq对象都可以调用该方法
            check:function () {
                //让复选框选中
                //this:调用该方法的jq对象
                this.prop("checked",true);
            },
            uncheck:function () {
                //让复选框不选中
                this.prop("checked",false);
            }
        });


        $(function () {
            //获取按钮
            $("#btn-check").click(function () {
                //获取复选框对象
                $("input[type='checkbox']").check();
            });

            $("#btn-uncheck").click(function () {
                //获取复选框对象
                $("input[type='checkbox']").uncheck();
            });
        });
    </script>



    <input id="btn-check" type="button" value="点击选中复选框" onclick="checkFn()">
    <input id="btn-uncheck" type="button" value="点击取消复选框选中" onclick="uncheckFn()">
    <br>

    <input type="checkbox" value="football">足球
    <input type="checkbox" value="basketball">篮球
    <input type="checkbox" value="volleyball">排球
<script>
        //对全局方法扩展两个方法,扩展min方法:求2个值的最小值;扩展max方法:求2个值最大值

        $.extend({
            max:function (a,b) {
                //返回两数中的较大值
                return a>=b ? a:b;
            },

            min:function (a,b) {
                //返回两数中的较小值
                return a>=b ? b:a;
            }
        });

        //调用全局方法
        var max = $.max(2,3);
        alert(max);
        var min = $.min(4,9);
        alert(min); 

    </script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值