這是一個我認為功能基本完善的插件,它包括添加、刪除、插入、上下移動、索引標識、 數量控制等功能,基本上能滿足大部分多行添加的需求,當然,在完成這些功能的前提下,我也盡量保持較少的代碼量和易理解的邏輯性。
這個插件的演示頁面是http://www.lovewebgames.com/demo/autoAdd/autoAdd.html ,引用自己動手制作jquery插件之自動添加刪除行(上)裡的介紹,這是一個簡單的插件,它的作用是:一個系統中有大量的需要對一個行進行復制添加,希望能夠進行批量的操作時,就可以用這個插件了。
插件效果圖如下:
在上篇裡已經提到了一些制作jquery插件的基礎知識,接下來就是完成這此功能了,我盡量寫得吸引人眼球一點,首先,我們要完成最基礎的復制行功能,很多人,都偏愛於去拼接html代碼,他們覺得這個插件的入口應該是傳入一段HTML代碼後,你再對這個HTML進行模版復制,我不能說這種做法是錯誤的,因為它也確實能夠完成這項工作,但是如果你要復制的行的代碼比較多,又有復雜一點的控件,如存在日歷或城市三級菜單等,這樣你就很不易維護了,我們做前端的,就是為了讓做程序的做更少的事,讓用戶更快捷方便的體驗。所以我盡量不讓程序去進行轉義拼接代碼,把這些工作留給JS,jquery中有個clone(bool)的方法很好用,它有一個
Boolean類型的參數,如果你要完全的復制某個dom對象,包括它上面的事件的話,就可以用clone(true)了,這樣也少了再次綁定事件的困繞,所以這個插件的回調方法,其實很難用到。添加行的代碼如下:
代碼如下:
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();
};
大家可能注意到,我在寫這些方法的時候,都有在前面調用content然後再查找子集,這個是為了一個頁面同時出現多次調用時,出現沖突的辦法。
這個插件寫到這就基本上算是完成了, 區區百來行代碼,就完成了一個我認為不錯且實用的小工具,以後調用,就只需要在html裡設置相對應的class就行了,多麼easy,是否也happy呢?那就不得而知,代碼比較粗糙,如有高手,可以幫我改進下,歡迎大家一起探討,自所謂送人菊花,留有余香,大家加我Q群一起學習進步吧!70210212或77813547.