JS实现双击编辑可修改
需求描述:在一段文字处双击可以进行修改,也就是双击后创建输入框,输入内容,在输入框失去焦点后将输入的内容再以文字的形式显示出来,以下是html代码:

1 <fieldset>
2 <legend>双击用户名进行编辑</legend>
3 <dl>
4 <dt>你的用户名:</dt>
5 <dd ondblclick="ShowElement(this)">诸葛亮</dd>
6 </dl>
7 </fieldset>

以下是摘录的JavaScript代码:

1 <script type="text/javascript">
2 function ShowElement(element) {
3 var oldhtml = element.innerHTML;
4 //创建新的input元素
5 var newobj = document.createElement('input');
6 //为新增元素添加类型
7 newobj.type = 'text';
8 //为新增元素添加value值
9 newobj.value = oldhtml;
10 //为新增元素添加光标离开事件
11 newobj.onblur = function() {
12 element.innerHTML = this.value == oldhtml ? oldhtml : this.value;
13 //当触发时判断新增元素值是否为空,为空则不修改,并返回原有值
14 }
15 //设置该标签的子节点为空
16 element.innerHTML = '';
17 //添加该标签的子节点,input对象
18 element.appendChild(newobj);
19 //设置选择文本的内容或设置光标位置(两个参数:start,end;start为开始位置,end为结束位置;如果开始位置和结束位置相同则就是光标位置)
20 newobj.setSelectionRange(0, oldhtml.length);
21 //设置获得光标
22 newobj.focus();
23
24 }
25 </script>

这里存在一个小问题,就是当已经双击一次的情况下,input已存在,再次双击,会出现input的内容被替换为上次双击的input的html代码。
解决方案是判断是否已存在input标签,如果存在,直接return,不做任何操作。
以下是修改后的Js代码:

1 <script type="text/javascript">
2 function ShowElement(element) {
3 var oldhtml = element.innerHTML;
4 //如果已经双击过,内容已经存在input,不做任何操作
5 if(oldhtml.indexOf('type="text"') > 0){
6 return;
7 }
8 //创建新的input元素
9 var newobj = document.createElement('input');
10 //为新增元素添加类型
11 newobj.type = 'text';
12 //为新增元素添加value值
13 newobj.value = oldhtml;
14 //为新增元素添加光标离开事件
15 newobj.onblur = function() {
16 element.innerHTML = this.value == oldhtml ? oldhtml : this.value;
17 //当触发时判断新增元素值是否为空,为空则不修改,并返回原有值
18 }
19 //设置该标签的子节点为空
20 element.innerHTML = '';
21 //添加该标签的子节点,input对象
22 element.appendChild(newobj);
23 //设置选择文本的内容或设置光标位置(两个参数:start,end;start为开始位置,end为结束位置;如果开始位置和结束位置相同则就是光标位置)
24 newobj.setSelectionRange(0, oldhtml.length);
25 //设置获得光标
26 newobj.focus();
27
28 }
29 </script>

JS实现双击编辑可修改的更多相关文章
- JS实现双击内容变为可编辑状态
在一些网站上我们经常看到交互性很强的功能.一些用户资料可以直接双击出现文本框,并在此输入新的资料即可修改,无需再按确定按钮等.. 我在网上查了很多资料,但都有一个小bug,就是当获取焦点后,光标的位置 ...
- JQUERY、AJAX双击DIV,直接修改DIV内的内容
最近在做后台功能开发的时候,用到对排序字段的修改,感觉只为了修改一个排序值,而要重新进入编辑页比较麻烦,于是自己动手写…… 最近在做后台功能开发的时候,用到对排序字段的修改,感觉只为了修改一个排序值, ...
- 如何禁用 FastAdmin 双击编辑功能?
如何禁用 FastAdmin 双击编辑功能? 新版 (1.0.0.20180513_beta)增加一个新功能,可以禁止双击编辑. 很多人还是喜欢双击选中复制,默认的双击编辑还是不怎么习惯. 可以以下文 ...
- 基于svg.js实现可编辑的图像
svg.js的git地址https://github.com/svgdotjs/svg.js 实现可以拖动,可双击编辑,可拖动改变长短,线条可旋转以及一个可点击改变大小,可更改内容的二维码. 首先引入 ...
- 零基础学习java------35---------删除一个商品案例,删除多个商品,编辑(修改商品信息),校验用户名是否已经注册(ajax)
一. 删除一个商品案例 将要操作的表格 思路图 前端代码 <%@ page language="java" contentType="text/html; cha ...
- ArcGIS学习记录—属性表的编辑与修改
原文地址: ArcGIS问题:属性表的编辑与修改 - Silent Dawn的日志 - 网易博客 http://gisman.blog.163.com/blog/static/344933882009 ...
- js实现class样式的修改、添加及删除的方法
本文实例讲述了js实现class样式的修改.添加及删除的方法.分享给大家供大家参考.具体分析如下: 比较常见的js前端功能,通过修改标签的className实现相应的功能. 具体代码如下: <t ...
- js实现双击后网页自己主动跑-------Day55
公司的界面设计环节总算是告一段落了,必需要承认的是,这段时间晚间的学习带给我非常多益处.在工作中偶尔的应用,效果出奇的好,收到领导和同事的一些小赞扬,表示非常欣慰,也长了点不少自信,尽管不理解,他们这 ...
- JS和Jquery获取和修改label的值的示例代码
abel标签在JS和Jquery中使用不能像其他标签一样用value获取它的值,下面有个不错的示例,希望大家可以学习下 来源: < JS和Jquery获取和修改label的值的示例代码 & ...
随机推荐
- 手机浏览器页面点击不跳转(Android手机部分浏览器) 浏览器双击放大网页 解决
手机端web网页项目(angluar js 1.4.6) 1,网页项目开发过程中,使用PC浏览器能正常访问,IOS设备浏览器也能正常访问,但是使用Android部分浏览器进行访问的时候,链接偶尔不跳转 ...
- 启用image-filter扩展模块
进入lnmp目录打开lnmp.conf配置文件 修改Nginx_Modules_Options=' --prefix=/usr/local/nginx --with-http_image_filter ...
- DevOps - 版本控制 - Git
配置 .gitignore 配置 .gitignore 配置文件用于配置不需要加入版本管理的文件,配置好该文件可以为我们的版本管理带来很大的便利. 有些时候,你必须把某些文件放到Git工作目录中,但又 ...
- QQ群技术:0成本创建2000人QQ群技巧
群人数,直接关系群权重;于排名,意义非凡;此法靠谱,笔者亲测. 就说这张图,这类关键词,要是没2000人群,不管你多流弊,你是做不上去滴. 于QQ群霸屏,笔者有太多的笔墨,各种排名技巧,阿力推推早前明 ...
- PHP一些常用魔术方法
魔术方法 调用方法 作用__set 有两个 ...
- redis搭建
redis 1.简介.安装 Remote Dictionary Server(Redis)是一个基于 key-value 键值对的持久化数据库存储系统.redis 和 Memcached 缓存服务很像 ...
- POJ2553 汇点个数(强连通分量
The Bottom of a Graph Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 12070 Accepted: ...
- PAT-B java实现
注意:java提交PAT时,不需要加package : 类名必须是Main. 1001 害死人不偿命的(3n+1)猜想 (15) 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值. 输出格式 ...
- 8-C++远征之继承篇-学习笔记
C++远征之继承篇 开篇介绍 整个C++远征计划: 起航->离港->封装->继承 为什么要用继承? 为什么要有继承? 如何来定义基类 <----> 派生类? 基类到派生类 ...
- Spark是什么
官方直达电梯 Spark一种基于内存的通用的实时大数据计算框架(作为MapReduce的另一个更优秀的可选的方案) 通用:Spark Core 用于离线计算,Spark SQL 用于交互式查询,Spa ...