自己動(dòng)手制作jquery插件之自動(dòng)添加刪除行功能介紹
這個(gè)插件的演示頁(yè)面是http://www.lovewebgames.com/demo/autoAdd/autoAdd.html ,引用自己動(dòng)手制作jquery插件之自動(dòng)添加刪除行(上)里的介紹,這是一個(gè)簡(jiǎn)單的插件,它的作用是:一個(gè)系統(tǒng)中有大量的需要對(duì)一個(gè)行進(jìn)行復(fù)制添加,希望能夠進(jìn)行批量的操作時(shí),就可以用這個(gè)插件了。
插件效果圖如下:

在上篇里已經(jīng)提到了一些制作jquery插件的基礎(chǔ)知識(shí),接下來(lái)就是完成這此功能了,我盡量寫(xiě)得吸引人眼球一點(diǎn),首先,我們要完成最基礎(chǔ)的復(fù)制行功能,很多人,都偏愛(ài)于去拼接html代碼,他們覺(jué)得這個(gè)插件的入口應(yīng)該是傳入一段HTML代碼后,你再對(duì)這個(gè)HTML進(jìn)行模版復(fù)制,我不能說(shuō)這種做法是錯(cuò)誤的,因?yàn)樗泊_實(shí)能夠完成這項(xiàng)工作,但是如果你要復(fù)制的行的代碼比較多,又有復(fù)雜一點(diǎn)的控件,如存在日歷或城市三級(jí)菜單等,這樣你就很不易維護(hù)了,我們做前端的,就是為了讓做程序的做更少的事,讓用戶更快捷方便的體驗(yàn)。所以我盡量不讓程序去進(jìn)行轉(zhuǎn)義拼接代碼,把這些工作留給JS,jquery中有個(gè)clone(bool)的方法很好用,它有一個(gè)
function addRow(num, isInsert, target) {
for (var i = 0; i < num - count; i++) {
var temp = content.find("." + settings.tempRowClass).first().clone(true);
temp.find("input").val("");
temp.find("select").val("-1");
temp.find("textarea").val("");
temp.find(":checkbox").attr("checked", false);
temp.attr("id", "");
temp.find("input,tr,textarea,select,:checkbox,tbody").attr("id", "");
if (temp.find(".richText").length > 0) {
temp.find(".ke-container").remove();
}
temp.find(".richText,input").each(function() {
$(this).attr("id", "txt_" + Math.round(Math.random() * new Date().getTime()))
$(this).show();
});
if (isInsert) {
temp.insertBefore(target.closest("." + settings.tempRowClass));
} else {
content.append(temp);
}
}
if (num < count) {
for (var j = count - 1; j >= num; j--) {
delRow(content.find("."+settings.tempRowClass).eq(j));
}
} else {
if (settings.addCallBack)
settings.addCallBack($(temp));
}
count = content.find("." + settings.tempRowClass).length;
settings.changeInput.val(count);
sumIndex();
showhideBtn();
};
大家可能注意到,我在寫(xiě)這些方法的時(shí)候,都有在前面調(diào)用content然后再查找子集,這個(gè)是為了一個(gè)頁(yè)面同時(shí)出現(xiàn)多次調(diào)用時(shí),出現(xiàn)沖突的辦法。
這個(gè)插件寫(xiě)到這就基本上算是完成了, 區(qū)區(qū)百來(lái)行代碼,就完成了一個(gè)我認(rèn)為不錯(cuò)且實(shí)用的小工具,以后調(diào)用,就只需要在html里設(shè)置相對(duì)應(yīng)的class就行了,多么easy,是否也happy呢?那就不得而知,代碼比較粗糙,如有高手,可以幫我改進(jìn)下,歡迎大家一起探討,自所謂送人菊花,留有余香,大家加我Q群一起學(xué)習(xí)進(jìn)步吧!70210212或77813547.
- JQuery實(shí)現(xiàn)的購(gòu)物車(chē)功能(可以減少或者添加商品并自動(dòng)計(jì)算價(jià)格)
- jquery實(shí)現(xiàn)在頁(yè)面加載的時(shí)自動(dòng)為日期插件添加當(dāng)前日期
- jquery中插件實(shí)現(xiàn)自動(dòng)添加用戶的具體代碼
- 自己動(dòng)手制作jquery插件之自動(dòng)添加刪除行的實(shí)現(xiàn)
- jquery 結(jié)合C#后臺(tái)的數(shù)組對(duì)文章的關(guān)鍵字自動(dòng)添加鏈接的代碼
- jQuery自動(dòng)添加表單項(xiàng)的方法
相關(guān)文章
jquery如何實(shí)現(xiàn)點(diǎn)擊空白處隱藏元素
這篇文章主要介紹了jquery實(shí)現(xiàn)點(diǎn)擊空白處隱藏元素div等方法和實(shí)現(xiàn)代碼的講解,一起學(xué)習(xí)下。2017-12-12jQuery初識(shí)之設(shè)計(jì)思想方法函數(shù)示例
這篇文章主要為大家介紹了jQuery初識(shí)之設(shè)計(jì)思想及方法函數(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06jQuery選擇器中含有空格的使用示例及注意事項(xiàng)
選擇器中的空格是不容忽視的,多一個(gè)空格或少一個(gè)空格也許得到的結(jié)果會(huì)截然不同的,下面以一個(gè)示例為大家詳細(xì)介紹下到底有什么不同,感興趣的朋友額可以參考下2013-08-08簡(jiǎn)單的jquery左側(cè)導(dǎo)航欄和頁(yè)面選中效果
這篇文章主要介紹一個(gè)簡(jiǎn)單的jquery左側(cè)導(dǎo)航欄和頁(yè)面選中效果,此功能需引用jquery,需要的朋友可以參考下2014-08-08jQuery+jqmodal彈出窗口實(shí)現(xiàn)代碼分明
jQuery+jqmodal彈出窗口的制作方法,需要的朋友可以參考下。2010-06-06Jquery實(shí)現(xiàn)無(wú)縫向上循環(huán)滾動(dòng)列表的特效
今天小編就為大家分享一篇關(guān)于Jquery實(shí)現(xiàn)無(wú)縫向上循環(huán)滾動(dòng)列表的特效,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-02-02