麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

jQuery 動(dòng)態(tài)云標(biāo)簽插件

2019-11-20 13:56:16
字體:
供稿:網(wǎng)友

前言:

  最近對js的插件封裝特別感興趣,無耐就目前的技術(shù)想做到j(luò)s的完全封裝,還是有一定困難,就基于jQuery封裝了一個(gè)小的插件,而且是基于對象級開發(fā)的,不是添加全局方法。高深的語法幾乎沒有,就有一個(gè)return:foreach()方法來返回對象實(shí)例本身,還有一個(gè)extend()函數(shù),用來擴(kuò)展參數(shù)對象的屬性,這也是為了對象在調(diào)完我這個(gè)方法后方便鏈?zhǔn)讲僮鳌?/p>

  插件打包下載地址:點(diǎn)我下載

插件名:動(dòng)態(tài)云標(biāo)簽

插件特點(diǎn):

在指定塊級元素內(nèi)動(dòng)態(tài)生成a標(biāo)簽
a標(biāo)簽的高度、寬度、位置、層數(shù)、背景顏色隨機(jī)可控
a標(biāo)簽漸隱顯示和漸隱消失,可改變初始化的透明度
a標(biāo)簽創(chuàng)建的速度和移動(dòng)速度可控(計(jì)時(shí)器)
a標(biāo)簽移動(dòng)的步長可控制(每次循環(huán)移動(dòng)的距離)
鼠標(biāo)懸浮停止動(dòng)畫且透明度最大,層數(shù)最高,鼠標(biāo)離開,恢復(fù)之前狀態(tài)
遇到問題:

  目前插件是可以正常運(yùn)行,但如果切換瀏覽器標(biāo)簽,不把插件頁顯示,過一會(huì)再切換回來,會(huì)有卡頓的現(xiàn)象,這個(gè)現(xiàn)在還不知道什么情況,請了解的給予指點(diǎn),里面也有很多需要優(yōu)化的地方,有好的點(diǎn)子希望提出來,我好及時(shí)給予更正。

動(dòng)畫效果:

汗:gif圖片可能有點(diǎn)大,稍等會(huì)就動(dòng)了。耐心哦

 

 JS代碼片段:

復(fù)制代碼 代碼如下:

(function($){
    $.fn.activiTag = function(opts) {
        opts = $.extend({
            move_step:2,    // 元素移動(dòng)步長--px
            move_speed:40,    // 元素移動(dòng)速度--ms
            init_speed:1000,// 元素創(chuàng)建速度--ms
            min_opacity:0,    // 元素最低透明度--0-1小數(shù)
            max_grain: 10,    // 最大粒度
            // a標(biāo)簽數(shù)組
            a_List: ["<a href='#'>請?zhí)砑釉嘏?lt;/a>","<a href='#'>Spring Jpa詳解</a>","<a href='#'>javamail郵箱</a>"],    // a標(biāo)簽字符串?dāng)?shù)組
            // 背景顏色數(shù)組
            color_List: ['#CD2626','#8b4513','#696969','#ff8c00','#6495ED']    // 標(biāo)簽顏色數(shù)組
        },opts||{});
       
        var aTag = $(this); // 當(dāng)前容器對象
        var T_width = aTag.width(), T_height = aTag.height(); // 容器高度、寬度
       
        return this.each(function(){
           
            function setATagCss() {    // 設(shè)置容器相應(yīng)css
                aTag.css({position:'relative',overflow:'hidden'});
            }
          
            function getRandomNum(Min, Max){ // 獲取兩個(gè)區(qū)間之內(nèi)隨機(jī)數(shù)
                Min = new Number(Min);Max = new Number(Max);
                var Range = Max - Min + 1;
                var Rand = Math.random();
                return Min + Math.floor(Rand * Range);
            }
           
            function getRandomXY(num) {    // 隨機(jī)返回一個(gè) 正/負(fù)參數(shù)
                num = new Number(num);   
                if(Math.random()<=0.5)
                num = -num;
                return num;
            }
           
            /**
             * 隨機(jī)創(chuàng)建a標(biāo)簽,寬度為容器寬度的三分之一,然后在自身基礎(chǔ)上+-五分之一寬度
             * 高度自身寬度的三分之一,然后+-三分之一
             */
            function createATag() {
                var i = getRandomNum(0,opts.a_List.length-1);
                var a = $(opts.a_List[i]);    // 每個(gè)標(biāo)簽元素
                aTag.append(a);
                return a;
            }
           
            /** 設(shè)置a標(biāo)簽css樣式 **/
            function setCss(a) {
                var w = Math.ceil(T_width/3) + getRandomXY(T_width/60);
                var h = Math.ceil(w/3) + getRandomXY(w/36); // 行高
                var zIndex = Math.ceil(Math.random()*400);    // 層數(shù)
                var rdmOpcy = getRandomNum(new Number(opts.min_opacity),0);
                // 行高、層數(shù)、透明度
                a.css({
                    opacity:rdmOpcy,
                    zIndex: zIndex,
                    lineHeight:h+'px',
                    position: 'absolute',
                    textDecoration:'none',
                    textAlign:'center',
                    borderRadius: '3px',
                    color:'#FFFFFF',
                    whiteSpace: 'nowrap',
                });
                return a;
            }
           
            /** 計(jì)算標(biāo)簽相對于容器的初始化位置(X_Y 坐標(biāo)) **/
            function setXY(a) {
                var x = getRandomNum(0,(T_width-a.width()));
                var y = getRandomNum(0,T_height/10);
                a.css({left:x+'px', bottom:y+'px'});
                return a;
            }
           
            /** 設(shè)置隨機(jī)背景顏色 **/
            function setColor(a) {
                var i = Math.ceil(Math.random()*opts.color_List.length -1);
                a.css({backgroundColor:opts.color_List[i]})
            }
           
            /** 構(gòu)造函數(shù)入口 **/
            function construct() {
                var a = createATag();
                setCss(a);    // css
                setColor(a); // color
                setXY(a);    // 坐標(biāo)位置
                return a;
            }
           
            /** 動(dòng)畫定時(shí)器函數(shù) **/
            function interVal(a,s_opcy,botm,n,space,s) {
                var opcy = a.css('opacity');  // 透明度
                var botm_ = a.css('bottom').replace('px',''); // 實(shí)時(shí)底部距離
                var opcy_ = parseFloat(new Number(a.css('opacity'))) + s_opcy;  // ++透明度
                var _opcy_ = parseFloat(new Number(a.css('opacity'))) - s_opcy; // --透明度
                var fall = botm_ - botm;  // 已移動(dòng)的距離
                botm_ = new Number(botm_) + new Number(opts.move_step);
                a.css({
                    display: 'block',
                    bottom: botm_,
                });
               
                if(fall < n)
                { a.css({opacity: opcy_}) }
                else if(2*n < fall)
                { a.css({opacity: _opcy_}) }
                   
                if (botm_ >= space)
                {
                    clearInterval(s);
                    a.remove();
                }
            }
           
            function init() {
                if(aTag.children('a').length >= new Number(opts.max_grain))
                return;
                var a = construct();
                var opcy = a.css('opacity');  // 透明度
                var zInx = a.css('zIndex');      // 層數(shù)
                var botm = a.css('bottom').replace('px',''); // 初始到底部距離
                var space = T_height - a.height() - a.css('bottom').replace('px','');  // 要移動(dòng)的距離
               
                var n = space/3;    // 變換透明度距離
                var step = 1-opcy;    // 要變化透明度值
                var sec = n/opts.move_step*opts.move_speed/1000; // 距離/單步長 * 單步長秒數(shù) = 需要秒數(shù)
                var s_opcy = opts.move_speed/1000/sec * step;  // 每次循環(huán)需要變換的透明度值
                var speed_ = getRandomNum(new Number(opts.move_speed)-30,new Number(opts.move_speed)+30);
                var currOpcy;    // 記錄鼠標(biāo)移入時(shí)透明度
//                console.log(opts.move_speed+'....'+speed_)
                /** 元素移動(dòng)循環(huán) **/
                var s = setInterval(function(){
                    interVal(a,s_opcy,botm,n,space,s);
                }, speed_)
               
                a.mouseover(function(){    // 鼠標(biāo)移入
                    currOpcy = a.css('opacity');
                    clearInterval(s);
                    $(this).css({
                        zIndex: 401,
                        opacity: 1
                    });
                });
               
                a.mouseout(function(){ // 鼠標(biāo)移出
                    $(this).css({
                        zIndex: zInx,
                        opacity: currOpcy
                    });
                    s= setInterval(function(){
                        interVal(a,s_opcy,botm,n,space,s);
                    },speed_);
                });
            }
            setATagCss();
            setInterval(init,opts.init_speed);
        });
    }
})(jQuery)

HTML:

復(fù)制代碼 代碼如下:

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 黑人一级片视频 | av在线免费观看网 | 91看片淫黄大片欧美看国产片 | 久久精品综合视频 | 一本色道久久综合狠狠躁篇适合什么人看 | 天天干干 | 精品一区二区三区网站 | 91看片在线播放 | 欧美日韩1区2区3区 黄片毛片一级 | 成人毛片网 | 中文字幕线观看 | 久久久在线免费观看 | 欧美成人免费一区二区三区 | 欧美成人一区二区视频 | 午夜伦情电午夜伦情电影 | 国产一级一片免费播放 | 麻豆一二区 | 香蕉国产精品 | 免费黄色欧美视频 | 免费观看欧美一级片 | 免费午夜视频 | 暴力肉体进入hdxxxx古装 | 91成人在线免费观看 | 草草影院地址 | 欧美黄色一级生活片 | 免费在线观看亚洲 | 日本xxxx视频 | 99亚洲伊人久久精品影院红桃 | 一级黄色a视频 | 色操网 | 免费在线中文字幕 | 日本欧美一区二区三区在线播 | 视频在线91 | 免费h片 | 毛片a片免费看 | 一区二区久久电影 | 最新欧美精品一区二区三区 | 色天使中文字幕 | 国产午夜精品久久久久 | 欧美a视频 | 羞羞网站 |