2003-3-30 23:29
宝玉
这几天人气不行,发一个以前的文章—— HTML在线编辑器的调用方法
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
宝玉
第一次写技术性文章,很乱!后来也懒得整理,不过也许对部分人还有点用
介绍了一下html在线编辑器的调用方法
重点是解决了直接上传本地图片到服务器并插入到html编辑器中,以及在编辑文章的时候调用html编辑器进行编辑
当时解决图片上传到服务器的方案不是非常科学——每插入一次本地图片即上传一次到服务器,无形中给服务器产生了很多垃圾图片
后来采用插入图片同时动态产生 <input type=file>的方法,在提交的同时一次性处理所有“需要”上传的图片,且和文章一起生成指定命名的文件和图片目录
如文章是artile321.htm,则对应的图片的文件夹就在artile321.files内,删除文章的时候就可以同时删除对应的图片文件夹。
同时对于粘贴上去的图片,也可以根据*.alll.tags("img")来提取所有来自其他网站的地址,并且可以通过xmlhttp来下载到服务器上,这样就可以避免可能无法访问
对于上面介绍的关于html编辑器调用的一些改进一直没时间整理一下写出来,最近比较忙:(
有问题可以一起探讨探讨
2003-3-30 23:45
宝玉
文章中的一个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 最后编辑 ]
2003-3-30 23:47
宝玉
还有一个例子中用到的原创编辑器
2003-3-30 23:47
剑啸狂沙
呵呵,宝玉,这个我加到我的站时去了哦,
谢了~
:)
2003-3-30 23:48
宝玉
呵呵,本来就是拿出来共享的:)
你要有兴趣可以好好整理一下
2003-3-31 13:28
aspx
上传图之后用这不行:
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
Psher
宝玉做的不错啊
我家带鱼妹妹有福了,呵呵
但是界面还是差点
你用的asp我不懂,所以无法修改
我做的php的editer,欢迎批评指点
http://e-ht.net/psher/action.php?action=NewPost&fid=1
2003-4-4 19:38
宝玉
请问阁下是?你家带鱼偶还没吃过那,西西
不管是asp和php,最终都是js:)
你的功能很强,我的只是为了向大家演示一下上传本地图片到编辑器中
2003-4-6 21:12
bad_boy
宝玉,真厉害,我一直在探索这方面的问题,今天有进步了一点。
你还有这方面的东东吗。能不能在贡献点出来啊,谢谢!
2003-4-7 09:00
宝玉
很抱歉最近一直在忙一个项目,确实没时间来研究这个,
只是后来又解决了处理垃圾图片和下载编辑器中外部网站图片的方法
但是没时间整理
有什么问题你直接问我就好了
2003-4-7 09:01
Psher
带鱼吗,就是黛玉MM啦
不是你的老相好吗?怎么,抛弃了?
2003-4-7 10:10
宝玉
考,都什么年代了,带鱼那种类型的MM偶已经没兴趣了,嘿嘿
偶现在连花花公子都不当了 ,当程序员
2003-6-18 16:30
csouth
为什么下载不了
一点下载就跳出一个下载文件名为ViewThread的窗口,下完后一看根本不是自已要的东西
2003-6-23 17:32
宝玉
把文件名改一下旧可以用了
2003-7-14 21:06
xtadw
把下载下来的文件,加一个扩展名rar就行了
2003-7-14 21:18
xtadw
暂时发现一处不是问题的问题,第一次打开编辑器,打了几个字母进去(没有回车),点用HTML编辑时没有反应
2003-7-24 08:04
不学无术
国外某个论坛也有这种编辑器,但是使用的时候发现直接支持了部分HTML,这样的话,就意味着对DHTML也支持了,所以常常会出现一些不想看到的问题。不知道这个有没有同类型问题。
上次在leadbbs看到有人转贴了这个,看过演示,当时还没想到这个问题。
2003-7-30 17:35
earth
当时还没想到这个问题
2003-8-10 01:01
engine
记下!
2003-8-11 16:48
ahxiao
宝玉
为什么,我加上代码,浏览器没有反映?
<script>
var src='<?=$purl?>';
opener.form1.doc_html.value+="<img border=0 src="+src+">";
window.close();
</script>
弹出的窗口并没有关闭?
我看原文件,文件上传成功,$purl可以显示。
但是,就是无法添加到html编辑器中,怎么回事?
2003-9-30 18:24
engine
edit.rar (39.04 K)这个附件中的编辑器有问题!!!
当编辑器出现卷轴条(内容大于框的高度时),上面的工具栏就会消失!!!
2003-10-5 10:19
紫色真情
[quote][i]engine[/i] 于 2003-9-30 18:24 写道:
当编辑器出现卷轴条(内容大于框的高度时),上面的工具栏就会消失!!! [/quote]
我证明[b]的确是哦![/b]:(
2003-10-5 12:00
BillyChow
强~
慢慢学哦..
2003-10-12 22:26
engine
我认为!!!
现在楼主公布的两种编辑器都有一些功能上问题(BUG?),一种能插入上传的图片,但一回车(n个回车后)连工具栏都消失掉,简直不能用!别一个就只能插入在线图片,功能不实用!!!请楼主和各位高手跟进一下吧!:)
2003-11-4 06:58
jhxli
怪不得,我忙了半天,白忙了啊!
[quote][i]engine[/i] 于 2003-10-12 22:26 写道:
现在楼主公布的两种编辑器都有一些功能上问题(BUG?),一种能插入上传的图片,但一回车(n个回车后)连工具栏都消失掉,简直不能用!别一个就只能插入在线图片,功能不实用!!!请楼主和各位高手跟进一下吧!:) [/quote]
为什么我根本就不能插入进数据库呢?
2003-11-5 12:09
宝玉
[quote][i]engine[/i] 于 2003-10-12 10:26 PM 写道:
现在楼主公布的两种编辑器都有一些功能上问题(BUG?),一种能插入上传的图片,但一回车(n个回车后)连工具栏都消失掉,简直不能用!别一个就只能插入在线图片,功能不实用!!!请楼主和各位高手跟进一下吧!:) [/quote]
对于回车工具栏消失的bug可以把iframe的高度减小即可解决!
另一个编辑器也可以插入图片只是没给例子,具体实现方法文章中有提到!
2003-11-7 14:12
jumpan
宝玉兄,你说的方法不是很懂,能不能详细一些,我用的是object的调用,也会工具栏消失
2003-11-7 16:32
jumpan
试出来了
2004-3-11 14:40
undong
狗猛啊~~~~~~~~~~~~~~~~~~~~~现在的花花公子都当程序员啦~~~~~~~~~~~~~
2004-3-11 17:54
aysun
太好了好东东
2004-3-30 16:05
ggwang
先试试
2004-4-29 11:17
camalmail
谢谢各位了!
这里的资料太好了,好优秀的文章!
2004-5-19 09:57
abbish
是不是直接读取content变量的数据就是编辑器内的数据呢?
我的输出怎么是undefined
2004-8-17 14:04
MythologyAge
帮我看看
我这个文件不知道什么地方错误,在外层网页调用gethtml时会出错:没有访问权限,搞不懂,望高手帮忙看看
<HEAD>
<META http-equiv="Content-Type" content="text/html;Charset=GB2312">
<SCRIPT>
var L_DEFAULTHTML_TEXT="<DIV></DIV>";
function _CFont(szDef,szText,bSymbol){
return new Array(szDef,szText,bSymbol);
};
defaultFonts=new Array();
defaultFonts[0]=_CFont("Geneva,Arial,Sans-serif","Arial",false);
defaultFonts[1]=_CFont("Arial Black,Geneva,Arial,Sans-serif","Arial Black",false);
defaultFonts[2]=_CFont("Courier New,Courier,Monospace","Courier New",false);
defaultFonts[3]=_CFont("Times New Roman,Times,Serif","Times New Roman",false);
defaultFonts[4]=_CFont("Verdana,Geneva,Arial,Sans-serif","Verdana",false);
defaultFonts[5]=_CFont("Lucida Handwriting,Cursive","Lucida Handwriting",false);
defaultFonts[6]=_CFont("Garamond,Times,Serif","Garamond",false);
defaultFonts[7]=_CFont("Webdings","Webdings",true);
defaultFonts[8]=_CFont("Wingdings","Wingdings",true);
defaultFonts[9]=_CFont("宋体","宋体",false);
defaultFonts[10]=_CFont("黑体","黑体",false);
defaultFonts[11]=_CFont("细明体","细明体",false);
var L_TOOLBARGIF_TEXT="gledit.gif";
var aSizes=new Array(25,25,25,8,25,25,8,25,25,25,8,52,52,52,8,25,25,25,8,25,25,25,8,25,25,25,25,8,25);
var isIE4=(navigator.appVersion.indexOf("MSIE 4")>0)
function setHTML(szHTML)
{
szHTML=convHTML(szHTML)
if(szHTML=="")szHTML=L_DEFAULTHTML_TEXT
if(g_state.bMode)
idEditbox.document.body.innerHTML=szHTML
else
idEditbox.document.body.innerText=szHTML
if(g_state.bLoaded)setSelection(true)
}
function getHTML()
{
var szRet=(g_state.bMode?_CUtil_TrimCR(_CUtil_CleanHTML()):_CUtil_TrimCR(idEditbox.document.body.innerText));
return szRet;
};
function getText(){
var szRet=""
if(g_state.bMode)
szRet=idEditbox.document.body.innerText
else{
setMode(true)
szRet=idEditbox.document.body.innerText
setMode(false)
}
return szRet
}
function getBody()
{
var oRet=idEditbox.document.body
return oRet
}
function getWidth()
{
var nRet=document.body.offsetWidth
return nRet
}
function getHeight()
{
var nRet=document.body.offsetHeight
return nRet
}
function insertHTML(szHTML)
{
var sType
var sel=g_state.GetSelection()
sType=sel.type
if(g_state.bMode){
if(sType=="Control")
sel.item(0).outerHTML=szHTML
else
sel.pasteHTML(szHTML)
}
else
sel.text=szHTML
g_state.selection=null
}
function appendHTML(szHTML){
if(g_state.bMode)
idEditbox.document.body.insertAdjacentHTML("beforeEnd",szHTML)
else
idEditbox.document.body.insertAdjacentText("beforeEnd",szHTML)
}
function setBGColor(szValue)
{
g_state.bgColor=szValue
//idEditbox.document.body.bgColor=g_state.bgColor
}
function setSelection(bDir){
var tr=idEditbox.document.body.createTextRange()
tr.collapse(bDir)
tr.select()
g_state.SaveSelection()
}
function setDefaultStyle(szValue)
{
g_state.css=szValue
if(g_state.bMode)
idEditbox.document.body.style.cssText=g_state.css
}
function setSkin(szSkin)
{
if(szSkin==null)
document.styleSheets.skin.cssText=g_state.defaultSkin
else
document.styleSheets.skin.cssText=szSkin
document.styleSheets.skin.disabled=false
}
function setToolbar(id,g_state)
{
var el=document.all[id]
if(el)
el.style.display=(g_state)?"":"none"
if(id=="tbmode"){
_setSize()
}
}
function setMode(bMode)
{
if(bMode!=g_state.bMode){
g_state.bMode=bMode
var objBody=idEditbox.document.body
if(!bMode&&!g_state.bMode)
{
objBody.bgColor=objBody.style.cssText="#FFFFFF"
if(g_state.customButtons)
idStandardBar.style.display="none"
else
idToolbar.style.display="none"
objBody.innerText=idEditbox.document.body.innerHTML
objBody.className="textMode"
}
if((bMode)&&(g_state.bMode))
{
setDefaultStyle(g_state.css)
setBGColor(g_state.bgColor)
objBody.className=idStandardBar.style.display=idToolbar.style.display=""
objBody.innerHTML=idEditbox.document.body.innerText
}
_setSize()
setSelection(true)
}
return bMode
}
function _Format(szHow,szValue){
var oSel=g_state.GetSelection()
var sType=oSel.type
var oTarget=(sType=="None"?idEditbox.document:oSel)
var oBlock=(oSel.parentElement!=null?_CUtil_GetBlock(oSel.parentElement()):oSel.item(0))
switch(szHow)
{
case "Justify":
if(oBlock)
{
oBlock.style.textAlign=""
if(((oBlock.tagName=="TABLE")||(oBlock.tagName=="IMG"))&&(("left"==oBlock.align)&&("Left"==szValue))){
oBlock.align=""
break;
}
oBlock.align=szValue
if((oBlock.tagName=="HR")||((oBlock.tagName=="IMG")&&szValue!="Center"))break;
}
szHow=szHow+szValue
szValue=""
default:
oTarget.execCommand(szHow,false,szValue)
break
}
g_state.RestoreSelection()
return true
}
function _pageReady()
{
idEditbox.document.body.onblur=idEditbox.onblur=g_state.SaveSelection
idEditbox.document.onkeydown=_Editor_KeyDownHandler
idEditbox.document.onmousedown=_Editor_ClickHandler
idEditbox.document.ondblclick=_Editor_DblClickHandler
idEditbox.document.body.oncontextmenu=new Function("return false")
if(g_state.szSearch!="")idPopup.document.domain=idEditbox.document.domain=document.domain=g_state.szSearch
else{
g_state.szSearch=_CUtil_DomainSuffix(location.hostname)
if(g_state.szSearch!="")idPopup.document.domain=idEditbox.document.domain=document.domain=parent.document.domain=g_state.szSearch
}
if(document.styleSheets.skin.disabled)setSkin(null)
_setSize()
idEditor.style.visibility=""
g_state.bLoaded=true
// var tr=idEditbox.document.body.createTextRange()
// tr.select()
// g_state.SaveSelection()
// setSelection(false)
setBGColor(g_state.bgColor)
}
function _initEditor(){
g_state=new _CState()
window.onresize=_setSize
var sz=""
sz+="<STYLE>A{text-decoration:none}\nTD{font-size:14.9px}\n.textMode{border-top: 1px black solid;font-size:14.9px}\n.NOBORDER TD{border:1px gray solid}BODY{border:1px black solid;border-top:none;font-size:14.9px}</STYLE><BODY ONCONTEXTMENU=\"return false\">"+L_DEFAULTHTML_TEXT+"</BODY>"
_CPopup_Init()
idEditbox.document.designMode="on"
idEditbox.document.open("text/html","replace")
idEditbox.document.write(sz)
idEditbox.document.close()
setTimeout("_pageReady()",100)
}
function _Editor_ClickHandler(){
g_state.selection=null
}
function _Editor_KeyDownHandler(){
/*var ev=this.parent.event
if((ev.keyCode==78||ev.keyCode==72)&&ev.ctrlKey){
if(ev.keyCode==78)
window.open(parent.location)
ev.keyCode=0;ev.returnValue=false
}
if(ev.keyCode==9)
g_state.SaveSelection()
else
g_state.selection=null*/
}
function _Editor_DblClickHandler(){
var el=this.parentWindow.event.srcElement
if(el.tagName=="IMG"){
el.removeAttribute("width")
el.removeAttribute("height")
el.style.removeAttribute("width")
el.style.removeAttribute("height")
el.width=el.width
el.height=el.height
}
if(el.tagName=="TABLE")
_CPopup_Show('Table')
}
function _setSize(){
document.all.idEditbox.style.pixelHeight=document.body.clientHeight - idToolbar.offsetHeight - document.all.idMode.offsetHeight
//document.all.idPopup.style.pixelLeft=(document.body.clientWidth - idPopup.document.all.puRegion.offsetWidth)/ 2
}
function _drawToolbar()
{
var aIds=new Array("cut","copy","paste","bar1","undo","redo","bar2","link","table","image","bar3","formatblock","fontstyle","fontsize","bar4","bold","italic","underline","bar5","left","center","right","bar6","orderedlist","unorderedlist","outdent","indent","bar7","textcolor")
var aTips=new Array("剪切","复制","粘贴","","撤销","恢复","","超链接","插入表格","插入图片","","字体格式","字体","字体尺寸","","加粗","斜体","下划线","","左对齐","居中","右对齐","","编号","项目符号","减少缩进","增加缩进","","字体颜色")
var aCommand=new Array("_Format('cut')","_Format('copy')","_Format('paste')",null,"_Format('undo')","_Format('redo')",null,"_CPopup_Show('Link')","_CPopup_Show('Table')","_CPopup_Show('Image')",null,"_CPopup_Show('formatblock')","_CPopup_Show('font')","_CPopup_Show('fontsize')",null,"_Format('bold')","_Format('italic')","_Format('underline')",null,"_Format('Justify','Left')","_Format('Justify','Center')","_Format('Justify','Right')",null,"_Format('insertorderedlist')","_Format('insertunorderedlist')","_Format('outdent')","_Format('indent')",null,"_CPopup_Show('ForeColor')")
var sz="<DIV ID=idStandardBar><NOBR>",iLeft=0,iHeight=24
for(var i=0 ;i<aSizes.length;i++)
{
sz+="<SPAN CLASS=tbButton ONKEYPRESS=\"if(event.keyCode==13){"+aCommand[i]+";event.keyCode=0}\" ID=\"tb"+aIds[i]+"\" STYLE=\"width:"+aSizes[i]+";height:"+iHeight+"\">" +"<SPAN STYLE=\"position:absolute;width:"+aSizes[i]+";height:"+iHeight+";clip:rect(0 "+aSizes[i]+" "+iHeight+" 0)\"><IMG ALT=\""+aTips[i]+"\" TITLE=\""+aTips[i]+"\" ONCLICK=\""+aCommand[i]+";event.cancelBubble=true\" ONMOUSEDOWN=\"if(event.button==1)this.style.pixelTop=-"+(iHeight*2)+"\" ONMOUSEOVER=\"this.style.pixelTop=-"+iHeight+"\" ONMOUSEOUT=\"this.style.pixelTop=0\" ONMOUSEUP=\"this.style.pixelTop=-"+iHeight+"\" SRC=\""+L_TOOLBARGIF_TEXT+"\" STYLE=\"position:absolute;top:0;left:-"+iLeft+"\"></SPAN></SPAN>" +(aTips[i]==""?"</NOBR><NOBR>":"")
iLeft+=aSizes[i]
}
sz+="</NOBR>"
document.write(sz+"</DIV>")
}
function _drawModeSelect(){
var sz="<TABLE CELLSPACING=0 CELLPADDING=0 ID=idMode></TABLE>"
document.write(sz)
}
function _CState()
{
this.selection=null
this.bMode=true
this.customButtons=false
this.css=this.bgColor="#FFFFFF"
this.defaultSkin=document.styleSheets.skin.cssText
this.popupSkin=document.styleSheets.popupSkin.cssText
this.szSearch=location.search.substring(1)
this.aBindings=new Array()
this.aListPopups=new Object()
this.aCache=new Object()
this.bLoaded=false
this.oPhoto=null
this.RestoreSelection=_CState_RestoreSelection
this.GetSelection=_CState_GetSelection
this.SaveSelection=_CState_SaveSelection
}
function _CState_RestoreSelection()
{
if(this.selection)this.selection.select()
}
function _CState_GetSelection()
{
var oSel=this.selection
if(!oSel){
oSel=idEditbox.document.selection.createRange()
oSel.type=idEditbox.document.selection.type
}
return oSel
}
function _CState_SaveSelection()
{
/*g_state.selection=idEditbox.document.selection.createRange()
if(!g_state.selection)
g_state.selection=new Object
g_state.selection.type=idEditbox.document.selection.type*/
}
function _CPopup_Init()
{
var sz="<HTML ID=popup><STYLE>" +document.styleSheets.defPopupSkin.cssText +"\n" +document.styleSheets.popupSkin.cssText +"</STYLE><BODY ONCONTEXTMENU=\"return false\" ONSCROLL=\"return false\" SCROLL=no TABINDEX=-1 ONSELECTSTART=\"return event.srcElement.tagName=='INPUT'\" ><DIV ID=puRegion><TABLE ID=header><TR><TH NOWRAP ID=caption></TH><TH VALIGN=middle ALIGN=RIGHT><DIV ID=close ONCLICK=\"parent._CPopup_Hide()\">×</DIV></TH></TR></TABLE><DIV ALIGN=CENTER ID=content></DIV></DIV></BODY></HTML>"
idPopup.document.open("text/html","replace")
idPopup.document.write(sz)
idPopup.document.close()
}
function _CPopup_Hide()
{
document.all.idPopup.style.zIndex=-1
document.all.idPopup.style.visibility="hidden"
//idPopup.document._type=""
//idPopup.document.onkeydown=idPopup.document.onmouseover=idPopup.document.onclick=null
}
function _CPopup_Show(szType)
{
var oRenderer,szCacheKey="PopupRenderer."+szType
if(!isIE4)
g_state.SaveSelection()
if(idPopup.document._type==szType)
_CPopup_Hide()
else
{
document.all.idPopup.style.zIndex=-1
oRenderer=g_state.aCache[szCacheKey]
if((!oRenderer)||("Link"==szType)||("Image"==szType))
g_state.aCache[szCacheKey]=oRenderer=new _CPopupRenderer(szType)
document.all.idPopup.style.visibility=""
document.all.idPopup.style.pixelHeight=document.all.idPopup.style.pixelWidth=idPopup.document.all.puRegion.style.pixelHeight=idPopup.document.all.puRegion.style.pixelWidth=50
idPopup.document._type=szType
idPopup.document._renderer=oRenderer
idPopup.document.all.caption.innerText=oRenderer.GetCaption()
idPopup.document.all.content.innerHTML=oRenderer.GetHTML()
idPopup.document.onkeydown=new Function("this._renderer.OnKeyDown()")
idPopup.document.onmouseover=new Function("this._renderer.OnMouseOver()")
idPopup.document.onclick=new Function("this._renderer.OnClick()")
oRenderer.ResetContext(idPopup.document)
setTimeout("_CPopupRenderer_Display('"+szType+"')",100)
}
}
function _CPopupRenderer_Display(szType){
var oRenderer,szCacheKey="PopupRenderer."+szType
oRenderer=g_state.aCache[szCacheKey]
if(oRenderer.autoSize){
idPopup.document.all.puRegion.style.pixelHeight=document.all.idPopup.style.pixelHeight=idPopup.document.all.puRegion.offsetHeight
idPopup.document.all.puRegion.style.pixelWidth=document.all.idPopup.style.pixelWidth=idPopup.document.all.puRegion.offsetWidth+50
document.all.idPopup.style.pixelLeft=(document.body.clientWidth - idPopup.document.all.puRegion.offsetWidth)/ 2
}
else{
idPopup.document.all.puRegion.style.pixelHeight=document.all.idPopup.style.pixelHeight=document.body.clientHeight - idToolbar.offsetHeight- document.all.idMode.offsetHeight-20
idPopup.document.all.puRegion.style.pixelWidth=document.all.idPopup.style.pixelWidth=document.body.clientWidth - 50
document.all.idPopup.style.pixelLeft=25
}
document.all.idPopup.style.zIndex=2
idPopup.focus()
}
function _CPopupRenderer(szType)
{
this.szType=szType
this.elCurrent=this.oDocument=null
this.ResetContext=_CPopupRenderer_ResetContext
this.GetCaption=_CPopupRenderer_GetCaption
this.GetHTML=_CPopupRenderer_GetHTML
this.autoSize=true
this.OnMouseOver=new Function()
this.OnKeyDown=_CListPopupRenderer_GenericOnKeyDown
switch(szType)
{
case "formatblock":
case "font":
case "fontsize":
this.OnMouseOver= _CListPopupRenderer_OnMouseOver
this.OnKeyDown=_CListPopupRenderer_OnKeyDown
case "ForeColor":
this.OnClick=_CListPopupRenderer_OnClick
this.Highlight=_CListPopupRenderer_Highlight
this.Select=_CListPopupRenderer_Select
break
default:
this.OnClick=new Function()
break
}
switch(szType)
{
case "formatblock":
this.szCaption="选择当前字体格式"
this.PrepareHTML=_CFormatBlockPopupRenderer_PrepareHTML
this.szHTML=this.PrepareHTML()
break
case "font":
this.szCaption="选择当前字体"
this.PrepareHTML=_CFontFacesPopupRenderer_PrepareHTML
this.szHTML=this.PrepareHTML()
break
case "fontsize":
this.szCaption="选择当前字体尺寸"
this.PrepareHTML =_CFontSizesPopupRenderer_PrepareHTML
this.szHTML=this.PrepareHTML()
break
case "Link":
this.szCaption="创建、修改链接"
this.PrepareHTML=_CLinkPopupRenderer_PrepareHTML
this.szHTML=this.PrepareHTML()
break
case "Image":
this.szCaption="创建、修改图片"
this.PrepareHTML=_CImagePopupRenderer_PrepareHTML
this.szHTML=this.PrepareHTML()
break
case "Table":
this.szCaption="创建、修改表格"
this.PrepareHTML=_CTablePopupRenderer_PrepareHTML
this.szHTML=this.PrepareHTML()
break
case "ForeColor":
this.szCaption="选择当前字体颜色"
this.szHTML="<DIV ID=ColorPopup ALIGN=CENTER>"+_CUtil_BuildColorTable("")+"</DIV>"
break
default:
this.szCaption=""
break
}
}
function _CPopupRenderer_ResetContext(oDoc)
{
this.oDocument=oDoc
this.elCurrent=null
if(this.szType=="Table"){
var oSel=idEditbox.document.selection.createRange()
var oBlock=(oSel.parentElement!=null?_CUtil_GetElement(oSel.parentElement(),"TABLE"):_CUtil_GetElement(oSel.item(0),"TABLE"))
if(oBlock!=null){
oDoc.all.tabEdit.className=""
oDoc.all.tabEditBodytxtPadding.value=oBlock.cellPadding
oDoc.all.tabEditBodytxtSpacing.value=oBlock.cellSpacing
oDoc.all.tabEditBodytxtBorder.value=oBlock.border
oDoc.all.tabEditBodytxtBorderColor.value=oBlock.borderColor
oDoc.all.tabEditBodytxtBackgroundImage.value=oBlock.background
oDoc.all.tabEditBodytxtBackgroundColor.value=oBlock.bgColor
}
oDoc.elCurrent=oBlock
}
}
function _CPopupRenderer_GetCaption()
{
return this.szCaption
}
function _CPopupRenderer_GetHTML()
{
return this.szHTML
}
function _CFontSizesPopupRenderer_PrepareHTML()
{
var sz="<TABLE ALIGN=center ID=idList CELLSPACING=0 CELLPADDING=0>"
for(var i=1;i <= 7;i++)
{
sz+="<TR><TD NOWRAP _item="+i+" ALIGN=center STYLE=\"margin:0pt;padding:0pt\"><FONT SIZE="+i+">" +"Font("+i+")</FONT></TD></TR>"
}
sz+="</TABLE>"
return sz
}
function _CFontFacesPopupRenderer_PrepareHTML()
{
var sz="<TABLE ALIGN=center ID=idList CELLSPACING=0 CELLPADDING=0>"
for(var i=0;i<defaultFonts.length;i++)
{
if(i%2==0)sz+="<TR>"
sz+="<TD NOWRAP _item="+i+" ALIGN=center STYLE=\"margin:0pt;padding:0pt\"><FONT FACE=\""+defaultFonts[i][0]+"\">" +defaultFonts[i][1] +"</FONT>"+(defaultFonts[i][2]?("("+defaultFonts[i][1]+")"):"")+"</TD>"
if(i%2)sz+="</TR>"
}
if(i%2)sz+="</TR>"
sz+="<TR><TD ROWSPAN=2 ONCLICK=\"parent._CFontFacesPopupRenderer_InsertOther(this)\" ALIGN=center _item=\"custom\" STYLE=\"margin:0pt;padding:0pt\" NOWRAP ID=customFont>其他字体...</TD></TR>"
sz+="</TABLE>"
return sz
}
function _CFontFacesPopupRenderer_InsertOther(){
var szFont=prompt("请输入您指定的字体名称: ","宋体")
if((szFont!=null)&&(szFont!=""))
_Format("FontName",szFont)
_CPopup_Hide()
}
2004-8-17 14:06
MythologyAge
帮我看看
分批上传:
function _CFormatBlockPopupRenderer_PrepareHTML()
{
var sz,defaultParagraphs=new Array()
defaultParagraphs[0]=new Array("<P>","普通")
for(var i=1;i <= 6;i++)
defaultParagraphs[i]=new Array("<H"+i+">","标题"+i+"(H"+i+")")
defaultParagraphs[7]=new Array("<PRE>","格式化文本(PRE)")
sz="<TABLE CLASS=block ALIGN=center ID=idList CELLSPACING=0 CELLPADDING=0>"
for(var i=0;i<defaultParagraphs.length;i++)
{
sz+="<TR><TD NOWRAP _item="+i+" ALIGN=center STYLE=\"margin:0pt;padding:0pt\">"+defaultParagraphs[i][0] +defaultParagraphs[i][1] +"</"+defaultParagraphs[i][0].substring(1)+"</TD></TR>"
}
sz+="</TABLE>"
return sz
}
function _CTablePopupRenderer_PrepareHTMLPage(szID,bDisplay){
var sz="<TABLE height=100% "+((!bDisplay)?" style=\"display:none\"":"")+" width=100% CELLSPACING=0 CELLPADDING=0 ID="+szID+"><TR ID=tableContents><TD ID=tableOptions VALIGN=TOP NOWRAP WIDTH=150 ROWSPAN=2><A HREF=\"javascript:parent._CTablePopupRenderer_Select(this,'"+szID+"','prop1')\">设定行列</A><BR><A HREF=\"javascript:parent._CTablePopupRenderer_Select(this,'"+szID+"','prop2')\">设定边框与间隔</A><BR><A HREF=\"javascript:parent._CTablePopupRenderer_Select(this,'"+szID+"','prop3')\">设定边框</A><BR><A HREF=\"javascript:parent._CTablePopupRenderer_Select(this,'"+szID+"','prop4')\">设定背景</A><BR></TD><TD BGCOLOR=black ID=puDivider ROWSPAN=2></TD><TD ID=tableProps VALIGN=TOP>"
if(szID=="tabNewBody"){
sz+= "<DIV ID='"+szID+"prop1'><P CLASS=tablePropsTitle>设定行列</P><TABLE><TR><TD>行: </TD><TD><INPUT SIZE=2 MAXLENGTH=2 TYPE=text ID="+szID+"txtRows VALUE=2 ></TD></TR><TR><TD>列: </TD><TD><INPUT SIZE=2 MAXLENGTH=2 TYPE=text ID="+szID+"txtColumns VALUE=2 ></TD></TR></TABLE></DIV>"
}
else{
sz+= "<DIV ID='"+szID+"prop1'><P CLASS=tablePropsTitle>设定行列</P>" +"<INPUT type=button ID="+szID+"txtRows VALUE=\"插入行\" ONCLICK=\"parent._CTablePopupRenderer_AddRow(this)\"><P><INPUT type=button ID="+szID+"txtCells VALUE=\"插入列\" ONCLICK=\"parent._CTablePopupRenderer_AddCell(this)\"><BR></DIV>"
}
sz+="<DIV ID='"+szID+"prop2' STYLE=\"display:none\"><P CLASS=tablePropsTitle>设定边框与间隔</P>单元格边框: <INPUT SIZE=2 TYPE=text ID="+szID+"txtPadding VALUE=1><BR>单元格间隔: <INPUT SIZE=2 TYPE=text ID="+szID+"txtSpacing VALUE=1></DIV><DIV ID="+szID+"prop3 STYLE=\"display:none\"><P CLASS=tablePropsTitle>设定边框</P>边框宽度: <INPUT SIZE=2 TYPE=text ID="+szID+"txtBorder VALUE=1><BR>边框颜色: <INPUT SIZE=4 TYPE=text ID="+szID+"txtBorderColor value=#000000><BR>" +_CUtil_BuildColorTable("idBorder"+szID,"","parent._CTablePopupRenderer_ColorSelect(this,'"+szID+"txtBorderColor')")+"</DIV><DIV ID="+szID+"prop4 SIZE=12 STYLE=\"display:none\"><P CLASS=tablePropsTitle>设定背景</P>背景图片: <INPUT TYPE=text ID="+szID+"txtBackgroundImage SIZE=15><BR>背景颜色: <INPUT TYPE=text SIZE=4 ID="+szID+"txtBackgroundColor><BR>" +_CUtil_BuildColorTable("idBackground"+szID,"","parent._CTablePopupRenderer_ColorSelect(this,'"+szID+"txtBackgroundColor')")+"</DIV></TD></TR><TR><TD align=center ID=tableButtons valign=bottom>"
if(szID=="tabNewBody"){
sz+="<INPUT TYPE=submit ONCLICK=\"parent._CTablePopupRenderer_BuildTable('"+szID+"',this.document)\" VALUE=\"创建表格\"> <INPUT TYPE=reset VALUE=\" 取 消 \" ONCLICK=\"parent._CPopup_Hide()\">"
}else{
sz+="<INPUT TYPE=submit ONCLICK=\"parent._CTablePopupRenderer_BuildTable('"+szID+"',this.document)\" VALUE=\"修改表格\"> <INPUT TYPE=reset VALUE=\" 取 消 \" ONCLICK=\"parent._CPopup_Hide()\">"
}
sz+= "</TD></TR></TABLE>"
return sz
}
function _CTablePopupRenderer_PrepareHTML()
{
var sz="<TABLE CLASS=tabBox ID=\"tabSelect\" CELLSPACING=0 CELLPADDING=0 WIDTH=95%><TR HEIGHT=15><TD CLASS=tabItem STYLE=\"border-bottom:none\" NOWRAP><DIV ONCLICK=\"if(tabEdit.className!='disabled'){this.className='selected';this.parentElement.style.borderBottom=tabEdit.className=tabNewBody.style.display='';tabEditBody.style.display='none';tabEdit.parentElement.style.borderBottom='1px black solid'}\" CLASS=selected ID=tabNew>创建表格</DIV></TD><TD CLASS=tabItem NOWRAP><DIV ONCLICK=\"if(this.className!='disabled'){this.className='selected';this.parentElement.style.borderBottom=tabNew.className=tabEditBody.style.display='';tabNew.parentElement.style.borderBottom='1px black solid';tabNewBody.style.display='none'}\" CLASS=disabled ID=tabEdit>修改表格</DIV></TD><TD CLASS=tabSpace WIDTH=100%> </TD></TR><TR><TD VALIGN=TOP CLASS=tabBody COLSPAN=3>"+_CTablePopupRenderer_PrepareHTMLPage("tabNewBody",true)+_CTablePopupRenderer_PrepareHTMLPage("tabEditBody",false)+"</TD></TR></TABLE>"
return sz
}
function _CTablePopupRenderer_Select(el,szID,id)
{
var d=el.document
for(var i=1;i<5;i++)
d.all[szID+"prop"+i].style.display="none"
d.all[szID+id].style.display=""
}
function _CTablePopupRenderer_ColorSelect(el,id)
{
el.document.all[id].value=el.bgColor
}
function _CTablePopupRenderer_AddRow(el){
var elRow=el.document.elCurrent.insertRow()
for(var i=0;i<el.document.elCurrent.rows[0].cells.length;i++){
var elCell=elRow.insertCell()
elCell.innerHTML=" "
}
}
function _CTablePopupRenderer_AddCell(el){
for(var i=0;i<el.document.elCurrent.rows.length;i++){
var elCell=el.document.elCurrent.rows[i].insertCell()
elCell.innerHTML=" "
}
}
function _CTablePopupRenderer_BuildTable(szID,d)
{
if(szID=="tabNewBody"){
var sz="<TABLE "+(((d.all[szID+"txtBorder"].value=="")||(d.all[szID+"txtBorder"].value=="0"))?"class=\"NOBORDER\"":"")+(d.all[szID+"txtPadding"].value!=""?"cellPadding=\""+d.all[szID+"txtPadding"].value+"\" ":"")+(d.all[szID+"txtSpacing"].value!=""?"cellSpacing=\""+d.all[szID+"txtSpacing"].value+"\" ":"")+(d.all[szID+"txtBorder"].value!=""?"border=\""+d.all[szID+"txtBorder"].value+"\" ":"")+(d.all[szID+"txtBorderColor"].value!=""?"bordercolor=\""+d.all[szID+"txtBorderColor"].value+"\" ":"")+(d.all[szID+"txtBackgroundImage"].value!=""?"background=\""+d.all[szID+"txtBackgroundImage"].value+"\" ":"")+(d.all[szID+"txtBackgroundColor"].value!=""?"bgColor=\""+d.all[szID+"txtBackgroundColor"].value+"\" ":"")+">"
if(d.all[szID+"txtRows"].value>99)d.all[szID+"txtRows"].value=99
if(d.all[szID+"txtColumns"].value>99)d.all[szID+"txtColumns"].value=50
for(var r=0;r<parseInt(d.all[szID+"txtRows"].value);r++)
{
sz+="<TR>"
for(var c=0;c<parseInt(d.all[szID+"txtColumns"].value);c++)
sz+="<TD> </TD>"
sz+="</TR>"
}
sz+="</TABLE>"
insertHTML(sz)
}else
if(d.elCurrent){
d.elCurrent.cellPadding=d.all.tabEditBodytxtPadding.value
d.elCurrent.cellSpacing=d.all.tabEditBodytxtSpacing.value
d.elCurrent.border=d.all.tabEditBodytxtBorder.value
d.elCurrent.className=(d.elCurrent.border==""||d.elCurrent.border==0)?"NOBORDER":""
d.elCurrent.borderColor=d.all.tabEditBodytxtBorderColor.value
d.elCurrent.bgColor=d.all.tabEditBodytxtBackgroundColor.value
d.elCurrent.background=d.all.tabEditBodytxtBackgroundImage.value
}
g_state.RestoreSelection()
_CPopup_Hide()
}
function _CListPopupRenderer_OnClick()
{
var elTD=_CUtil_GetElement(this.oDocument.parentWindow.event.srcElement,"TD")
if(elTD &&elTD._item)this.Select(elTD)
}
function _CListPopupRenderer_GenericOnKeyDown(){
var ev=this.oDocument.parentWindow.event
if(ev.keyCode==27)_CPopup_Hide()
}
function _CListPopupRenderer_OnKeyDown()
{
var el
var iRow=iCell=0
var ev=this.oDocument.parentWindow.event
var idList=this.oDocument.all.idList
var elTR=_CUtil_GetElement(this.elCurrent,"TR")
var elTD=_CUtil_GetElement(this.elCurrent,"TD")
if(elTR!=null)
{
iRow=elTR.rowIndex
iCell=elTD.cellIndex
}
switch(ev.keyCode)
{
case 37:
iCell--
if(iCell<0)
iCell=idList.rows[iRow].cells.length-1
break
case 38:
iRow--
if(iRow<0)
iRow=idList.rows.length-1
break
case 39:
iCell++
if(iCell>idList.rows[iRow].cells.length-1)
iCell=0
break
case 40:
iRow++
if(iRow>idList.rows.length-1)
iRow=0
break
case 13:
break;
case 27:
_CPopup_Hide()
break;
default:
return;
}
el=idList.rows[iRow].cells[iCell]
if(el &&el._item)
if(13==ev.keyCode){
ev.keyCode=0
this.Select(el)
}
else
this.Highlight(el)
}
function _CListPopupRenderer_OnMouseOver()
{
var el=_CUtil_GetElement(this.oDocument.parentWindow.event.srcElement,"TD")
if(el &&el._item &&el!=this.elCurrent)
this.Highlight(el)
}
function _CListPopupRenderer_Highlight(el)
{
var elC=this.elCurrent
if(elC)elC.style.borderWidth=elC.style.borderColor=elC.style.borderStyle=""
el.style.borderWidth="1px"
el.style.borderColor="green"
el.style.borderStyle="solid"
this.elCurrent=el
}
function _CListPopupRenderer_Select(elTD)
{
g_state.RestoreSelection()
var el=elTD.children[0]
switch(this.szType)
{
case "font":
if(!el)
parent._CFontFacesPopupRenderer_InsertOther(this)
else
_Format("FontName",el.face)
break
case "fontsize":
_Format("FontSize",el.size)
break
case "formatblock":
_Format("FormatBlock","<"+el.tagName+">")
break
case "ForeColor":
_Format("ForeColor",elTD.bgColor)
break
}
_CPopup_Hide()
}
function _CLinkPopupRenderer_AddLink(d)
{
var szURL=d.all.urlValue.value
var szType=d.all.urlType[d.all.urlType.selectedIndex].text
var oSel=g_state.GetSelection()
szURL=((0==szURL.indexOf("mailto:")||0==szURL.indexOf("http://")||0==szURL.indexOf("ftp://"))?"":szType)+szURL
if(szURL!="")
{
if((oSel.parentElement)&&(oSel.text==""))
{
oSel.expand("word")
if(oSel.text=="")
{
var sText=""
var oStore=oSel.duplicate()
if(d.all.pageList){
var idx=d.all.pageList.selectedIndex
if(d.all.pageList[idx].value==szURL)
sText=d.all.pageList[idx].text
else
sText=szURL
}
else
sText=szURL
oSel.pasteHTML('<A HREF="'+szURL+'">'+sText+'</A>')
oSel.setEndPoint("StartToStart",oStore)
oSel.select()
_CPopup_Hide()
return
}
}
else
if((oSel.item)&&(oSel.item(0).tagName=="IMG"))
{
oSel.item(0).width=oSel.item(0).offsetWidth
oSel.item(0).height=oSel.item(0).offsetHeight
oSel.item(0).border=(d.all.displayBorder.checked)?1:""
}
if(d.all.urlValue.value!="")
oSel.execCommand("CreateLink",false,szURL)
else
oSel.execCommand("UnLink",false,szURL)
}
oSel.select()
_CPopup_Hide()
}
function _CLinkPopupRenderer_PrepareHTML()
{
var oSel=g_state.GetSelection()
var oEl,bImg=false,szURL=sz=""
if(oSel.parentElement)
{
oEl=_CUtil_GetElement(oSel.parentElement(),"A")
}
else
{
oEl=_CUtil_GetElement(oSel.item(0),"A")
bImg=oSel.item(0).tagName=="IMG"
}
if(oEl)szURL=oEl.href
sz ="<TABLE ALIGN=center>"
var arTypes=new Array("http","ftp","mailto")
var arText=new Array("http://","ftp://","mailto:")
var szType=szURL.substring(0,szURL.indexOf(":"))
if(("http"==szType)||("ftp"==szType))
szURL=szURL.substring(szURL.indexOf("//")+2)
else
szURL=szURL.substring(szURL.indexOf(":")+1)
sz+="<BR>输入或修改一个链接地址: <NOBR><SELECT ID=urlType>"
for(var i=0;i<arTypes.length;i++){
sz+= "<OPTION VALUE='"+arTypes[i]+"' "+(arTypes[i]==szType?" SELECTED ":"")+">"+arText[i]
}
sz+="</SELECT><INPUT ID=urlValue SIZE=45 VALUE=\""+szURL+"\" TYPE=text></NOBR>"
if(bImg)
{
sz+="<BR><INPUT TYPE=checkbox ID=displayBorder "+((oSel.item(0).border!=0)?" checked ":"")+">是否显示图片链接边框?"
}
sz+="</TD></TR><TR><TD ALIGN=center><INPUT ONCLICK=\"parent._CLinkPopupRenderer_AddLink(this.document)\" TYPE=submit ID=idSave VALUE=\" "+(szURL==""?"插 入":"修 改")+" \"> <INPUT ONCLICK=\"parent._CPopup_Hide()\" TYPE=reset ID=idCancel VALUE=\" 取 消 \"></TD></TR></TABLE>"
return sz
}
function _CImagePopupRenderer_AddImage(d)
{
var szURL=d.all.urlValue.value
var szType=d.all.urlType[d.all.urlType.selectedIndex].text
var oSel=g_state.GetSelection()
var szALT=d.all.imgAlt.value
var szALIGN=d.all.imgAlign[d.all.imgAlign.selectedIndex].value
var szBORDER=d.all.imgBorder.value
var SelImg
if(!oSel.parentElement)SelImg=oSel.item(0)
szURL=((0==szURL.indexOf("http://")||0==szURL.indexOf("ftp://"))?"":szType)+szURL
if(szURL!="")
{
if(SelImg)
{
if(SelImg.src!=szURL)SelImg.src=szURL
if(SelImg.alt!=szALT)SelImg.alt=szALT
if(SelImg.align.toLowerCase()!=szALIGN)_Format("Justify",szALIGN)
if(SelImg.border!=szBORDER)SelImg.border=szBORDER
}
else
insertHTML('<IMG SRC="'+szURL+'"'+(szALT==""?"":' ALT="'+szALT+'"')+(szALIGN==""?"":' ALIGN="'+szALIGN+'"')+(szBORDER==""?"":' BORDER="'+szBORDER+'"')+'>')
oSel.select()
_CPopup_Hide()
return
}
}
function _CImagePopupRenderer_PrepareHTML()
{
var oSel=g_state.GetSelection()
var szURL=szALT=szALIGN=szBORDER=sz=""
var SelImg
if(!oSel.parentElement)
{
SelImg=oSel.item(0)
if(SelImg.tagName=="IMG")
{
szURL=SelImg.href
szALT=SelImg.alt
szALIGN=SelImg.align.toLowerCase()
szBORDER=SelImg.border
}
}
sz ="<TABLE ALIGN=center><BR>输入或修改一个图片地址: <NOBR><SELECT ID=urlType>"
var arTypes=new Array("http","ftp")
var arText=new Array("http://","ftp://")
var szType=szURL.substring(0,szURL.indexOf(":"))
if(("http"==szType)||("ftp"==szType))
szURL=szURL.substring(szURL.indexOf("//")+2)
else
szURL=szURL.substring(szURL.indexOf(":")+1)
for(var i=0;i<arTypes.length;i++){
sz+= "<OPTION VALUE='"+arTypes[i]+"' "+(arTypes[i]==szType?" SELECTED ":"")+">"+arText[i]
}
sz+="</SELECT><INPUT ID=urlValue SIZE=45 VALUE=\""+szURL+"\" TYPE=text></NOBR>"
sz+="<BR><NOBR>注释文本: <INPUT ID=imgAlt SIZE=44 VALUE=\""+szALT+"\" TYPE=text></NOBR>"
sz+="<BR><NOBR>对齐模式: <SELECT ID=imgAlign>"
var arTypes=new Array("","left","right","top","texttop","middle","absmiddle","baseline","bottom","absbottom","center")
var arText=new Array("默认","左对齐","右对齐","顶边对齐","文本上方","相对垂直居中","绝对垂直居中","基线","相对底边对齐","绝对底边对齐","水平居中")
for(var i=0;i<arTypes.length;i++){
sz+= "<OPTION VALUE='"+arTypes[i]+"' "+(arTypes[i]==szALIGN?" SELECTED ":"")+">"+arText[i]
}
sz+="</SELECT> 边框粗细: <INPUT ID=imgBorder SIZE=5 VALUE=\""+szBORDER+"\" TYPE=text></NOBR>"
sz+="</TD></TR><TR><TD ALIGN=center><INPUT ONCLICK=\"parent._CImagePopupRenderer_AddImage(this.document)\" TYPE=submit ID=idSave VALUE=\" "+(szURL==""?"插 入":"修 改")+" \"> <INPUT ONCLICK=\"parent._CPopup_Hide()\" TYPE=reset ID=idCancel VALUE=\" 取 消 \"></TD></TR></TABLE>"
return sz
}
function _CUtil_GetElement(oEl,sTag)
{
while(oEl!=null &&oEl.tagName!=sTag)
oEl=oEl.parentElement
return oEl
}
function _CUtil_BuildColorTable(sID,fmt,szClick)
{
var sz,cPick=new Array("00","33","66","99","CC","FF"),iCnt=2
var iColors=cPick.length,szColor=""
sz="<TABLE CELLSPACING=0 CELLPADDING=0><TR><TD VALIGN=middle><DIV CLASS=currentColor ID=\""+sID+"Current\"> </DIV></TD><TD><TABLE ONMOUSEOUT=\"document.all."+sID+"Current.style.backgroundColor=''\" ONMOUSEOVER=\"document.all."+sID+"Current.style.backgroundColor=event.srcElement.bgColor\" CLASS=colorTable CELLSPACING=0 CELLPADDING=0 ID=\""+sID+"\">"
for(var r=0;r<iColors;r++){
sz+="<TR>"
for(var g=iColors-1;g>=0;g--)
for(var b=iColors-1;b>=0;b--){
szColor=cPick[r]+cPick[g]+cPick[b]
sz+="<TD BGCOLOR=\"#"+szColor+"\"_item=\""+szColor+"\" TITLE=\"#"+szColor+"\" "+(szClick?"ONCLICK=\""+szClick+"\" ":"")+"> </TD>"
}
sz+="</TR>"
}
sz+="</TABLE></TD></TR></TABLE>"
return sz
}
function replace(str,replace_what,replace_with)
{
var ndx=str.indexOf(replace_what);
var delta=replace_with.length - replace_what.length;
while(ndx >= 0)
{
str=str.substring(0,ndx)+replace_with+str.substring(ndx+replace_what.length);
ndx=str.indexOf(replace_what,ndx+delta+1);
}
return str;
}
function _CUtil_TrimCR(sValue){
return replace(sValue,"\r\n"," ")
}
function _CUtil_GetBlock(oEl)
{
var sBlocks="|H1|H2|H3|H4|H5|H6|P|PRE|LI|TD|DIV|BLOCKQUOTE|DT|DD|TABLE|HR|IMG|"
while((oEl!=null)&&(sBlocks.indexOf("|"+oEl.tagName+"|")==-1))
oEl=oEl.parentElement
return oEl
}
function _CUtil_DomainSuffix(szHost){
var idx=szHost.indexOf("commun")
if(idx>=0){
idx=szHost.indexOf(".",idx)
return szHost.substring(idx+1)
}else
{
idx=szHost.lastIndexOf(".",szHost.length-5)
return szHost.substring(idx+1)
}
return szHost
}
function _CUtil_CleanHTML(){
var bBindings=(g_state.aBindings.length>0)
var elAll=idEditbox.document.all
var iCount=elAll.length
for(var i=iCount-1;i>=0;i--){
if(elAll[i].tagName=="IMG"){
elAll[i].width=elAll[i].offsetWidth
elAll[i].height=elAll[i].offsetHeight
}
if((elAll[i].tagName=="INPUT")&&(bBindings))
elAll[i].outerHTML='['+elAll[i].name+']';
}
return idEditbox.document.body.innerHTML
}
var g_state
window.onload = _initEditor
function _drawIE4Focus(){
if(isIE4)document.write("<INPUT TYPE=textbox STYLE=\"width:0;height:0;left:0;position:absolute\">")
}
</SCRIPT>
<STYLE>
body{border-style:none;border-width:medium;margin:0pt;padding:0pt}
#idMode{margin-top:0pt}
.tbButton{text-align:left;margin-left:0pt;margin-right:1pt;margin-top:0pt;margin-bottom:0pt;padding:0pt}
#EditBox{position:relative;}
</STYLE>
<STYLE id="skin" disabled>
#idEditRegion{margin-left:0px;margin-right:0px;margin-top:0px;margin-bottom:0px;padding:0px}
#tbUpRight,#tbUpLeft{width:13px}
#idMode{margin-left:11px;padding:0pt}
#idMode label{color:navy;text-decoration:none;font-size:14.9px}
</STYLE>
<STYLE id="defPopupSkin">
#popup body{border-top-style:none;border-top-width:medium;margin:0px;padding:0pt}
#popup .colorTable{height:91px}
#popup #header{width:100%}
#popup #close{cursor:default;font-size:12px;width:18px;text-align:center}
#popup #content{padding:0pt}
#popup table{vertical-align:top}
#popup .tabBody{border-left:1px solid black;border-right:1px solid black;border-top-style:none;border-top-width:medium;border-bottom:1px solid black}
#popup .tabItem,#popup .tabSpace{border-left:1px solid black;border-bottom:1px solid black}
#popup .tabItem{font-size:14.9px;border-top:1px solid black}
#popup .currentColor{width:20px;height:20px;border:1px solid black;margin-left:0pt;margin-right:15pt;margin-top:0pt;margin-bottom:0pt}
#popup .tabItem div{cursor:hand;margin:3px;padding:0px}
#popup .tabItem div.disabled{color:gray;cursor:default}
#customFont{font-size:14.9px}
</STYLE>
2004-8-17 14:06
MythologyAge
帮我看看
分批上传:
<STYLE id="popupSkin">
#popup body{background-color:#F1F1F1;border:1px solid #6699CC;background-position:0%;font-size:14.9px}
#popup #header{background-color:#6699CC;color:white;background-position:0%}
#popup #caption{text-align:left;font-size:14.9px}
#popup .ColorTable,#popup #idList td#current{border:1px solid black}
#popup #idList td{cursor:hand;border:1px solid #F1F1F1}
#popup #close{cursor:hand;color:#99CCFF;border:1px solid #99CCFF;margin-right:6px;padding-left:4px;padding-right:4px;padding-top:0px;padding-bottom:2px}
#popup #tableProps .tablePropsTitle{color:#6699CC;text-align:left;border-bottom:1px solid black;margin-left:0pt;margin-right:0pt;margin-top:0pt;margin-bottom:5pt}
#tableButtons,#tableProps{padding:5px}
#popup #tableContents{height:175px}
#popup #tableProps .tablePropsTitle,#popup #tableProps,#popup #tableProps table{font-size:14.9px}
#popup #tableOptions{font-size:14.9px;padding-left:5pt;padding-right:5pt;padding-top:15pt;padding-bottom:15pt}
#popup #puDivider{background-color:black;width:1px;background-position:0%}
#popup #content{margin:0pt;padding-left:3pt;padding-right:3pt;padding-top:5pt;padding-bottom:8pt}
#popup #ColorPopup{width:250px}
#popup .ColorTable tr{height:6px}
#popup .ColorTable td{width:6px;cursor:hand}
#popup .block p,#popup .block h1,#popup .block h2,#popup .block h3,#popup .block h4,#popup .block h5,#popup .block h6,#popup .block pre{margin:0pt;padding:0pt}
</STYLE>
</HEAD>
<BODY STYLE="background-color:transparent" oncontextmenu="return false" tabindex="-1" scroll="no" onselectstart="return false" ondragstart="return false" onscroll="return false">
<DIV id="idEditor" style="VISIBILITY:hidden">
<TABLE id="idToolbar" width="100%" cellspacing="0" cellpadding="0" onclick="_CPopup_Hide()">
<TR><TD bgColor=menu><SCRIPT>_drawToolbar()</SCRIPT></TD></TR>
<TR><TD bgColor=#000000 HEIGHT=1></TD></TR>
</TABLE>
<IFRAME NAME="idPopup" STYLE="HEIGHT:200px;LEFT:25px;MARGIN-TOP:8px;POSITION:absolute;VISIBILITY:hidden;WIDTH:200px;Z-INDEX:-1"></IFRAME>
<DIV id="idEditRegion">
<IFRAME TABINDEX=1 ID="EditBox" NAME="idEditbox" WIDTH="100%" HEIGHT="100%" MARGINHEIGHT="1" MARGINWIDTH="1" ONFOCUS="_CPopup_Hide();"></IFRAME>
</DIV>
<SCRIPT>_drawIE4Focus()</SCRIPT>
<DIV id="tbmode">
<SCRIPT>_drawModeSelect()</SCRIPT>
</DIV>
</DIV>
</BODY><SCRIPT LANGUAGE=vbscript>
function convHTML(htmlstr)
htmlstr = replace(htmlstr, """, """")
htmlstr = replace(htmlstr, "<", "<")
htmlstr = replace(htmlstr, ">", ">")
htmlstr = replace(htmlstr, "&", "&")
convHTML = htmlstr
end function
</SCRIPT>
2004-8-28 15:00
lbx972
mark
页:
[1]
2
3
Powered by Discuz! Archiver 5.5.0
© 2001-2006 Comsenz Inc.