设为首页收藏本站订阅更新

无忧脚本

 找回密码
 加入无忧

QQ登录

只需一步,快速开始

搜索
查看: 51268|回复: 95

这几天人气不行,发一个以前的文章—— HTML在线编辑器的调用方法

[复制链接]
发表于 2003-3-30 23:29:16 | 显示全部楼层 |阅读模式
HTML在线编辑器不需要懂得使用Dreamweaver,会用Word就会使用此编辑器,在文章系统或者是新闻系统需要文字编辑的web程序中非常实用。
但是如何将html编辑器嵌入到web页中和怎么取得里面的数据呢?!
首先我们假定我们所要调用得HTML在线编辑器放在一个单独得页面中,文件名是gledit.htm上传图片的前台页面:http://www.jfinfo.com/room/admin/img_upload.asp。
HTML在线编辑器有两种基本调用方法
一、使用object调用(http://www.jfinfo.com/room/admin/editor.asp):
    1、怎么在web页中嵌入html编辑器: 我们在需要嵌入得位置加入以下html代码:<object id=doc_html data="gledit.htm" width=530 height=320 type=text/x-scriptlet  VIEWASTEXT></object>
其中object标签里面得data后面接得数据就是我们所要调用得在线编辑器页得路径,id就是我们调用object得id,后面取编辑器中得数据时就要用到这个id。Width和height就是编辑器得高度和宽度了。
2、怎么取得html编辑器中的数据:所有需要提交的内容我们都是放在一个表单里面,同样利用object调用的编辑器也放在这个表单里面,同时我们可以设置一个隐藏的文本区域(<textarea name="content" style="display:none"></textarea>或<INPUT TYPE="hidden" name="content">)用以在提交的时候临时保存html在线编辑器的数据,因为在asp或者jsp,php中不能直接获取表单中的object的内容,所以我们必须借助隐藏文本区域来获取数据。我们在表单提交的同时将object里面的内容复制到隐藏的文本区域中。详细代码如下:
<script language="javascript">
function CheckForm()
{
document.form1.content.value=document.form1.doc_html.value;
}
</script>
  <form method="post" action="add_news_save.asp"  onsubmit="CheckForm()" name="form1">
    <object id=doc_html name= doc_html style="LEFT: 0px; TOP: 0px" data=" gledit.htm" width=530 height=320 type=text/x-scriptlet  VIEWASTEXT></object>
    <input type="hidden" name="content" >
</form>
这样在后台处理的页面中我们就可以直接通过取隐藏区域content的数据来获取html在线编辑器的数据。
3、怎么在文本编辑器中加入上传本机图片到html在线编辑器中:首先我们使得在点击插入图片的按钮时弹出一个上传图片的窗口,我们利用自己写的程序来实现上传本机图片到服务器上,然后我们需要记录图片的路径,然后通过html在线编辑器的值中加入显示图片的html标签。详细说明及代码如下:
在编辑器中我们在插入图片的按钮上加入事件onclick="window.open('img_upload.asp','img_upload','width=481 height=190')">在'img_upload.asp'中我们将提交的图片上传到服务器制定目录然后记录图片路径
<script language=javascript>
var src='<%="upload/"&newname%>';
  opener.form1. doc_html.value +="<img border=0 src="+src+">";
window.close();
</script>
这样就实现了简单的将上传的图片插入到编辑器中。
4、怎么在编辑修改文章的时候调用HTML在线编辑器来修改数据:当我们把在添加的时候将HTML在线编辑器来修改数据提交到数据库后我们还需要能将数据库的内容用HTML在线编辑器来修改数据。首先我们在表单中加入一个隐藏区域来放置数据库中的内容,例如<TEXTAREA style="display:none" NAME="content" ROWS="20" COLS="70"><%= rs("Content")%></TEXTAREA>,要注意这里我们用隐藏的textarea而不能用隐藏的input,因为数据里面可能包含了回车换行,所以如果我们使用<INPUT TYPE="hidden" name=content value="<%=(rs("Content")%>">很可能因为<%=(rs("Content")%>有换行而出现HTML错误(value=后面接的数据必须保证是在一行,否则出错)。然后按照前面介绍的方法使用object调用HTML在线编辑器,方法和代码同上,现在我们要做的其实就是提交时候的逆过程,我们只要将隐藏文本区域的内容复制到HTML在线编辑器就可以了,在这里我们在body里面加上<body onload="document.form1. doc_html.value=document.form1.content.value">,这样在页面装载完的时候就可以将数据库中的内容放入HTML在线编辑器中编辑了,提交过程和上面介绍的一样,在此就不赘述了。


二、使用iframe调用(http://qxd.5599.net/by/source/article/manage/gledit.htm )
1、 怎么在web页中嵌入:我们在需要嵌入得位置加入以下html代码:<IFRAME SRC="gledit.htm" id='content_html' style="LEFT: 0px; POSITION: absolute; TOP: 0px;z-index:0" width="100%" height="100%"></IFRAME>其中"src="后面接得数据就是我们所要调用得在线编辑器页得路径,id就是我们调用IFRAME得id,Width和height就是编辑器得高度和宽度了。
2、 怎么取得html编辑器中的数据:同样所有需要提交的内容我们都是放在一个表单里面,同时我们可以设置一个隐藏的文本区域(<textarea name="content" style="display:none"></textarea>或<INPUT TYPE="hidden" name="content">)用以在提交的时候临时保存html在线编辑器的数据,我们借助隐藏文本区域来获取数据。我们在表单提交的同时将object里面的内容复制到隐藏的文本区域中。详细代码如下:
function subchk(cmd)
{
document.form1.content.value= window.content_html.getHTML();
}
</SCRIPT>
<FORM METHOD=POST ACTION="Article_add_save.gl" name="form1" onsubmit=" subchk()">
<input type="hidden" name="content" >
<IFRAME SRC="gledit.htm" id='content_html' style="LEFT: 0px; POSITION: absolute; TOP: 0px;z-index:0" width="100%" height="100%"></IFRAME>
</FORM>
在后台处理的页面中我们就可以直接通过取隐藏区域content的数据来获取html在线编辑器的数据。
2、怎么取得html编辑器中的数据:所有需要提交的内容我们都是放在一个表单里面,同样利用object调用的编辑器也放在这个表单里面,同时我们可以设置一个隐藏的文本区域(<textarea name="content" style="display:none"></textarea>或<INPUT TYPE="hidden" name="content">)用以在提交的时候临时保存html在线编辑器的数据,因为在asp或者jsp,php中不能直接获取表单中的object的内容,所以我们必须借助隐藏文本区域来获取数据。我们在表单提交的同时将object里面的内容复制到隐藏的文本区域中。详细代码如下:
<script language="javascript">
function CheckForm()
{
document.form1.content.value=document.form1.doc_html.value;
}
</script>
  <form method="post" action="add_news_save.asp"  onsubmit="CheckForm()" name="form1">
    <object id=doc_html name= doc_html style="LEFT: 0px; TOP: 0px" data=" gledit.htm" width=530 height=320 type=text/x-scriptlet  VIEWASTEXT></object>
    <input type="hidden" name="content" >
</form>
这样在后台处理的页面中我们就可以直接通过取隐藏区域content的数据来获取html在线编辑器的数据。
3、怎么在文本编辑器中加入上传本机图片到html在线编辑器中:首先我们使得在点击插入图片的按钮时弹出一个上传图片的窗口,我们利用自己写的程序来实现上传本机图片到服务器上,然后我们需要记录图片的路径,然后通过在调用html在线编辑器的web页中写一个函数在光标的位置插入显示图片的html标签。详细说明及代码如下:
在编辑器中我们在插入图片的按钮上加入事件onclick="window.open('img_upload.asp','img_upload','width=481 height=190')">在调用编辑器的页面中我们定义好插入html代码到编辑器的函数
<script language=javascript>
function insertHtml(HtmlCode)
{
var win=window.content_html.idEditbox.document;//其中编辑区域是gledit.htm中的一个iframe,id是idEditbox
window.content_html.idEditbox.focus();//是编辑器获得焦点,防止代码插入在编辑器外地方
win.selection.createRange().pasteHTML(HtmlCode)//在光标的位置插入html代码
}
</script>
在处理上传图片的文件中,我们调用父窗口的函数插入html代码
<script language=javascript>
var src='<%=" upload/"&newname%>';
var htmlcodes;
  htmlcodes = "<img src='"+src+"' alt='<%=theForm("alt")%>' align='<%=theForm("align")%>' border='<%=theForm("border")%>' hspace='<%=theForm("hspace")%>' vspace='<%=theForm("vspace")%>'>";
  opener.insertHtml(htmlcodes)
window.close();
</script>
这样就实现了简单的将上传的图片插入到编辑器中。
4、 怎么在编辑修改文章的时候调用HTML在线编辑器来修改数据:当我们把在添加的时候将HTML在线编辑器来修改数据提交到数据库后我们还需要能将数据库的内容用HTML在线编辑器来修改数据。首先我们在表单中加入一个隐藏区域来放置数据库中的内容,例如<TEXTAREA style="display:none" NAME="content" ROWS="20" COLS="70"><%= rs("Content")%></TEXTAREA>,在这里我们在调用编辑器的页面中的body标签里面加上<BODY onload="insertHtml(document.form1.content.value)">其中inserthtml()就是我们定义好插入html代码到编辑器的函数(具体参考插入图片的代码)。这样在页面装载完的时候就可以将数据库中的内容放入HTML在线编辑器中编辑了,提交过程和上面介绍的一样,在此就不赘述了。

这里只是简单的向大家介绍了一下如何来调用html在线编辑器,具体代码并未一一列出,整理过程中,如果大家对文章中的内容有任何问题和建议请和我联系。
 楼主| 发表于 2003-3-30 23:42:49 | 显示全部楼层
第一次写技术性文章,很乱!后来也懒得整理,不过也许对部分人还有点用
介绍了一下html在线编辑器的调用方法
重点是解决了直接上传本地图片到服务器并插入到html编辑器中,以及在编辑文章的时候调用html编辑器进行编辑

当时解决图片上传到服务器的方案不是非常科学——每插入一次本地图片即上传一次到服务器,无形中给服务器产生了很多垃圾图片
后来采用插入图片同时动态产生 <input type=file>的方法,在提交的同时一次性处理所有“需要”上传的图片,且和文章一起生成指定命名的文件和图片目录
如文章是artile321.htm,则对应的图片的文件夹就在artile321.files内,删除文章的时候就可以同时删除对应的图片文件夹。
同时对于粘贴上去的图片,也可以根据*.alll.tags("img")来提取所有来自其他网站的地址,并且可以通过xmlhttp来下载到服务器上,这样就可以避免可能无法访问

对于上面介绍的关于html编辑器调用的一些改进一直没时间整理一下写出来,最近比较忙:(
有问题可以一起探讨探讨
 楼主| 发表于 2003-3-30 23:45:38 | 显示全部楼层
文章中的一个bug :

function HtmlLoad(HtmlCode)
{
var win=window.content_html.idEditbox.document.body;
win.innerHTML=HtmlCode
}
<BODY onload="HtmlLoad(document.all.CONTENT.value)">

强烈建议大家将内容装载到iframe得时候使用这个函数
否则会出现ie不兼容得问题

示例程序如下:

[ 本贴由 宝玉 于 2003-3-30 23:46 最后编辑 ]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?加入无忧

x
 楼主| 发表于 2003-3-30 23:47:23 | 显示全部楼层
还有一个例子中用到的原创编辑器

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?加入无忧

x
发表于 2003-3-30 23:47:52 | 显示全部楼层
呵呵,宝玉,这个我加到我的站时去了哦,
谢了~
:)
 楼主| 发表于 2003-3-30 23:48:52 | 显示全部楼层
呵呵,本来就是拿出来共享的:)
你要有兴趣可以好好整理一下
发表于 2003-3-31 13:28:47 | 显示全部楼层
上传图之后用这不行:
opener.top.glmain.form1.content_html.value+="<img border=0 src="+src+">"
我改用这个可以了:
<script language=javascript>
function HtmlLoad()
{
var src='<%="upload/"&newname%>';
var win=opener.window.Composition.document.body;
win.innerHTML +="<img border=0 src="+src+">";
window.close();
}
<BODY onload="HtmlLoad()">
发表于 2003-4-4 15:12:27 | 显示全部楼层

宝玉做的不错啊

我家带鱼妹妹有福了,呵呵

但是界面还是差点
你用的asp我不懂,所以无法修改

我做的php的editer,欢迎批评指点

http://e-ht.net/psher/action.php?action=NewPost&fid=1
 楼主| 发表于 2003-4-4 19:38:53 | 显示全部楼层
请问阁下是?你家带鱼偶还没吃过那,西西

不管是asp和php,最终都是js:)
你的功能很强,我的只是为了向大家演示一下上传本地图片到编辑器中
发表于 2003-4-6 21:12:17 | 显示全部楼层
宝玉,真厉害,我一直在探索这方面的问题,今天有进步了一点。
你还有这方面的东东吗。能不能在贡献点出来啊,谢谢!
 楼主| 发表于 2003-4-7 09:00:00 | 显示全部楼层
很抱歉最近一直在忙一个项目,确实没时间来研究这个,
只是后来又解决了处理垃圾图片和下载编辑器中外部网站图片的方法
但是没时间整理
有什么问题你直接问我就好了
发表于 2003-4-7 09:01:31 | 显示全部楼层
带鱼吗,就是黛玉MM啦
不是你的老相好吗?怎么,抛弃了?
 楼主| 发表于 2003-4-7 10:10:40 | 显示全部楼层
考,都什么年代了,带鱼那种类型的MM偶已经没兴趣了,嘿嘿
偶现在连花花公子都不当了 ,当程序员
发表于 2003-6-18 16:30:23 | 显示全部楼层

为什么下载不了

一点下载就跳出一个下载文件名为ViewThread的窗口,下完后一看根本不是自已要的东西
 楼主| 发表于 2003-6-23 17:32:53 | 显示全部楼层
把文件名改一下旧可以用了
发表于 2003-7-14 21:06:05 | 显示全部楼层
把下载下来的文件,加一个扩展名rar就行了
发表于 2003-7-14 21:18:15 | 显示全部楼层
暂时发现一处不是问题的问题,第一次打开编辑器,打了几个字母进去(没有回车),点用HTML编辑时没有反应
发表于 2003-7-24 08:04:00 | 显示全部楼层
国外某个论坛也有这种编辑器,但是使用的时候发现直接支持了部分HTML,这样的话,就意味着对DHTML也支持了,所以常常会出现一些不想看到的问题。不知道这个有没有同类型问题。

上次在leadbbs看到有人转贴了这个,看过演示,当时还没想到这个问题。
发表于 2003-7-30 17:35:41 | 显示全部楼层

当时还没想到这个问题

发表于 2003-8-10 01:01:44 | 显示全部楼层
记下!
您需要登录后才可以回帖 登录 | 加入无忧

本版积分规则

小黑屋|手机版|Archiver|无忧脚本 ( 苏ICP备05080427号 )|值班电话:027-62300445   鄂公网安备 42011102000433号

GMT+8, 2017-11-25 09:42 , Processed in 0.112643 second(s), 8 queries , Gzip On, Memcache On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表