亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 綜合 > 正文

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

2024-07-21 02:53:32
字體:
來源:轉載
供稿:網友
近日做個小網站,用到了代碼高亮嵌入顯示功能,想將FCKeditor和dp.SyntaxHighlighter結合使用。
 

因此上網查了許多資料,沒有說怎么做的,都是自己改好一個包上傳。我研究了一個這些整合好的例子,粗略說一說,對以后開發其它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;i<codeTypeNum;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("<" , "<"); 
    //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">

 

最終目錄結構如下:

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

      第七步:找到“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代碼高亮顯示就完成了。

最終效果如圖:

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



注:相關教程知識閱讀請移步到編輯器頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品精品视频| 国产精品福利无圣光在线一区| 欧美重口另类videos人妖| 国产精品日日摸夜夜添夜夜av| 奇门遁甲1982国语版免费观看高清| 国产精品一区二区女厕厕| 亚洲男人天堂网| 国产美女精品视频免费观看| 亚洲日本中文字幕免费在线不卡| 国产福利视频一区二区| 国产美女精彩久久| 午夜剧场成人观在线视频免费观看| 日韩成人av在线| 久久久av免费| 在线视频国产日韩| 夜夜嗨av色一区二区不卡| 欧美天天综合色影久久精品| 国产精品视频男人的天堂| 精品国产网站地址| 欧美日韩亚洲视频一区| 亚洲国产精品久久久久秋霞蜜臀| 久久久久久噜噜噜久久久精品| 欧美寡妇偷汉性猛交| 欧美成年人视频网站欧美| 久久中国妇女中文字幕| 在线看福利67194| 欧美性猛交xxxx乱大交3| 国产精品一区二区三区毛片淫片| 亚洲精品xxx| 久久国产精彩视频| 欧美尺度大的性做爰视频| 久久久久日韩精品久久久男男| 成人免费淫片视频软件| 国产97在线|日韩| 91大神福利视频在线| 国产精品永久免费| 国产美女久久精品香蕉69| 91影院在线免费观看视频| 久久亚洲精品毛片| 国产精品欧美久久久| 国产成人综合精品在线| 国产精品国产自产拍高清av水多| 欧美中文字幕在线播放| 久久99精品久久久久久噜噜| 久久精品99无色码中文字幕| 全色精品综合影院| 性欧美办公室18xxxxhd| 亚洲欧美一区二区三区四区| 国产69精品99久久久久久宅男| 久久的精品视频| 亚洲自拍偷拍在线| 亚洲国产高清自拍| 69av在线视频| 欧美中文在线观看| 热re91久久精品国99热蜜臀| 成人日韩在线电影| 国产91精品黑色丝袜高跟鞋| 宅男66日本亚洲欧美视频| 亚洲xxxx做受欧美| 国产精品扒开腿做爽爽爽男男| 国内伊人久久久久久网站视频| 激情成人中文字幕| 91高清免费在线观看| 亚洲国产精品va在看黑人| 国产成人激情小视频| 国产福利成人在线| 在线精品视频视频中文字幕| 国产精品稀缺呦系列在线| 欧美性猛交xxxx黑人猛交| 亚洲国模精品私拍| 中文字幕成人精品久久不卡| 国产一区二区三区欧美| 欧美激情二区三区| 欧美色道久久88综合亚洲精品| 中文国产成人精品久久一| 亚洲乱亚洲乱妇无码| 欧美激情女人20p| 亚洲性无码av在线| 亚洲va码欧洲m码| 国产精品ⅴa在线观看h| 亚洲变态欧美另类捆绑| 欧美日韩国产精品一区二区不卡中文| 欧美亚洲伦理www| 精品视频中文字幕| 欧美精品成人91久久久久久久| 日韩a**中文字幕| 亚洲男人的天堂在线| 神马久久久久久| 国产这里只有精品| 久久资源免费视频| 国产精品久久久久久久久久尿| 国产精品99导航| 精品欧美激情精品一区| www.亚洲成人| 亚洲精品资源美女情侣酒店| 在线观看国产成人av片| 国产亚洲精品成人av久久ww| 亚洲人成免费电影| 色妞欧美日韩在线| 久久艳片www.17c.com| 久久久久久午夜| 欧美综合一区第一页| 538国产精品一区二区免费视频| 91久久夜色精品国产网站| 久久夜色精品亚洲噜噜国产mv| 国产视频久久久| 国产精品一区二区3区| 欧美日韩国产影院| 亚洲视频在线免费观看| 亚洲天堂第二页| 日韩中文综合网| 亲子乱一区二区三区电影| 91精品视频在线免费观看| 欧美黄色片免费观看| 久久99亚洲精品| 精品久久久久久国产| 亚洲福利在线播放| 欧美黄色性视频| 亚洲最大福利网站| 国产精品2018| 亚洲最新中文字幕| 亚洲精品日韩欧美| 亚洲黄色av网站| 欧美亚洲视频一区二区| 久久躁日日躁aaaaxxxx| 亚洲精品国产拍免费91在线| 亚洲高清在线观看| 久久精品视频免费播放| 亚洲精品免费网站| 国产日韩换脸av一区在线观看| 国产精品欧美风情| 91av视频在线观看| 在线视频一区二区| 日韩视频在线一区| 91精品国产91久久久久久吃药| 亚洲japanese制服美女| 日韩综合中文字幕| 国产一区二区三区丝袜| 色爱av美腿丝袜综合粉嫩av| 亚洲美女精品成人在线视频| 亚洲欧美国产日韩中文字幕| 亚洲精品视频网上网址在线观看| 亚洲一级片在线看| 91久久嫩草影院一区二区| 97视频在线观看免费高清完整版在线观看| 欧美日韩精品二区| 日韩精品一二三四区| 欧美精品在线免费| 亚洲精品999| 亚洲日本aⅴ片在线观看香蕉| 国产精品视频白浆免费视频| 午夜精品久久久久久99热软件| 国产精品久久不能| 国产精品亚洲一区二区三区| 亚洲女人天堂成人av在线| 欧美网站在线观看| 欧美成人国产va精品日本一级| 综合网中文字幕| 国产精品亚洲片夜色在线| 国产精品天天狠天天看| 大桥未久av一区二区三区| 91亚洲精品久久久| 9.1国产丝袜在线观看| 日韩欧美在线一区|