最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

基于JQuery制作可编辑的表格特效_jquery

来源:动视网 责编:小采 时间:2020-11-27 21:30:47
文档

基于JQuery制作可编辑的表格特效_jquery

基于JQuery制作可编辑的表格特效_jquery:最近做了个项目,其中项目要求:点击表格后可直接编辑,回车或鼠标点击页面其他地方后编辑生效,按Esc可取消编辑 2个小伙伴给出了2中解决方案,大家来看看哪种更合适呢? 第一种单击表格可以编辑的方法 代码如下: //相当于在页面中的 body标签加上onloa
推荐度:
导读基于JQuery制作可编辑的表格特效_jquery:最近做了个项目,其中项目要求:点击表格后可直接编辑,回车或鼠标点击页面其他地方后编辑生效,按Esc可取消编辑 2个小伙伴给出了2中解决方案,大家来看看哪种更合适呢? 第一种单击表格可以编辑的方法 代码如下: //相当于在页面中的 body标签加上onloa


最近做了个项目,其中项目要求:点击表格后可直接编辑,回车或鼠标点击页面其他地方后编辑生效,按Esc可取消编辑

2个小伙伴给出了2中解决方案,大家来看看哪种更合适呢?

第一种单击表格可以编辑的方法

代码如下:
//相当于在页面中的 body标签加上onload事件
$(function() {
//找到所有的td节点
var tds = $("td");
//给所有的td添加点击事件
tds.click(function() {
//获得当前点击的对象
var td = $(this);
//取出当前td的文本内容保存起来
var oldText = td.text();
//建立一个文本框,设置文本框的值为保存的值
var input = $("");
//将当前td对象内容设置为input
td.html(input);
//设置文本框的点击事件失效
input.click(function() {
return false;
});
//设置文本框的样式
input.css("border-width", "0");
input.css("font-size", "16px");
input.css("text-align", "center");
//设置文本框宽度等于td的宽度
input.width(td.width());
//当文本框得到焦点时触发全选事件
input.trigger("focus").trigger("select");
//当文本框失去焦点时重新变为文本
input.blur(function() {
var input_blur = $(this);
//保存当前文本框的内容
var newText = input_blur.val();
td.html(newText);
});
//响应键盘事件
input.keyup(function(event) {
// 获取键值
var keyEvent = event || window.event;
var key = keyEvent.keyCode;
//获得当前对象
var input_blur = $(this);
switch (key)
{
case 13://按下回车键,保存当前文本框的内容
var newText = input_blur.val();
td.html(newText);
break;
case 27://按下 esc键,取消修改,把文本框变成文本
td.html(oldText);
break;
}
});
});
});

第二种单击表格可以编辑的方法

代码如下:
$(document).ready(function(){
var tds = $("td");
tds.click(tdClick);
});
function tdClick(){
var tdnode = $(this);
var tdtext = tdnode.text();
tdnode.html("");
var input = $("");
input.val(tdtext); // input.attr("value",tdtext);
input.keyup(function(event){
var myEvent = event || window.event;
var keyCode = myEvent.keyCode;
if(keyCode == 13){
var inputnode = $(this);
var inputtext = inputnode.val();
var td = inputnode.parent();
td.html(inputtext);
td.click(tdClick);
}
if(keyCode == 27){ //判断是否按下ESC键
$(this).parent().html(tdtext);
$(this).parent().click(tdClick);
}
});
tdnode.append(input);
tdnode.children("input").trigger("select");
//输入框失去焦点,所执行的方法
input.blur(function(){
tdnode.html($(this).val());
tdnode.click(tdClick);
});
tdnode.unbind("click");
}

想比较来说,个人更喜欢第二种一些,小伙伴们是什么意见呢,欢迎留言给我。

文档

基于JQuery制作可编辑的表格特效_jquery

基于JQuery制作可编辑的表格特效_jquery:最近做了个项目,其中项目要求:点击表格后可直接编辑,回车或鼠标点击页面其他地方后编辑生效,按Esc可取消编辑 2个小伙伴给出了2中解决方案,大家来看看哪种更合适呢? 第一种单击表格可以编辑的方法 代码如下: //相当于在页面中的 body标签加上onloa
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top