用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下高效拼装字符串的几种方法比较与测试代码
Apr 15 Javascript
JS正则表达式大全(整理详细且实用)
Nov 14 Javascript
使用控制台破解百小度一个月只准改一次名字
Aug 13 Javascript
基于JavaScript实现动态创建表格和增加表格行数
Dec 20 Javascript
jquery日历插件datepicker用法分析
Jan 22 Javascript
JavaScript函数节流的两种写法
Apr 07 Javascript
Angular 如何使用第三方库的方法
Apr 18 Javascript
vue 本地环境跨域请求proxyTable的方法
Sep 19 Javascript
Vue 样式绑定的实现方法
Jan 15 Javascript
vue点击自增和求和的实例代码
Nov 06 Javascript
基于vue3.0.1beta搭建仿京东的电商H5项目
May 06 Javascript
正则表达式基础与常用验证表达式
Jun 16 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
关于php mvc开发模式的感想
2011/06/28 PHP
php实现在限定区域里自动调整字体大小的类实例
2015/04/02 PHP
PHP实现将textarea的值根据回车换行拆分至数组
2015/06/10 PHP
PHP实现HTTP断点续传的方法
2015/06/17 PHP
PHP常见过waf webshell以及最简单的检测方法
2019/05/21 PHP
laravel dingo API返回自定义错误信息的实例
2019/09/29 PHP
jQuery改变form表单的action,并进行提交的实现代码
2016/05/25 Javascript
浅谈js的html元素的父节点,子节点
2016/08/06 Javascript
js设置和获取自定义属性的方法
2016/10/20 Javascript
在网页中插入百度地图的步骤详解
2016/12/02 Javascript
关于 jQuery Easyui异步加载tree的问题解析
2016/12/06 Javascript
javascript中UMD规范的代码推演
2018/08/29 Javascript
react+ant design实现Table的增、删、改的示例代码
2018/12/27 Javascript
ES6入门教程之let、const的使用方法
2019/04/13 Javascript
vue 使用鼠标滚动加载数据的例子
2019/10/31 Javascript
koa中间件核心(koa-compose)源码解读分析
2020/06/15 Javascript
[57:37]EG vs Mineski 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
Python常用模块用法分析
2014/09/08 Python
python用来获得图片exif信息的库实例分析
2015/03/16 Python
tensorflow实现对图片的读取的示例代码
2018/02/12 Python
Python配置虚拟环境图文步骤
2019/05/20 Python
Tensorflow训练模型越来越慢的2种解决方案
2020/02/07 Python
学习python需要有编程基础吗
2020/06/02 Python
python适合做数据挖掘吗
2020/06/16 Python
如何在Python3中使用telnetlib模块连接网络设备
2020/09/21 Python
利用Pycharm + Django搭建一个简单Python Web项目的步骤
2020/10/22 Python
往来会计岗位职责
2013/12/19 职场文书
小学毕业感言500字
2014/02/28 职场文书
班主任评语大全
2014/04/26 职场文书
团日活动总结书
2014/05/08 职场文书
品质口号大全
2014/06/17 职场文书
民族团结好少年事迹材料
2014/08/19 职场文书
2014年防汛工作总结
2014/12/08 职场文书
Python的flask接收前台的ajax的post数据和get数据的方法
2021/04/12 Python
详解PHP设计模式之依赖注入模式
2021/05/25 PHP
SpringBoot生成License的实现示例
2021/06/16 Java/Android