用Jquery实现可编辑表格并用AJAX提交到服务器修改数据


Posted in Javascript onDecember 27, 2009

下面是js Code:

$(function() { // 相当于在页面中的body标签加上onload事件 
$(".caname").click(function() { // 给页面中有caname类的标签加上click函数 
var objTD = $(this); 
var oldText = $.trim(objTD.text()); // 保存老的类别名称 
var input = $("<input type='text' value='" + oldText + "' />"); // 文本框的HTML代码 
objTD.html(input); // 当前td的内容变为文本框 
// 设置文本框的点击事件失效 
input.click(function() { 
return false; 
}); 
// 设置文本框的样式 
input.css("border-width", "0px"); //边框为0 
input.height(objTD.height()); //文本框的高度为当前td单元格的高度 
input.width(objTD.width()); // 宽度为当前td单元格的宽度 
input.css("font-size", "14px"); // 文本框的内容文字大小为14px 
input.css("text-align", "center"); // 文本居中 
input.trigger("focus").trigger("select"); // 全选 
// 文本框失去焦点时重新变为文本 
input.blur(function() { 
var newText = $(this).val(); // 修改后的名称 
var input_blur = $(this); 
// 当老的类别名称与修改后的名称不同的时候才进行数据的提交操作 
if (oldText != newText) { 
// 获取该类别名所对应的ID(序号) 
var caid = $.trim(objTD.prev().text()); 
// AJAX异步更改数据库 
var url = "../handler/ChangeCaName.ashx?caname=" + encodeURI(encodeURI(newText)) + "&caid=" + caid + "&t=" + new Date().getTime(); 
$.get(url, function(data) { 
if (data == "false") { 
$("#test").text("类别修改失败,请检查是否类别名称重复!"); 
input_blur.trigger("focus").trigger("select"); // 文本框全选 
} else { 
$("#test").text(""); 
objTD.html(newText); 
} 
}); 
} else { 
// 前后文本一致,把文本框变成标签 
objTD.html(newText); 
} 
}); 
// 在文本框中按下键盘某键 
input.keydown(function(event) { 
var jianzhi = event.keyCode; 
var input_keydown = $(this); 
switch (jianzhi) { 
case 13: // 按下回车键 ,把修改后的值提交到数据库 
// $("#test").text("您按下的键值是: " + jianzhi); 
var newText = input_keydown.val(); // 修改后的名称 
// 当老的类别名称与修改后的名称不同的时候才进行数据的提交操作 
if (oldText != newText) { 
// 获取该类别名所对应的ID(序号) 
var caid = $.trim(objTD.prev().text()); 
// AJAX异步更改数据库 
var url = "../handler/ChangeCaName.ashx?caname=" + encodeURI(encodeURI(newText)) + "&caid=" + caid + "&t=" + new Date().getTime(); 
$.get(url, function(data) { 
if (data == "false") { 
$("#test").text("类别修改失败,请检查是否类别名称重复!"); 
input_keydown.trigger("focus").trigger("select"); // 文本框全选 
} else { 
$("#test").text(""); 
objTD.html(newText); 
} 
}); 
} else { 
// 前后文本一致,把文本框变成标签 
objTD.html(newText); 
} 
break; 
case 27: // 按下Esc键, 取消修改,把文本框变成标签 
$("#test").text(""); 
objTD.html(oldText); 
break; 
} 
}); 
}); 
}); // 屏蔽Enter按键 
$(document).keydown(function(event) { 
switch (event.keyCode) { 
case 13: return false; 
} 
});

下面是 一般处理程序代码 ChangeCaName.ashx
<%@ WebHandler Language="C#" Class="ChangeCaName" %> 
using System; 
using System.Web; 
using BLL; 
using Model; 
public class ChangeCaName : IHttpHandler 
{ 
public void ProcessRequest(HttpContext context) 
{ 
context.Response.ContentType = "text/plain"; 
string caid = context.Request.QueryString["caid"]; 
string caname = context.Server.UrlDecode(context.Request.QueryString["caname"]); 
// 判断数据库中是否已经存在同名类别 
if (new CategoryManager().IsExists(caname)) 
{ 
context.Response.Write("false"); 
return; 
} 
// 更改数据库类别名 
Category ca = new Category(caid, caname); 
bool b = new CategoryManager().Update(ca); 
if (b) 
{ 
context.Response.Write("true"); 
} 
else 
{ 
context.Response.Write("false"); 
} 
} 
public bool IsReusable 
{ 
get 
{ 
return false; 
} 
} 
}
Javascript 相关文章推荐
编写js扩展方法判断一个数组中是否包含某个元素
Nov 08 Javascript
JQuery的ready函数与JS的onload的区别详解
Nov 21 Javascript
jQuery中通过ajax调用webservice传递数组参数的问题实例详解
May 20 Javascript
基于bootstrop常用类总结(推荐)
Sep 11 Javascript
jquery写出PC端轮播图实例
Jan 26 jQuery
JavaScript中的E-mail 地址格式验证
Mar 28 Javascript
小程序实现录音上传功能
Nov 22 Javascript
使用js实现单链解决前端队列问题的方法
Feb 03 Javascript
Vue项目中使用flow做类型检测的方法
Mar 18 Javascript
编写一个javascript元循环求值器的方法
Apr 14 Javascript
axios封装与传参示例详解
Oct 18 Javascript
js闭包和垃圾回收机制示例详解
Mar 01 Javascript
jQuery中的常用事件总结
Dec 27 #Javascript
jQuery 动态酷效果实现总结
Dec 27 #Javascript
javascript 清空form表单中某种元素的值
Dec 26 #Javascript
JavaScript 入门基础知识 想学习js的朋友可以参考下
Dec 26 #Javascript
十分钟打造AutoComplete自动完成效果代码
Dec 26 #Javascript
jQuery 常见开发使用技巧总结
Dec 26 #Javascript
javascript 最常用的10个自定义函数[推荐]
Dec 26 #Javascript
You might like
玩转虚拟域名◎+ .
2006/10/09 PHP
php根据操作系统转换文件名大小写的方法
2014/02/24 PHP
thinkphp中空模板与空模块的用法实例
2014/11/26 PHP
PHP把MSSQL数据导入到MYSQL的方法
2014/12/27 PHP
关于扩展 Laravel 默认 Session 中间件导致的 Session 写入失效问题分析
2016/01/08 PHP
php查询及多条件查询
2017/02/26 PHP
PHP十六进制颜色随机生成器功能示例
2017/07/24 PHP
Nigma vs Alliance BO5 第四场2.14
2021/03/10 DOTA
javascript代码加载优化方法
2011/01/30 Javascript
jquery创建一个新的节点对象(自定义结构/内容)的好方法
2013/01/21 Javascript
纯JS实现旋转图片3D展示效果
2015/04/12 Javascript
jQuery.deferred对象使用详解
2016/03/18 Javascript
原生js实现电商侧边导航效果
2017/01/19 Javascript
angular4中引入echarts的方法示例
2019/01/29 Javascript
[02:27]《DAC最前线》之附加赛征程
2015/01/29 DOTA
[06:20]2015国际邀请赛第三日top10
2015/08/08 DOTA
[15:07]lgd_OG_m2_BP
2019/09/10 DOTA
python自动化测试实例解析
2014/09/28 Python
Python常用时间操作总结【取得当前时间、时间函数、应用等】
2017/05/11 Python
python opencv之SURF算法示例
2018/02/24 Python
python获取时间及时间格式转换问题实例代码详解
2018/12/06 Python
python实现简单多人聊天室
2018/12/11 Python
浅谈python requests 的put, post 请求参数的问题
2019/01/02 Python
python给微信好友定时推送消息的示例
2019/02/20 Python
详解Python装饰器
2019/03/25 Python
Python面向对象封装操作案例详解 II
2020/01/02 Python
HTML5中drawImage用法分析
2014/12/01 HTML / CSS
商务助理岗位职责
2013/11/13 职场文书
学校食堂采购员岗位职责
2013/12/05 职场文书
车间组长岗位职责
2013/12/20 职场文书
体育教师自我鉴定
2014/02/12 职场文书
书香校园活动方案
2014/02/28 职场文书
科长竞聘演讲稿
2014/05/16 职场文书
超市优秀员工获奖感言
2014/08/15 职场文书
关于青春的演讲稿三分钟
2014/08/22 职场文书
2014年房产销售工作总结
2014/12/08 职场文书