自己动手制作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 简短右键菜单 多浏览器兼容
Jan 01 Javascript
Javascript读取cookie函数代码
Oct 16 Javascript
DWR实现模拟Google搜索效果实现原理及代码
Jan 30 Javascript
thinkphp实现无限分类(使用递归)
Dec 19 Javascript
js判断文本框输入的内容是否为数字
Dec 23 Javascript
JS正则匹配URL网址的方法(可匹配www,http开头的一切网址)
Jan 06 Javascript
webpack热模块替换(HMR)/热更新的方法
Apr 05 Javascript
微信小程序中this.data与this.setData的区别详解
Sep 17 Javascript
可能被忽略的一些JavaScript数组方法细节
Feb 28 Javascript
Vue.js轮播图走马灯代码实例(全)
May 08 Javascript
vue3修改link标签默认icon无效问题详解
Oct 09 Javascript
解决Vue使用bus总线时,第一次路由跳转时数据没成功传递问题
Jul 28 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
消息持续发送的完整例子
2006/10/09 PHP
一个简单php扩展介绍与开发教程
2010/08/19 PHP
php加密解密实用类分享
2014/01/07 PHP
php实现保存submit内容之后禁止刷新
2014/03/19 PHP
PHP 获取ip地址代码汇总
2015/07/05 PHP
php arsort 数组降序排序详细介绍
2016/11/17 PHP
php设计模式之策略模式实例分析【星际争霸游戏案例】
2020/03/26 PHP
IE与firefox下Dhtml的一些区别小结
2009/12/02 Javascript
借助JavaScript脚本判断浏览器Flash Player信息的方法
2014/07/09 Javascript
js和jquery中循环的退出和继续学习记录
2014/09/06 Javascript
JS实现控制表格行内容垂直对齐的方法
2015/03/30 Javascript
详解JavaScript中的every()方法
2015/06/08 Javascript
解决AngualrJS页面刷新导致异常显示问题
2017/04/20 Javascript
Javascript中从学习bind到实现bind的过程
2018/01/05 Javascript
jQuery实现表单动态添加与删除数据操作示例
2018/07/03 jQuery
Vue刷新修改页面中数据的方法
2018/09/16 Javascript
webpack中的模式(mode)使用详解
2020/02/20 Javascript
JQuery获得内容和属性方法解析
2020/05/30 jQuery
Python splitlines使用技巧
2008/09/06 Python
python self,cls,decorator的理解
2009/07/13 Python
python使用urllib2模块获取gravatar头像实例
2013/12/18 Python
Python使用自带的ConfigParser模块读写ini配置文件
2016/06/26 Python
浅谈Python2、Python3相对路径、绝对路径导入方法
2018/06/22 Python
使用python实现抓取腾讯视频所有电影的爬虫
2019/04/15 Python
利用python-pypcap抓取带VLAN标签的数据包方法
2019/07/23 Python
对Tensorflow中tensorboard日志的生成与显示详解
2020/02/04 Python
Python+Kepler.gl实现时间轮播地图过程解析
2020/07/20 Python
css3学习之2D转换功能详解
2016/12/23 HTML / CSS
英国领先的汽车轮胎和快速健康中心:Kwik Fit
2017/10/29 全球购物
Sephora丝芙兰马来西亚官方网站:国际化妆品购物
2018/03/15 全球购物
技术总监个人的自我评价范文
2013/12/18 职场文书
拓展训练激励口号
2014/06/17 职场文书
2015年中学图书馆工作总结
2015/07/22 职场文书
新郎婚礼致辞
2015/07/27 职场文书
创业计划书之农家乐
2019/10/09 职场文书
如何用Navicat操作MySQL
2021/05/12 MySQL