项目页面需要一个简单的文本编辑器,网上的那些富文本编辑器功能都很强大,很多东西用不到,所以自己用js写了一个简单的文本编辑器。
代码如下:
- >
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=gbk">
- <title>简单文本编辑器title>
- head>
- <body>
- <div
- style="width: 450px; height: 30px; border-top: 1px solid; border-left: 1px solid; border-right: 1px solid;">
- <select onchange=document.execCommand('FontSize',false,this.value)>
- <option value=3>3号字option>
- <option value=4>4号字option>
- <option value=5>5号字option>
- <option value=6>6号字option>
- <option value=7>7号字option>
- select> <input type=button value="红色" onclick=document.execCommand('ForeColor',false,'#ff0000')>
- <input type=button value="绿色" onclick=document.execCommand('ForeColor',false,'#00ff00')>
- <input type=button value="蓝色" onclick=document.execCommand('ForeColor',false,'#0000ff')>
- <input type=button value="左对齐"
- onclick="document.execCommand('JustifyLeft')"> <input
- type=button value="居中" onclick=document.execCommand('JustifyCenter')>
- <input type=button value="右对齐" onclick=document.execCommand('JustifyRight')>
- div>
- <div id="editArea" contenteditable style="height: 200px; width: 450px; border: 1px solid; overflow-y: auto;">
- div>
- <div align="center" style="width: 450px;">
- <input type="button" value="↓" onclick='htmlsource.value=editArea.innerHTML;'>
- <input type="button" value="↑" onclick='editArea.innerHTML=htmlsource.value;'>
- div>
- <div>
- <textarea id="htmlsource" name="htmlsource" cols="62" rows="10">textarea>
- div>
- body>
- html>
实现原理:
1.将id为editArea的div元素添加contenteditable,这个div则拥有了编辑的功能,document执行的execCommand函数就能针对这个div中选中的区域进行相应的操作。
2.至于document的execCommand函数怎么用的,网上有很多解释,我就不重复说了。
效果图如下所示:(在chrome和IE8下显示的html源码有点不同,换行回车,chrome用
表示的,而IE8则用
表示的)
chrome:
IE8:
行业门户()文章,希望大家可以留言建议
阅读(703) | 评论(0) | 转发(0) |