下面就是我開發(fā)的過程。
首先,我的 tinyMCE版本是 Version: 3.2.7 (2009-09-22) 。
tinyMCE插入代碼,需要調(diào)用 tinyMCE的 tinyMCE.execCommand('mceInsertContent',false,value); 方法。其中參數(shù)無需改變,value 就是你要插入的內(nèi)容,
比如我寫了一個函數(shù),
代碼如下:
function InsertHTML(value)
{
tinyMCE.execCommand('mceInsertContent',false,value);
}
后面,針對該例子,提供下載。在例子中。一共涉及到三個文件。
tinyMCE.html insertcode.php save.php 這三個文件。
tinyMCE.html 是tinyMCE文本框頁面。
主要代碼如下:
代碼如下:
function InsertHTML(value)
{
tinyMCE.execCommand('mceInsertContent',false,value);
}
后面,針對該例子,提供下載。在例子中。一共涉及到三個文件。
tinyMCE.html insertcode.php save.php 這三個文件。
tinyMCE.html 是tinyMCE文本框頁面。
主要代碼如下:
代碼如下:
input name="button" type="button" onclick="window.open('insertcode.php','插入代碼','height=500, width=600, top=300, left=300, toolbar=no, menubar=no, scrollbars=no, resizable=no,location=no, status=no')" value="點擊這里插入代碼" />
上面這段代碼,是用來打開insertcode.php文件的。
接下來,我們來看下 insertcode。php 這個文件的代碼。
首先是 js 代碼
代碼如下:
<script language="javascript" src="http://www.gosoa.com.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() 函數(shù)用來調(diào)用 tinyMCE.html頁面的 insertHTMl()函數(shù),并將代碼插入到 tinyMCE.html 頁面中。
代碼中,我們?yōu)槭裁匆?'+value+' 呢?
因為我們在顯示頁面,將會采用 SyntaxHighlighter 插件來高亮顯示代碼。
還有一點要說明,在這里,$content = htmlspecialchars($content); 我們對于代碼本身,進行了 htmlspecialchars 轉(zhuǎn)義操作。這樣,插入數(shù)據(jù)庫的代碼則會是安全的。
OK,我們再來看 save.php,該頁面用來顯示 提交的內(nèi)容。
主要代碼如下:
代碼如下:
<?
$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,完了。
^_^ ~~~
更多信息請查看IT技術(shù)專欄