zoukankan      html  css  js  c++  java
  • 关于【jq插件开发】

    很详细,原文链接:https://www.cnblogs.com/Wayou/p/jquery_plugin_tutorial.html#commentform和https://www.cnblogs.com/ghost-xyx/p/5025571.html

    附例子:

    <div class="a_div">
                构造函数内部可以使用this关键字;普通函数内部不建议使用this,因为这时候this指向的是window全局对象,这样无意间就会为window添加了一些全局变量或函数
            </div>
            <a>点击</a>
            <script type="text/javascript">
                             //构造函数内部可以使用this关键字;普通函数内部不建议使用this,
    //因为这时候this指向的是window全局对象,这样无意间就会为window添加了一些全局变量或函数
                //自调用匿名函数里面的代码会在第一时间执行,页面准备好过后,上面的代码就将插件准备好了,
                //以方便在后面的代码中使用插件
                //别人的代码也正常工作,只是最后定义的那个函数没有用分号结尾而以,然后当页面中引入我们的插件时,报错了
                //window等系统变量在插件内部就有了一个局部的引用,可以提高访问速度,会有些许性能的提升
                ;
                (function($, window, document, undefined) {
                    //面向对象
                    //定义对象Beautifier 的构造函数
                    var Carousel = function() {};
                    Carousel.prototype = {
                        //容器选择器
                        container: "",
                        //图片地址数组
                        datas: null,
                        autoplaySpeed: null,
                        autoplay: false,
                        // 初始化
                        init: function(options) {
                            this.container = options.container;
                            this.datas = options.datas;
                            this.autoplaySpeed = options.autoplaySpeed;
                            this.autoplay = options.autoplay;
                            $(this.container).html("");
                            this.createCarousel(options);
                            this.arrowHover();
                            this.tabImg();
                            this.setZindex();
                            //判断是否需要自动播放
                            if(options.autoplay || this.autoplay == true) {
                                this.autoPlay(this.autoplaySpeed);
                            } else {
                                console.log(0);
                                return;
                            }
                        },
                        createCarousel: function(options) {
                            this.createDOM(this.container, options);
                        },
                        // 生成DOM
                        createDOM: function(container, options) {
                            console.log(options);
                            var html = "";
                            html = "<div class='carousel-box clearfix'>" +
                                "<div class='transverse-box pull-left'>" +
                                "</div>" +
                                "<div class='vertical-box pull-right'>" +
                                "<ul>" +
                                "</ul>" +
                                "</div>" +
                                "<span class='left-arrow'>‹</span>" +
                                "<span class='right-arrow'>›</span>" +
                                "</div>";
                            $(container).html(html);
                            var imgLength = options.datas.length;
                            for(var i = 0; i < imgLength; i++) {
                                $(".transverse-box").append("<div class='img-item'><img src='" + options.datas[i] + "'></div>");
                            };
                            $(".vertical-box ul").append("<li><img src='" + options.datas[1] + "'></li>");
                            $(".vertical-box ul").append("<li><img src='" + options.datas[2] + "'></li>");
    
                        },
                        arrowHover: function() {
                            $(".carousel-box").hover(function() {
                                $(".left-arrow,.right-arrow").css("display", "flex");
                            }, function() {
                                $(".left-arrow,.right-arrow").css("display", "none");
                            })
                        },
                        // 点击左右箭头触发翻页
                        tabImg: function() {
                            var obj = this;
                            $(".left-arrow").on("click", function() {
                                obj.changeZindex_add();
                            })
                            $(".right-arrow").on("click", function() {
                                obj.changeZindex_sub();
                            })
                        },
                        // 设置初始zindex
                        setZindex: function() {
                            //左侧横向TAB
                            var imgNum = $(".transverse-box").find(".img-item").length;
    
                            for(var i = 0; i < imgNum; i++) {
                                $(".img-item").eq(i).css({
                                    "zIndex": i
                                });
                                $(".img-item").eq(i).attr("Zindex", i);
                            }
                        },
                        //前翻
                        changeZindex_add: function() {
                            var imgNum = $(".transverse-box").find(".img-item").length;
                            var lastZindex = $(".transverse-box").find(".img-item").eq(length - 1).attr("zindex");
                            var firstImgSrc = $(".transverse-box").find(".img-item").eq(0).find("img").attr("src");
                            var lastImgSrc = $(".transverse-box").find(".img-item").eq(length - 1).find("img").attr("src");
                            var last2ImgSrc = $(".transverse-box").find(".img-item").eq(length - 2).find("img").attr("src");
                            $(".transverse-box").find(".img-item").eq(0).remove();
                            $(".transverse-box").append("<div class='img-item' zindex='" + (parseInt(lastZindex) + 1) + "'><img src='" + firstImgSrc + "'><div>");
                            $(".vertical-box ul").find("li").eq(0).find("img").attr("src", lastImgSrc);
                            $(".vertical-box ul").find("li").eq(1).find("img").attr("src", last2ImgSrc);
                            $(".transverse-box").find(".img-item").eq(length - 1).css({
                                "zIndex": parseInt(lastZindex) + 1,
                                "opacity": 0
                            }, 500);
                            $(".transverse-box").find(".img-item").eq(length - 1).animate({
                                "opacity": 1
                            }, 500);
    
                        },
                        // 后翻
                        changeZindex_sub: function() {
                            var imgNum = $(".transverse-box").find(".img-item").length;
                            var lastZindex = $(".transverse-box").find(".img-item").eq(length - 1).attr("zindex");
                            var firstZindex = $(".transverse-box").find(".img-item").eq(0).attr("zindex");
                            var lastImgSrc = $(".transverse-box").find(".img-item").eq(length - 1).find("img").attr("src");
                            var firstImgSrc = $(".transverse-box").find(".img-item").eq(0).find("img").attr("src");
                            var first2ImgSrc = $(".transverse-box").find(".img-item").eq(1).find("img").attr("src");
                            $(".transverse-box").find(".img-item").eq(length - 1).remove();
                            $(".transverse-box").prepend("<div class='img-item' zindex='" + (parseInt(firstZindex) - 1) + "'><img src='" + lastImgSrc + "'><div>");
                            $(".vertical-box ul").find("li").eq(0).find("img").attr("src", firstImgSrc);
                            $(".vertical-box ul").find("li").eq(1).find("img").attr("src", first2ImgSrc);
                            $(".transverse-box").find(".img-item").eq(0).css({
                                "zIndex": parseInt(firstZindex) - 1
                            }).siblings().css("opacity", "0");
                            $(".transverse-box").find(".img-item").eq(length - 1).animate({
                                "opacity": 1
                            });
    
                        },
                        // 自动播放
                        autoPlay: function(x) {
                            var obj = this;
                            this.changeZindex_add();
                            setTimeout(function() {
                                obj.autoPlay(x)
                            }, x);
                        }
    
                    }
                })(jQuery, window, document);
                //至于这个undefined,稍微有意思一点,
                //为了得到没有被修改的undefined,我们并没有传递这个参数,但却在接收时接收了它,因为实际并没有传,所以‘undefined’那个位置接收到的就是真实的'undefined'了
            </script>
            <script type="text/javascript">
                $(function() { //在dom文档载入完成后执行的函数
                    var banner = new Carousel();
                    //图片地址数组。不要少于三张
                    var imgSrcDate = ["./public/img/a1.png", "./public/img/a2.png", "./public/img/a3.png", "./public/img/a4.png", "./public/img/a5.png", "./public/img/a6.png"];
                    banner.init({
                        container: "#banner",
                        datas: imgSrcDate,
                        autoplaySpeed: 5000,
                        autoplay: false
                    });
                });
            </script>        
  • 相关阅读:
    VS2013 调试窗口一闪而过的解决方法
    什么是文件?
    局部变量和全局变量的区别
    一个简单java程序的要素
    运行一个简单的Java程序
    Javascript 构造函数原型继承机制
    函数式编程之一等公民的函数
    弹性布局flex-兼容问题
    TypeScript中的枚举类型
    依赖注入
  • 原文地址:https://www.cnblogs.com/su20110702048/p/7851583.html
Copyright © 2011-2022 走看看