校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > FCKEditor SyntaxHighlighter整合實現代碼高亮顯示

FCKEditor SyntaxHighlighter整合實現代碼高亮顯示

熱門標簽:四平電話機器人哪家好 株洲外呼營銷系統有哪些 長春銷售外呼系統業務 長春防封卡電銷卡套餐 天津電銷卡外呼系統線路 靈聲智能電話機器人招聘 興化400電話辦理多少錢 智能電銷機器人真的好嗎 企業電話機器人辦理

因此上網查了許多資料,沒有說怎么做的,都是自己改好一個包上傳。我研究了一個這些整合好的例子,粗略說一說,對以后開發其它FCKeditor插件也有好處。
為方便大家使用,腳本之家特提供兩個已經做成插件的版本。下載地址
第一步:在FCKeditor的路徑中找到“editor\plugins\”,在其中創建“highlighter”文件夾。

第二步:將“dp.SyntaxHighlighter\Scripts”文件夾復制到此文件夾中,所有的js文件和一個flash文件也要一通復制過來。

第三步:在“highlighter\”創建“lang”文件夾,在其中新建“zh-cn.js”文件,內容如下——

復制代碼 代碼如下:

FCKLang.CodeBtn = '插入高亮代碼' ;
FCKLang.CodeArea = '代碼';
FCKLang.CodeDlgTitle = '插入高亮代碼' ;
FCKLang.CodeDlgName = '語言' ;
FCKLang.CodeErrNoName = '請輸入代碼' ;


第四步:在“highlighter\”創建“fckplugin.js”,內容如下——此文件內容也可以參考其他plugins目錄下的同名文件。
復制代碼 代碼如下:

// Register the related commands.
//FCKCommands.RegisterCommand( 'HighLighter', new FCKDialogCommand("HighLighter",FCKLang.DlgHighLighterTitle,FCKConfig.Plugins.Items['highlighter'].Path + 'highlighter.html', 540, 540 ) ) ;
FCKCommands.RegisterCommand( 'HighLighter', new FCKDialogCommand("HighLighter",FCKLang['CodeDlgTitle'],FCKConfig.PluginsPath + 'highlighter/highlighter.html', 540, 500 ) ) ;
// Create the "highlighter" toolbar button.
var oHighLighterItem        = new FCKToolbarButton( 'HighLighter', FCKLang['CodeBtn'] ) ;
oHighLighterItem.IconPath    = FCKConfig.PluginsPath + 'highlighter/highlighter.gif' ;
FCKToolbarItems.RegisterItem( 'HighLighter', oHighLighterItem );// 'HighLighter' is the name used in the Toolbar config.
var FCKHighLighter = new Object();
var CSS_PATH      = FCKConfig.PluginsPath + "highlighter/dp.SyntaxHighlighter/Styles/";
var pool = {"firstCss" : true };
FCKHighLighter.Add = function( value ){
    var oDiv = FCK.CreateElement("div");
    oDiv._FCKhighLighter = "hlDiv" + Math.random() ;
    oDiv.className="dp-highlighter";
    oDiv.innerHTML = value;
    if(pool.firstCss) {
        pool.firstCss = false;
        //oDiv.innerHTML += "link href="" + CSS_PATH + "SyntaxHighlighter.css" href="" + CSS_PATH + "SyntaxHighlighter.css"" + "type='text/css' rel='stylesheet'>/link>";
    }
    // alert(oDiv.innerHTML);
}
FCKHighLighter.OnDoubleClick = function( div ){
//    if(div._FCKhighLighter = "hlDiv") FCKCommands.GetCommand( 'HighLighter' ).Execute() ;
    if(div.className == "dp-highlighter" div.tagName=="DIV") FCKCommands.GetCommand( 'HighLighter' ).Execute() ;
}
FCK.RegisterDoubleClickHandler( FCKHighLighter.OnDoubleClick, 'DIV' ) ;

第五步:找一個21×21px的gif圖片作為按鈕,取名為“highlighter.gif”。

第六步:關鍵步驟,創建插入代碼對話框,取名為“highlighter.html”。內容如下——
復制代碼 代碼如下:

!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
html xmlns="http://www.w3.org/1999/xhtml">
head>
meta http-equiv="pragma" content="no-cache" />
meta http-equiv="Cache-Control" content="no-cache, must-revalidate" />
meta http-equiv="expires" content="Wed, 26 Feb 1997 08:21:57 GMT" />
meta http-equiv="expires" content="0" />
script type="text/javascript" src="dp.SyntaxHighlighter/Scripts/shCore.js" src="dp.SyntaxHighlighter/Scripts/shCore.js" >/script>
script type="text/javascript" src="dp.SyntaxHighlighter/Scripts/shBrushCSharp.js" src="dp.SyntaxHighlighter/Scripts/shBrushCSharp.js">/script>
script type="text/javascript" src="dp.SyntaxHighlighter/Scripts/shBrushPhp.js" src="dp.SyntaxHighlighter/Scripts/shBrushPhp.js">/script>
script type="text/javascript" src="dp.SyntaxHighlighter/Scripts/shBrushJScript.js" src="dp.SyntaxHighlighter/Scripts/shBrushJScript.js">/script>
script type="text/javascript" src="dp.SyntaxHighlighter/Scripts/shBrushJava.js" src="dp.SyntaxHighlighter/Scripts/shBrushJava.js">/script>
script type="text/javascript" src="dp.SyntaxHighlighter/Scripts/shBrushVb.js" src="dp.SyntaxHighlighter/Scripts/shBrushVb.js">/script>
script type="text/javascript" src="dp.SyntaxHighlighter/Scripts/shBrushSql.js" src="dp.SyntaxHighlighter/Scripts/shBrushSql.js">/script>
script type="text/javascript" src="dp.SyntaxHighlighter/Scripts/shBrushXml.js" src="dp.SyntaxHighlighter/Scripts/shBrushXml.js">/script>
script type="text/javascript" src="dp.SyntaxHighlighter/Scripts/shBrushDelphi.js" src="dp.SyntaxHighlighter/Scripts/shBrushDelphi.js">/script>
script type="text/javascript" src="dp.SyntaxHighlighter/Scripts/shBrushPython.js" src="dp.SyntaxHighlighter/Scripts/shBrushPython.js">/script>
script type="text/javascript" src="dp.SyntaxHighlighter/Scripts/shBrushRuby.js" src="dp.SyntaxHighlighter/Scripts/shBrushRuby.js">/script>
script type="text/javascript" src="dp.SyntaxHighlighter/Scripts/shBrushCss.js" src="dp.SyntaxHighlighter/Scripts/shBrushCss.js">/script>
script type="text/javascript" src="dp.SyntaxHighlighter/Scripts/shBrushCpp.js" src="dp.SyntaxHighlighter/Scripts/shBrushCpp.js">/script>
title>插入代碼/title>
script language="javascript" type="text/javascript">!--
var oEditor = window.parent.InnerDialogLoaded() ;
var FCKLang = oEditor.FCKLang ;
var FCKHighLighter = oEditor.FCKHighLighter ;
window.onload = function () {
    oEditor.FCKLanguageManager.TranslatePage( document ) ;
    window.parent.SetOkButton( true ) ;    
    LoadSelected();
document.getElementById("code").focus();
}
function Ok()
{
    if(document.getElementById("code").value.length==0)
    {
        alert(FCKLang['CodeErrNoName']);
        return false;
    }    
//    dp.SyntaxHighlighter.ClipboardSwf = 'dp.SyntaxHighlighter/Scripts/clipboard.swf';
    var result=dp.SyntaxHighlighter.HighlightAll('code',0,1,0,1,0);
    
    var str = "";
    for(key in result)
    {
        str += result[key][0];
    }
    FCKHighLighter.Add( str ) ;
    return true ;
}
var eSelected = oEditor.FCKSelection.GetSelectedElement() ;
function LoadSelected()
{
    if ( !eSelected ){ return ;}
    if ( eSelected.tagName == 'DIV' eSelected.className=="dp-highlighter" )
    {
     var ol = eSelected.document.getElementsByTagName("ol"); //火狐下提示這里出錯
        var codeClass = ol[0].className.substring(3,ol[0].className.length);
     var ddlv='';
     switch(codeClass){
     case "cpp":
     document.getElementById("code").className="cpp";
     ddlv="cpp";
     break;
     case "c": //c#,javascript php 不明白為什么這三種語言的CSS名都是dp-c,所以區分不了
     document.getElementById("code").className="csharp";
     ddlv="c#";
     break;
     case "css":
     document.getElementById("code").className="css";
     ddlv="css";
     break;
     case "delphi":
     document.getElementById("code").className="delphi";
     ddlv="delphi";
     break;
     case "j":
     document.getElementById("code").className="java";
     ddlv="java";
     break;
     case "py":
     document.getElementById("code").className="python";
     ddlv="python";
     break;
     case "rb":
     document.getElementById("code").className="ruby";
     ddlv="ruby";
     break;
     case "sql":
     document.getElementById("code").className="sql";
     ddlv="sql";
     break;
     case "vb":
     document.getElementById("code").className="vb";
     ddlv="vb";
     break;
     case "xml":
     document.getElementById("code").className="xml";
     ddlv="xml";
     break;
     }
        var codeTypeNum = document.getElementById("codeType").options.length;
        for(var i=0;icodeTypeNum;i++)
        {
            if(document.getElementById("codeType").options[i].value == ddlv)
            {
                document.getElementById("codeType").options[i].selected = true;
            }
        }
//        var codeContent = eSelected.nextSibling.innerHTML;
    //    document.getElementById('code').value = codeContent.replace("lt;" , "");
    //document.getElementById('code').value = codeContent.replace(/[^>]+>/g, "");
    
     if(navigator.userAgent.indexOf("MSIE")>0){
     document.getElementById('code').value = ol[0].innerText;
     }else{
     document.getElementById('code').value = ol[0].textContent;
     }
    }
    else eSelected == null ;
}
// -->/script>
/head>
body>
table style="width:100%;">
tr>
td style="width:10%; line-height:25px;">span fckLang="CodeDlgName">/span>/td>
td>
select id="codeType" style="width:250px;" onchange="document.getElementById('code').className =this.value;">
     option value="csharp">C#/option>
     option value="php">PHP/option>
     option value="javascript">Javascript/option>
     option value="xml">Xml/option>
     option value="xml">Html/option>
     option value="css">Css/option>
     option value="cpp">C/C++/option>
     option value="delphi">Delphi/option>
     option value="java">Java/option>
     option value="python">Python/option>
     option value="ruby">Ruby/option>
     option value="sql">Sql/option>
     option value="vb">VB/option>
     /select>    
/td>
/tr>
tr>
td>span fckLang="CodeArea">/span>/td>
td>
textarea rows="25" cols="80" class="csharp" name="code" id="code">

最終目錄結構如下:

      第七步:找到“fckconfig.js”文件。(這是fckeditor的核心配置文件,應該能找到的吧……)找“FCKConfig.ToolbarSets”這個key,然后在里面加入“'HighLighter'”。例如:

復制代碼 代碼如下:

FCKConfig.ToolbarSets["Basic"] = [
['Style','FontFormat','FontName','FontSize','-','Bold','Italic','-','TextColor','BGColor','-','HighLighter']

第八步:還是在“fckconfig.js”中,找到“FCKConfig.Plugins”這個key,添加如下代碼:
復制代碼 代碼如下:

FCKConfig.Plugins.Add( 'highlighter','zh-cn') ;

好了,以FCKEditor插件形式出現的SyntaxHighlighter代碼高亮顯示就完成了。

最終效果如圖:

您可能感興趣的文章:
  • asp.net 為FCKeditor開發代碼高亮插件實現代碼
  • ckeditor syntaxhighlighter代碼高亮插件,完美修復
  • CKeditor與syntaxhighlight打造joomla代碼高亮
  • CKEditor中加入syntaxhighlighter代碼高亮插件
  • ckeditor syntaxhighlighter代碼高亮插件配置分享
  • FCKeditor 和 SyntaxHighlighter 代碼高亮插件的整合
  • FCKeditor + SyntaxHighlighter 讓代碼高亮著色插件
  • CKeditor富文本編輯器使用技巧之添加自定義插件的方法
  • ckeditor自定義插件使用方法詳解
  • CKEditor 附插入代碼的插件
  • CKEditor 4.4.1 添加代碼高亮顯示插件功能教程【使用官方推薦Code Snippet插件】

標簽:貴港 黑龍江 青海 運城 石嘴山 巴彥淖爾 漯河 新疆

巨人網絡通訊聲明:本文標題《FCKEditor SyntaxHighlighter整合實現代碼高亮顯示》,本文關鍵詞  FCKEditor,SyntaxHighlighter,整合,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《FCKEditor SyntaxHighlighter整合實現代碼高亮顯示》相關的同類信息!
  • 本頁收集關于FCKEditor SyntaxHighlighter整合實現代碼高亮顯示的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    国产精品久久久爽爽爽麻豆色哟哟 | 欧美性videosxxxxx| 国产伦理精品不卡| 亚洲色图另类专区| 亚洲欧洲日本在线| 亚洲精品国产高清久久伦理二区| 国产精品视频一二| 亚洲欧美一区二区三区久本道91 | 成人av网在线| 一本大道久久a久久综合婷婷| 99视频精品免费视频| 91美女福利视频| 在线观看亚洲a| 日韩女优av电影| 国产精品色哟哟| 亚洲视频免费在线观看| 亚洲国产综合人成综合网站| 日本欧美加勒比视频| 国产一区二区电影| 91在线视频播放地址| 欧美日韩一区三区| 欧美精品一区二区三区蜜桃| 国产欧美综合在线观看第十页| 一区精品在线播放| 午夜久久久久久久久| 国产一区二区三区免费| 99re成人精品视频| 欧美mv日韩mv亚洲| 亚洲欧美日本在线| 激情综合色综合久久综合| 91一区二区三区在线观看| 欧美日韩一卡二卡| 中文字幕第一区二区| 午夜久久久久久电影| 成人午夜av电影| 欧美日本韩国一区二区三区视频 | 色欧美片视频在线观看在线视频| 欧美三级电影在线观看| 久久久久久久综合狠狠综合| 亚洲黄色尤物视频| 国产酒店精品激情| 91精品啪在线观看国产60岁| 国产精品五月天| 蜜桃视频在线一区| 欧美色图一区二区三区| 国产精品不卡在线| 国产老女人精品毛片久久| 7777精品伊人久久久大香线蕉经典版下载| 亚洲国产电影在线观看| 男女男精品视频网| 欧美无砖专区一中文字| 国产精品国产三级国产a| 久久丁香综合五月国产三级网站| 欧美亚洲高清一区二区三区不卡| 精品国产乱码久久久久久图片 | 日韩欧美成人午夜| 亚洲国产精品一区二区www在线 | 日韩经典中文字幕一区| 在线亚洲精品福利网址导航| 亚洲国产高清不卡| 国产一区二区免费看| 日韩久久久久久| 日本一道高清亚洲日美韩| 欧美三级午夜理伦三级中视频| 亚洲乱码国产乱码精品精可以看 | 欧美性大战久久| 亚洲人成在线观看一区二区| 国产91富婆露脸刺激对白| 精品人在线二区三区| 久久精品国产亚洲a| 欧美刺激午夜性久久久久久久| 午夜视黄欧洲亚洲| 91精品久久久久久蜜臀| 婷婷亚洲久悠悠色悠在线播放 | 国产成人免费av在线| 久久久不卡网国产精品一区| 国内一区二区视频| 国产亚洲精品资源在线26u| 国产又黄又大久久| 欧美激情一区在线| 91蝌蚪porny九色| 亚洲一区av在线| 91精品国产91久久久久久最新毛片| 性欧美疯狂xxxxbbbb| 7777精品久久久大香线蕉| 免费人成在线不卡| 国产婷婷色一区二区三区四区| 国产精品综合在线视频| 18成人在线观看| 欧美影院一区二区| 久久国产尿小便嘘嘘尿| 久久在线观看免费| 99r精品视频| 日韩精品乱码免费| 国产欧美一区二区精品秋霞影院| proumb性欧美在线观看| 亚洲一级二级在线| 久久久精品国产免费观看同学| 97精品久久久午夜一区二区三区 | 亚洲国产中文字幕在线视频综合 | 韩国女主播成人在线| 国产精品天干天干在线综合| 色综合久久久久久久久| 日韩精品视频网| 国产精品国产a| 91精品蜜臀在线一区尤物| 国产一区二区女| 亚洲18色成人| 国产精品麻豆欧美日韩ww| 欧美日韩激情在线| 丰满亚洲少妇av| 免费成人美女在线观看| 自拍偷拍亚洲综合| 精品国产网站在线观看| 日本久久精品电影| 国产91精品久久久久久久网曝门| 亚洲一区二区三区不卡国产欧美| 久久久久国产一区二区三区四区| 欧美日本在线一区| 91在线观看污| 国产不卡一区视频| 日韩综合在线视频| 亚洲精品视频免费观看| 国产亚洲精品aa午夜观看| 欧美福利电影网| 色菇凉天天综合网| 国产精品性做久久久久久| 午夜激情一区二区| 亚洲欧美另类在线| 国产精品色哟哟网站| 精品久久久久一区| 日韩亚洲电影在线| 欧美日韩成人综合| 欧美性生活大片视频| 一本色道久久加勒比精品| 成人手机在线视频| 国产**成人网毛片九色 | voyeur盗摄精品| 岛国一区二区在线观看| 精品亚洲成a人| 久久99精品久久久久久动态图| 视频一区二区三区在线| 亚洲成av人片在线| 午夜精品一区二区三区免费视频 | 韩国成人福利片在线播放| 亚洲高清免费观看| 午夜不卡av免费| 日韩**一区毛片| 美女高潮久久久| 国内成人精品2018免费看| 精品一区精品二区高清| 国产一区二区三区香蕉| 国产露脸91国语对白| 国产成人av在线影院| 国产成人av影院| 97精品国产露脸对白| 一本久久a久久精品亚洲| 91福利视频久久久久| 欧美日韩国产高清一区| 91精品视频网| 精品国产乱码久久久久久免费 | 色域天天综合网| 欧美视频在线播放| 欧美一区二区不卡视频| 精品国产乱码久久久久久图片 | 欧美美女激情18p| 欧美va亚洲va在线观看蝴蝶网| 久久这里只有精品6| 17c精品麻豆一区二区免费| 亚洲老司机在线| 日韩av电影免费观看高清完整版在线观看| 强制捆绑调教一区二区| 国产高清久久久久| 99久久国产免费看| 欧美一区二区视频观看视频| 久久影院视频免费| 一区二区欧美精品| 久久aⅴ国产欧美74aaa| 99麻豆久久久国产精品免费| 欧美精品在欧美一区二区少妇| 精品国产电影一区二区| 亚洲国产精品传媒在线观看| 亚洲一区二区三区中文字幕 | av网站免费线看精品| 色94色欧美sute亚洲13| 日韩一区二区在线免费观看| 国产色产综合产在线视频| 亚洲综合一二三区| 国产另类ts人妖一区二区| 欧美视频一区二区三区四区| 久久久精品天堂| 亚洲gay无套男同| 成人夜色视频网站在线观看| 欧美性受xxxx黑人xyx| 久久久亚洲精华液精华液精华液| 亚洲免费观看高清在线观看| 久久国产精品无码网站| 欧洲精品一区二区| 日本一二三四高清不卡| 美腿丝袜亚洲综合|