自己动手制作jquery插件之自动添加删除行功能介绍


Posted in Javascript onOctober 14, 2011

这是一个我认为功能基本完善的插件,它包括添加、删除、插入、上下移动、索引标识、 数量控制等功能,基本上能满足大部分多行添加的需求,当然,在完成这些功能的前提下,我也尽量保持较少的代码量和易理解的逻辑性。

     这个插件的演示页面是http://www.lovewebgames.com/demo/autoAdd/autoAdd.html ,引用自己动手制作jquery插件之自动添加删除行(上)里的介绍,这是一个简单的插件,它的作用是:一个系统中有大量的需要对一个行进行复制添加,希望能够进行批量的操作时,就可以用这个插件了。

     插件效果图如下:

 

自己动手制作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.

Javascript 相关文章推荐
jQuery jcrop插件截图使用方法
Nov 20 Javascript
Jquery插件easyUi表单验证提交(示例代码)
Dec 30 Javascript
javascript 模拟坦克大战游戏(html5版)附源码下载
Apr 08 Javascript
jquery浏览器滚动加载技术实现方案
Jun 03 Javascript
更靠谱的H5横竖屏检测方法(js代码)
Sep 13 Javascript
懒加载实现的分页&amp;&amp;网站footer自适应
Dec 21 Javascript
基于vue,vue-router, vuex及addRoutes进行权限控制问题
May 02 Javascript
修改npm全局安装模式的路径方法
May 15 Javascript
小程序组件之仿微信通讯录的实现代码
Sep 12 Javascript
Vue使用vue-draggable 插件在不同列表之间拖拽功能
Mar 12 Javascript
前端使用crypto.js进行加密的函数代码
Aug 16 Javascript
关于uniApp editor微信滑动问题
Jan 15 Javascript
javascript nextSibling 与 getNextElement(node) 使用介绍
Oct 13 #Javascript
获取body标签的两种方法
Oct 13 #Javascript
自己动手制作jquery插件之自动添加删除行的实现
Oct 13 #Javascript
jQuery EasyUI API 中文文档 - NumberBox数字框
Oct 13 #Javascript
最短的javascript:地址栏载入脚本代码
Oct 13 #Javascript
jQuery EasyUI API 中文文档 - ComboGrid 组合表格
Oct 13 #Javascript
Javascript insertAfter() 实现函数代码
Oct 12 #Javascript
You might like
php 301转向实现代码
2008/09/18 PHP
PHP向浏览器输出内容的4个函数总结
2014/11/17 PHP
php通过array_merge()函数合并关联和非关联数组的方法
2015/03/18 PHP
PHP的pcntl多进程用法实例
2015/03/19 PHP
php使用socket post数据到其它web服务器的方法
2015/06/02 PHP
php集成套件服务器xampp安装使用教程(适合第一次玩PHP的新手)
2015/06/03 PHP
PHP模拟QQ登录的方法
2015/07/29 PHP
php引用和拷贝的区别知识点总结
2019/09/23 PHP
PHP使用openssl扩展实现加解密方法示例
2020/02/20 PHP
jQuery filter函数使用方法
2014/05/19 Javascript
js获取json元素数量的方法
2015/01/27 Javascript
浅谈JavaScript的Polymer框架中的behaviors对象
2015/07/29 Javascript
jQuery获取多种input值的简单实现方法
2016/06/20 Javascript
JS取数字小数点后两位或n位的简单方法
2016/10/24 Javascript
js实现砖头在页面拖拉效果
2020/11/20 Javascript
vue.js系列中的vue-fontawesome使用
2018/02/10 Javascript
使用async await 封装 axios的方法
2018/07/09 Javascript
vue中使用sessionStorage记住密码功能
2018/07/24 Javascript
浅谈微信JS-SDK 微信分享接口开发(介绍版)
2018/08/15 Javascript
Jquery让form表单异步提交代码实现
2019/11/14 jQuery
python实现dnspod自动更新dns解析的方法
2014/02/14 Python
wx.CheckBox创建复选框控件并响应鼠标点击事件
2018/04/25 Python
使用Python实现在Windows下安装Django
2018/10/17 Python
Python celery原理及运行流程解析
2020/06/13 Python
Python用requests库爬取返回为空的解决办法
2021/02/21 Python
俄罗斯的精英皮具:Wittchen
2018/01/29 全球购物
理肤泉俄罗斯官网:La Roche-Posay俄罗斯
2018/07/24 全球购物
德国网上花店:Valentins
2018/08/15 全球购物
Web Service面试题:如何搭建Axis2的开发环境
2012/06/20 面试题
毕业生的自我鉴定
2013/10/29 职场文书
《夸父追日》教学反思
2014/02/26 职场文书
投标担保书范文
2014/04/02 职场文书
低碳环保演讲稿
2014/08/28 职场文书
2015年初中教师个人工作总结
2015/07/21 职场文书
穷人该怎么创业?谨记以下几点
2019/07/11 职场文书
Redis主从配置和底层实现原理解析(实战记录)
2021/06/30 Redis