jQuery插件小結(jié)

雖然現(xiàn)如今vue、angular等的框架大行其道念搬,但是jQuery依然還是日常開(kāi)發(fā)非常常用的抑堡,而其中插件又是愛(ài)不釋手的,今天簡(jiǎn)單來(lái)看一下如何封裝一個(gè)簡(jiǎn)單的插件朗徊。

核心語(yǔ)法

<pre>

<script>
//定義好一個(gè)插件
$.fn.extend({
toRed(){
this.css(background:'red')
//這個(gè)方法被誰(shuí)引用首妖,this就是指被引用的jQuery對(duì)象
}
})
//下面開(kāi)始引用插件
$(function(){
$('div').toRed();
})
</script>
<body>
<div></div>
</body>
</pre>
1.一個(gè)拖拽案例
<pre>
<script>
$.fn.extend({
drag(){
//this在這里表示被外面哪一個(gè)元素引用的jQuery對(duì)象
let oDiv=this;
oDiv.on('mousedown',function(ev){
let disx=ev.clientX-oDiv.offset().left;
let disy=ev.clientY-oDiv.offset().top;

                function fnMove(ev){
                    let l=ev.clientX-disx;
                    let t=ev.clientY-disy;
                    
                    oDiv.css({
                        left:l+'px',
                        top:t+'px'
                    })
                    return false;
                }
                function fnUp(){
                    $(document).off('mousemove',fnMove);
                    $(document).off('mouseup',fnUp);
                }
                $(document).on('mousemove',fnMove);
                $(document).on('mouseup',fnUp);
                
            })
            }
        })
       //在這里引用插件中封裝好的drag方法
        $(function(){
            $('div').drag();
        })
    </script>
<body>
    <div id="div"></div>
</body>

</script>
</pre>

2.一個(gè)可以傳參數(shù)的拖拽
defaultConfig,當(dāng)中可以設(shè)置任意參數(shù)。el代表可以進(jìn)行拖拽哪個(gè)元素爷恳,還有距離四個(gè)方向的距離有缆,如果不傳遞那么就是默認(rèn)的。
<pre>
<script>
$.fn.extend({
drag(options){
let oDiv=this;
let defaultConfig={
el:oDiv,
left:0,
top:0,
right:document.documentElement.clientWidth,
bottom:document.documentElement.clientHeight
}
//這里需要將外部傳遞的參數(shù)和這里默認(rèn)的值進(jìn)行校驗(yàn)
let config=$.extend(defaultConfig,options);
let el;
//判斷是否傳遞控制哪一個(gè)元素温亲,如果不傳默認(rèn)是oDiv
if(typeof(config.el)=="string"){
el=oDiv.find(config.el);
}else{
el=oDiv;
}
el.on('mousedown',function(ev){
let disx=ev.clientX-el.offset().left;
let disy=ev.clientY-el.offset().top;

                function fnMove(ev){
                    let l=ev.clientX-disx;
                    let t=ev.clientY-disy;
                    if(l<config.left){
                        l=config.left;
                    }
                    if(l>config.right-oDiv.outerWidth()){
                        l=config.right-oDiv.outerWidth();
                    }
                    if(t<config.top){
                        t=config.top;
                    }
                    if(t>config.bottom){
                        t=config.bottom-oDiv.outerHeight();
                    }
                    oDiv.css({
                        left:l+'px',
                        top:t+'px'
                    })
                    return false;
                }
                function fnUp(){
                    $(document).off('mousemove',fnMove);
                    $(document).off('mouseup',fnUp);
                }
                $(document).on('mousemove',fnMove);
                $(document).on('mouseup',fnUp);
                
            })
            }
        })
        $(function(){

//直接引用妒貌,并且傳遞了四個(gè)參數(shù),代表了只有在span元素上的拖拽才會(huì)生效铸豁,并且限制div元素的四個(gè)最大方向
$('div').drag({
el:'span',
right:600,
left:50,
bottom:600
});
})
</script>
</head>
//當(dāng)然這里的div都沒(méi)有設(shè)置樣式灌曙,還須自己設(shè)置,span標(biāo)簽可以隨意設(shè)置任何標(biāo)簽
<body>
<div id="div">
<span></span>
</div>
</body>
</pre>

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末节芥,一起剝皮案震驚了整個(gè)濱河市在刺,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌头镊,老刑警劉巖蚣驼,帶你破解...
    沈念sama閱讀 217,826評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異相艇,居然都是意外死亡颖杏,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)坛芽,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)留储,“玉大人翼抠,你說(shuō)我怎么就攤上這事』窕洌” “怎么了阴颖?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,234評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)丐膝。 經(jīng)常有香客問(wèn)我量愧,道長(zhǎng),這世上最難降的妖魔是什么帅矗? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,562評(píng)論 1 293
  • 正文 為了忘掉前任偎肃,我火速辦了婚禮,結(jié)果婚禮上浑此,老公的妹妹穿的比我還像新娘累颂。我一直安慰自己,他們只是感情好尤勋,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,611評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著茵宪,像睡著了一般最冰。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上稀火,一...
    開(kāi)封第一講書(shū)人閱讀 51,482評(píng)論 1 302
  • 那天暖哨,我揣著相機(jī)與錄音,去河邊找鬼凰狞。 笑死篇裁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的赡若。 我是一名探鬼主播达布,決...
    沈念sama閱讀 40,271評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼逾冬!你這毒婦竟也來(lái)了黍聂?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,166評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤身腻,失蹤者是張志新(化名)和其女友劉穎产还,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體嘀趟,經(jīng)...
    沈念sama閱讀 45,608評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡脐区,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,814評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了她按。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片牛隅。...
    茶點(diǎn)故事閱讀 39,926評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡炕柔,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出倔叼,到底是詐尸還是另有隱情汗唱,我是刑警寧澤,帶...
    沈念sama閱讀 35,644評(píng)論 5 346
  • 正文 年R本政府宣布丈攒,位于F島的核電站哩罪,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏巡验。R本人自食惡果不足惜际插,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,249評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望显设。 院中可真熱鬧框弛,春花似錦、人聲如沸捕捂。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,866評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)指攒。三九已至慷妙,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間允悦,已是汗流浹背膝擂。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,991評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留隙弛,地道東北人架馋。 一個(gè)月前我還...
    沈念sama閱讀 48,063評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像全闷,于是被迫代替她去往敵國(guó)和親叉寂。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,871評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容