时间:2021-05-26
下面就是我开发的过程。
首先,我的 tinyMCE版本是 Version: 3.2.7 (2009-09-22) 。
下载地址 https://.cn/js/jquery.js"></script>
<script language="javascript">
function insertcode()
{
var value = $('#postcontent').html();
var codetype = $('#codetype').val();
// window.opener.InsertHTML('<textarea rows="3" cols="50" name="code" class="'+codetype+'">'+value+'</textarea>');
window.opener.InsertHTML('<pre name="code" class="'+codetype+'">'+value+'</pre>');
window.close();
}
</script>
其次是 PHP 和 html 代码
复制代码 代码如下:
<?php
error_reporting(0);
$content = $_POST['content'];
if(!empty($content))
{
$codetype = $_POST['codetype'];
echo '<div id="postcontent">';
$content = htmlspecialchars($content);
echo $content;
echo '</div>
<input type="hidden" name="codetype" id="codetype" value="'.$codetype.'" />
<input type="button" name="Submit" value="提交" onclick="insertcode()" style="border:1px solid #000; line-height:18px; width:60px;"/>';
}else
{
?>
<div style="margin:0 auto">
<form id="form1" name="form1" method="post" action="insertcode.php">
<label>选择要插入的代码类型
<select name="codetype" id="codetype">
<option value='php'>php</option>
<option value='js'>js</option>
<option value='html'>html</option>
<option value='c'>c</option>
<option value='asp'>asp</option>
<option value='xml'>xml</option>
<option value='java'>java</option>
<option value='java'>java</option>
<option value='CSharp'>C#</option>
<option value='sql'>SQL</option>
</select>
</label>
<label>
<textarea name="content" id="content" cols="30" rows="20" style="width:600px; height:200px; border:1px dashed #333"></textarea>
</label>
<p>
<label style="padding-left:50px;">
<input type="Submit" name="Submit" value="提交" style="border:1px solid #000; line-height:18px; width:60px;"/>
</label>
</p>
<p> </p>
</form>
</div>
<?php
}
?>
在insertcode.php中,insertcode() 函数用来调用 tinyMCE.html页面的 insertHTMl()函数,并将代码插入到 tinyMCE.html 页面中。
代码中,我们为什么要 '+value+' 呢?
因为我们在显示页面,将会采用 SyntaxHighlighter 插件来高亮显示代码。
还有一点要说明,在这里,$content = htmlspecialchars($content); 我们对于代码本身,进行了 htmlspecialchars 转义操作。这样,插入数据库的代码则会是安全的。
OK,我们再来看 save.php,该页面用来显示 提交的内容。
主要代码如下:
复制代码 代码如下:
<?
$Article_Content = $_POST['Article_Content'];
function transcode($str)
{
if(empty($str))
{
return false;
}
$str = str_replace('"','"',$str);
$str = str_replace('','',$str);
$str = str_ireplace('<BR>',"n",$str);
$str = str_ireplace('<pre','<pre name="code" ',$str);
return $str;
}
echo transcode($Article_Content);
?>
<script class="javascript" src="/tinymce/lightcode/Scripts/shCore.js"></script>
<script class="javascript" src="/tinymce/lightcode/Scripts/shBrushCSharp.js"></script>
<script class="javascript" src="/tinymce/lightcode/Scripts/shBrushPhp.js"></script>
<script class="javascript" src="/tinymce/lightcode/Scripts/shBrushJScript.js"></script>
<script class="javascript" src="/tinymce/lightcode/Scripts/shBrushJava.js"></script>
<script class="javascript" src="/tinymce/lightcode/Scripts/shBrushVb.js"></script>
<script class="javascript" src="/tinymce/lightcode/Scripts/shBrushSql.js"></script>
<script class="javascript" src="/tinymce/lightcode/Scripts/shBrushXml.js"></script>
<script class="javascript" src="/tinymce/lightcode/Scripts/shBrushDelphi.js"></script>
<script class="javascript" src="/tinymce/lightcode/Scripts/shBrushPython.js"></script>
<script class="javascript" src="/tinymce/lightcode/Scripts/shBrushRuby.js"></script>
<script class="javascript" src="/tinymce/lightcode/Scripts/shBrushCss.js"></script>
<script class="javascript" src="/tinymce/lightcode/Scripts/shBrushCpp.js"></script>
<script class="javascript">
dp.SyntaxHighlighter.HighlightAll('code');
</script>
OK,完了。
^_^ ~~~
tinyMCE 插件开发之插代码高亮 v1.0 (支持html,php,sql,js)
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
主要从两个方面入手了:1.高亮显示/换行2.复制代码按钮这两方面都有现成的插件。代码高亮插件——highlight.js1.下载highlight的js文件。h
复制代码代码如下:JS关键词高亮/**参数说明:*obj:对象,要进行高亮显示的html标签节点.*hlWords:字符串,要进行高亮的关键词词,使用竖杠(|)
CodeMirror是一个基于JavaScript的代码编辑器,CodeMirror支持大量语言的语法高亮,也包括css,html,js等的高亮显示。此外,Co
PHP+plupload.jsJS插件实现多图上传并显示进度条加删除实例,废话不多说,直接上代码HTML代码:多图上传*{margin:0px;padding:
ExtendedCHMPHP语法手册之DIY1.ExtendedCHM的主要特点可自定义右键菜单php代码块以语法高亮显示php代码块中的函数带有相应的函数手册