4、jQuery面向对象之简单的插件开发
1、alert例子
(function($){
$.alert = function(msg){
window.alert(msg);
}
$.fn.alert = function(msg){
window.alert(msg);
}
})($);
$().ready(function(){
$.alert("aaaaa");
$("body").alert("bbbb");
});
2、继承
(function(jQuery){
jQuery.fn.myextend = function(json){
for(var i in json){
jQuery.fn[i] = json[i];
}
}
jQuery.myextend = function(json){
for(var i in json){
jQuery[i] = json[i];
}
}
})(jQuery);
$().ready(function(){
$("body").myextend({
aa:function(){
alert("aa");
}
});
$("body").aa();
});
3、myeach
(function(jQuery){
jQuery.fn.myeach = function(callback){
var array = $(this);
for(var i=0;i<array.length;i++){
//this代表当前正在遍历的对象
callback.call($(array[i]),$(array[i]));
}
}
/**
* @param {Object} obj 可以来自于利用jquery的选择器创建的jquery对象,也可以来自于一个数组(来源于后台)
* @param {Object} callback
*/
jQuery.myeach = function(obj,callback){
var array = obj;
for(var i=0;i<array.length;i++){
//this代表当前正在遍历的对象
callback.call($(array[i]),$(array[i]));
}
}
})(jQuery);
$().ready(function(){
$("div").myeach(function(){
//this代表当前正在遍历的div对象
alert($(this).text());
});
$.myeach($("div"),function(e){
alert($(e).text());
});
});
4、jquery开发的querytable
1、首先封装一个命名空间的组件
(function($){
$.nameSapce = function(namespaceString){
var temp = [];//声明了一个空的数组
var array = namespaceString.split(".");
for (var i = 0; i < array.length; i++) {
temp.push(array[i]);
/**
* 把多个json对象添加了window上
*/
eval("window." + temp.join(".") + "={}");
}
}
})($); 2、封装对table的增删改查
(function($){
/**
* 这里需要一些方法
* 查询方法
* 修改的方法
* 删除的方法
*/
$.fn.GridPanel = {
/**
* 初始化事件
*/
initEvent:function(){
/**
* 给table中的所有的超级链接添加事件
*/
$("#"+$.fn.GridPanel.defaultConfig.table_id).delegate("a","click",function(){
if($(this).text()=="删除"){
$.fn.GridPanel.method.deleteRow.call(this);
}else if($(this).text()=="修改"){
}
})
/**
* 当点击一个td的时候,触发td的click事件
*
* "td:not(:has(a))" 不含有超级链接的td
*/
$("#"+$.fn.GridPanel.defaultConfig.table_id).delegate("td:not(:has(a))","click",function(){
if($(this).children("input").length==0){//td下面没有文本框
var value = $(this).text();
$(this).empty();//把该元素下面的所有的子子元素清空
var $txt = $.fn.GridPanel.method.createText();
$(this).append($txt);
$txt.focus();//聚焦
$txt.attr("value",value);//赋值
}
})
/*
* 添加td中的文本框失去焦点的事件
*/
$("#"+$.fn.GridPanel.defaultConfig.table_id).delegate("input","blur",function(){
$.fn.GridPanel.method.updateCell.call(this);
})
},
/**
* 默认的配置
*/
defaultConfig:{
table_id:'',
url:'',
/**
* 特定的操作要往后台传递的参数
*/
option:{
/**
* 查询操作
*/
query:{
},
/**
* 删除操作
*/
del:{
},
/**
* 修改操作
*/
update:{
}
},
/**
* <th field="name">姓名</th>
<th field="description">描述</th>
<th field="del">删除</th>
<th field="update">修改</th>
*/
fields:'',
filedUpdate:'',
filedDelete:''
},
/**
* 对表格操作的所有的方法全部放在method中
*/
method:{
/**
* 从后台加载数据,利用ajax技术形成表格
*/
createTable:function(config){
/**
* 1、请求后台,把数据传到客户端
*/
//把客户端传递过来的参数覆盖掉默认的配置 true为深度迭代
$.extend(true,$.fn.GridPanel.defaultConfig,config);
/**
* 执行initEvent方法
*/
$.fn.GridPanel.initEvent();
$.post($.fn.GridPanel.defaultConfig.url,$.fn.GridPanel.defaultConfig.option.query,function(data){
/**
* data:
* [
* {
* pid:1,
* name:'aa',
* description:'aa'
* },
* {
* pid:2,
* name:'bb',
* description:'bb'
* }
* ]
*/
//把后台回调过来的数据转化成json对象
var array = eval("("+data+")");
/**
* 遍历array数组中的每一个元素
* 第二个参数为回调,在该函数中创建tr
*/
$.each(array,function(){
/**
* 每遍历一次,调用一次createTR方法
* 当createTR方法调用完毕以后创建了一个tr,再把tr追加到tbody上
*/
$("#"+$.fn.GridPanel.defaultConfig.table_id+" tbody").append(
$.fn.GridPanel.method.createTR.call(this));
});
});
},
/**
* 修改其中的一个单元格
*/
updateCell:function(){
/**
* this为当前的文本框
*/
var updateObj = $(this);
var pid = $(this).parent().parent().data("id");
var value = $(this).val(); //文本框的值
var $td = $(this).parent();//文本框的父节点td
var item = $td.attr("item");//要修改的列名
$.post($.fn.GridPanel.defaultConfig.url,{
id:pid,
item:item,
value:value,
method:'update'
},function(data){
updateObj.remove();
$td.text(value);
});
},
/**
* 给table添加一行
*/
addRow:function(){
},
/**
* 删除指定的行
*/
deleteRow:function(){
var delObj = $(this);
if (window.confirm("您确认要删除吗")) {
/*
* 因为在查询的时候把id利用该tr放入到了jQuery的缓存中,所以在这里可以提取到
*/
$.fn.GridPanel.defaultConfig.option.del.pid = $(this).parent().parent().data("id");
$.post($.fn.GridPanel.defaultConfig.url, $.fn.GridPanel.defaultConfig.option.del, function(data){
delObj.parent().parent().remove();
});
}
},
/**
* 创建一个tr
*/
createTR:function(){
/**
* this为{
pid:2,
name:'bb',
description:'bb'
}
*/
var jsonObj = this;
var $tr = $("<tr/>");
/**
* 相当于把key为id,value为jsonObj.pid加在了jQuery.cache中
* 可以利用$tr.data("id")获取到值
*/
$tr.data("id",jsonObj.pid);
/**
* 因为$.fn.GridPanel.defaultConfig.fields的数组的长度就是多少列
*/
$.each($.fn.GridPanel.defaultConfig.fields,function(){
/**
* this代表正在遍历的每一个元素就是fields中的每一个元素
*/
$tr.append($.fn.GridPanel.method.createTD.call(this,jsonObj));
});
return $tr;
},
/**
* 创建一个td
* jsonObj
* {
pid:2,
name:'bb',
description:'bb'
}
*/
createTD:function(jsonObj){
/**
* this <th field="name">姓名</th>
*/
if($(this).attr("field")==$.fn.GridPanel.defaultConfig.filedDelete){//如果是删除
return $("<td/>").append($.fn.GridPanel.method.createA("删除"));
}else if($(this).attr("field")==$.fn.GridPanel.defaultConfig.filedUpdate){//如果是修改
return $("<td/>").append($.fn.GridPanel.method.createA("修改"));
}else{//不是超级链接
return $("<td/>").attr("item",$(this).attr("field")).text(jsonObj[$(this).attr("field")]);
}
},
createA:function(text){
return $("<a/>").css("cursor","pointer").text(text);
},
createText:function(){
return $("<input type='text'/>");
}
}
};
})($);
3、如何使用
$().ready(function(){
/**
* 1、创建命名空间
*/
$.nameSapce("com.itheima12.Person");
/**
* 2、把GridPanel中的内容复制给了com.itheima12.Person
*/
$.extend(com.itheima12.Person,$.fn.GridPanel);
/**
* 3、调用方法
*/
com.itheima12.Person.method.createTable({
table_id:'usertable',
url:'../PersonServlet',
fields:$("#usertable *[field]"),
option:{
query:{
method:'query'
},
del:{
method:'deleteById',
pid:''
},
update:{
method:"update"
}
},
filedUpdate:'update',
filedDelete:'del'
});
});
5、对于this的讲解
/**
* 任何一个对象都有可能成为任何一个对象的属性
*/
function Person(){
alert(this);
}
Person();//window = this function Student(){ }
Student.a = Person;
Student.a();//this就是Student
var json = {
a:Person
}
json.a();//this就是json对象 //可以利用call和 apply函数改变this的指向
Person.call(json);//Person.call(json)==json.Person
Person.apply(Student);//Student.Person();
4、jQuery面向对象之简单的插件开发的更多相关文章
- 使用dom元素和jquery元素实现简单增删改的练习
软件开发实际就是数据的增删改查,javascript前端开发也不例外.今天学了jquery框架的简单使用.于是用它实现简单的增删改,接着也用原始的javascript实现同样的功能,以便看出jquer ...
- 使用Struts2和jQuery EasyUI实现简单CRUD系统(转载汇总)
使用Struts2和jQuery EasyUI实现简单CRUD系统(一)——从零开始,ajax与Servlet的交互 使用Struts2和jQuery EasyUI实现简单CRUD系统(二)——aja ...
- php+jquery+ajax+json简单小例子
直接贴代码: <html> <title>php+jquery+ajax+json简单小例子</title> <?php header("Conte ...
- 原生JS取代一些JQuery方法的简单实现
原生JS取代一些JQuery方法的简单实现 下面小编就为大家带来一篇原生JS取代一些JQuery方法的简单实现.小编觉得挺不错的,现在就分享给大家,也给大家做个参考.一起跟随小编过来看看吧 1.选 ...
- 3、jQuery面向对象
1.首先介绍callback.js对ajax进行了封装 function ajaxFunction(){ var xmlHttp; try{ // Firefox, Opera 8.0+, Safar ...
- jQuery学习之路(7)- 用原生JavaScript实现jQuery的某些简单功能
▓▓▓▓▓▓ 大致介绍 学习了妙味,用原生的JavaScript实现jQuery中的某些部分功能 定义自己的函数库lQuery ▓▓▓▓▓▓ $()选择器的实现 jQuery是面向对象的,所以自己编写 ...
- MYSQL、PHP基础、面向对象基础简单复习总结
一.MYSQL 1.配置MySql 第一步安装服务器(apache). 第二部安装MySql界面程序 2 ...
- 以最简单的登录为例,诠释JS面向对象的简单实例
JavaScript,是前端开发人员必须会的一门技术,从JS演变出来的有很多框架,先说说几个热门的框架吧: JQuery:这个技术必须会,如果不会,那一定要会查api,知道怎么写,要看得懂英文文档,这 ...
- sql+PHP基础+面向对象基础简单总结
一.MYSQL 1.配置MySql 第一步安装服务器(apache). 第二部安装MySql界面程序 2 ...
随机推荐
- jQuery-resize和scroll的性能优化
## 下面是进行测试和研究怎么实现的用的 Document 改变页面大小试试 Document 滚动滚动条试试
- 使用SSH方式实现Git远程连接GitHub/gitlab
参照: https://blog.csdn.net/wuli_smbug/article/details/81480162
- 禁止修改input内容
有什么问题请到<a href='/bbs/index.asp?boardid=2'>论坛</a>中发表<br> <!--# 特效来源:http://www.o ...
- ubuntu 使用pecl 安装 PHP AMQP Extension
下载扩展: sudo apt-get -y install gcc make autoconf libc-dev pkg-config sudo apt-get -y install libssl-d ...
- 项目部署到IIS后,明明存在某个文件,但是访问却返回404
项目部署到IIS后,明明存在某个文件,但是访问却返回404,这是为什么呢,原因很可能是未添加MIME类型 比如我的文件名是“iconfont.woff” 打开IIS,点击对应的项目,右面展示的是下图 ...
- Linux拓展练习部分--输入输出 / find部分 /基础拓展2
目录 输入输出部分 find部分 基础阶段-拓展练习2 输入输出部分 1.输入时间命令"date"将当前系统时间输出到/data/1.txt [root@centos7 ~]# d ...
- Java缓冲流的优点和原理
不带缓冲的流的工作原理: 它读取到一个字节/字符,就向用户指定的路径写出去,读一个写一个,所以就慢了. 带缓冲的流的工作原理: 读取到一个字节/字符,先不输出,等凑足了缓冲的最大容量后一次性写出去,从 ...
- mysql 存储引擎介绍2
了解MYSQL的都知道,在MYSQL中建立任何一张数据表,在其数据目录对应的数据库目录下都有对应表的.frm文件,.frm文件是用来保存每个数据表的元数据(meta)信息,包括表结构的定义等,.frm ...
- oracle 数据恢复
闪回表删除之前 flashback table t1 to before drop; 如果彻底删除表此方法无效 若要彻底删除表,则使用语句:drop table <table_name> ...
- 禁用ubuntu启用虚拟内存swap
一.不重启电脑,禁用启用swap,立刻生效 # 禁用命令 sudo swapoff -a # 启用命令 sudo swapon -a # 查看交换分区的状态 sudo free -m 二.重新启动电脑 ...