zoukankan      html  css  js  c++  java
  • 代码着色一个优秀的代码着色插件SyntaxHighlighter

    SyntaxHighlighter Google Code 上的一个开源项目,主要用于给网页上的代码着色,使用十分方便,效果也不错,而且几乎支持常见的所有语言。

     

    安装使用方法:

     

    1. 首先在页面上添加如下代码(假设下载后的SyntaxHighlighter放在SyntaxHighlighter目录下面,注意目录结构):

    <link type="text/css" rel="stylesheet" href="SyntaxHighlighter/Styles/SyntaxHighlighter.css"></link>

    <script language="javascript" src="SyntaxHighlighter/Scripts/shCore.js"></script>

    <script language="javascript" src="SyntaxHighlighter/Scripts/shBrushCSharp.js"></script>

    <script language="javascript" src="SyntaxHighlighter/Scripts/shBrushXml.js"></script>

    <script language="javascript">

    window.onload = function ()

    {

        dp.SyntaxHighlighter.ClipboardSwf = 'SyntaxHighlighter/Scripts/clipboard.swf';

        dp.SyntaxHighlighter.HighlightAll('code');

    }

    </script>

     

    官方的安装中没有window.onload,我想这个还是需要的,毕竟,页面加载的时候我就需要给代码着色。

     

     

     

    2. 使用方法如下:

    方法一:使用pre

    <pre name="code" class="c-sharp">

    ... some code here ...

    </pre>

     

    方法二:使用textarea

    <textarea name="code" class="c#" cols="60" rows="10">

    ... some code here ...

    </textarea>

     

    另外,这里还有一些高级特性的设置方法可供参考,诸如代码折叠等。

    我在互动wiki 上安装成功,安装方法如上,第一步的修改代码放到doc.php文件的最后即可,以后编辑wiki的时候直接使用html模式即可按照第二步的方法给代码着色。

     

    PSCSDNblog系统上使用的也是这个插件:>

    =============================

    http://code.google.com/p/syntaxhighlighter/downloads/list

     

    第一步:增加样式包含

    <link type=text/css rel=stylesheet href=Styles/SyntaxHighlighter.css></link>

     

    第二步:增加代码

    <textarea name=code class=php>

    代码放在这里

    </textarea>

     

    这里的class指的是语言有c,c#,vb,java,php,ruby,js,css,sql

     

    第三步包含所需要的js

    <script language=javascript src=Scripts/shCore.js></script>

    <script language=javascript src=Scripts/shBrushPhp.js></script>(包含对应语言的文件)

    <script language=javascript>

    dp.SyntaxHighlighter.ClipboardSwf = Scripts/clipboard.swf;// 复制代码要用到

    dp.SyntaxHighlighter.HighlightAll(code);// 这里对应的就是上面的name

    </script>

     

     

    ====================================

    1.首先下载SyntaxHighlighter.

     

     

     

    2.解压到SyntaxHighlighter目录中.

     

     

     

    3.建立HTML文件:

     

    <pre name="code" class="Ruby">

    ...Ruby代码...

    </pre>

     

    可以应用在pretextarea两种HTML标签内,namecode,class为要着色的语言,现在支持C, C#, CSS, Delphi, Java, JScript, Php, Python, Ruby, Sql, VB, XML这些语言.

     

     

     

    4.加入所需的CSSJS文件:

     

    <link rel="stylesheet" type="text/css" href="./lib/SyntaxHighlighter/Styles/SyntaxHighlighter.css" />

    <script src="./lib/SyntaxHighlighter/Scripts/shCore.js"></script>

    <script src="./lib/SyntaxHighlighter/Scripts/shBrushRuby.js"></script>

     

    这里只用了Ruby,其他的类似.

     

     

    5.接下来就是在windowonload事件内,SyntaxHighlighter工作起来.

     

    window.onload = function()

    {

        dp.SyntaxHighlighter.ClipboardSwf = './lib/SyntaxHighlighter/Scripts/clipboard.swf';

        dp.SyntaxHighlighter.HighlightAll("code");

    };

     

     

    之后,刷新下页面,你就会发现,代码已经被着上了相应的颜色了

    ======================

    将你要高亮显示的代码放在 pre  textarea 

     

    <pre name="code" class="c-sharp">

    ... some code here ...

    </pre>

    <textarea name="code" class="c#" cols="60" rows="10">

    ... some code here ...

    </textarea>

     

    class选项允许你单独配置文本块。

     

    nogutter     将不会显示行号。

    nocontrols     将不会在顶部显示控制器。

    collapse     将默认折叠代码。

    firstline[value]     行计数开始值。默认值是 1

    showcolumns     将在第一行显示行列。

     

    这些选项和别名放置在一起,使用冒号 : 字符分隔。

     

    <pre name="code" class="html:nocontrols:firstline[10]">

    ... some code here ...

    </pre>

     

     

     

    语言     别名

    C++     cpp, c, c++

    C#     c#, c-sharp, csharp

    CSS     css

    Delphi     delphi, pascal

    Java     java

    Java Script     js, jscript, javascript

    PHP     php

    Python     py, python

    Ruby     rb, ruby, rails, ror

    Sql     sql

    VB     vb, vb.net

    XML/HTML     xml, html, xhtml, xslt

     

     

     

    在页面最后添加JSCSS引用    JS有很多,若是语言固定的话,只要引入 shCore  shBrushXml(相应JS文件就行了

    <link type="text/css" rel="stylesheet" href="css/SyntaxHighlighter.css"></link>

    <script language="javascript" src="js/shCore.js"></script>

    <script language="javascript" src="js/shBrushCSharp.js"></script>

    <script language="javascript" src="js/shBrushXml.js"></script>

    <script language="javascript">

    dp.SyntaxHighlighter.ClipboardSwf = '/flash/clipboard.swf';

    dp.SyntaxHighlighter.HighlightAll('code');//这里的 ‘code’ 为上面放置代码的容器

    </script>

     

        * SyntaxHighlighterHighlightAll 方法

    这是一个全局函数,它找出网页上所有的代码块,将他们转换成高亮的代码块。

    参数

    function dp.SyntaxHighlighter.HighlightAll(name, [showGutter], [showControls],

    [collapseAll], [firstLine], [showColumns])

     

    name         必要     <pre> 和 <textarea> 元素使用的名称。

    showGutter     可选     打开或关闭所有处理的代码块的行号。(默认为 true

    showControls     可选     打开或关闭所有处理的 <pre> 的控制器。(默认为 true

    collapseAll     可选     打开或关闭所有处理的 <pre> 的折叠。如果 showControls  false 或被交换了,这个值将被忽略。(默认为 false

    firstLine     可选     允许指定行号开始的第一行。当你想指明代码块在文件的哪个相对位置时有用。(默认为 1

    showColumns     可选     将在第一行显示行列。(默认为 false

     

    所有传到 HighlightAll 调用的值将重载配置的对应选项.

     

     

     

    下载地址:

    http://code.google.com/p/syntaxhighlighter/

     

     

     

    附一个小例子说一下 textarea  pre 的区别

     

    <html>

    <head>

    <title>高亮测试</title>

        <link type="text/css" rel="stylesheet" href="Styles/SyntaxHighlighter.css"/>

        <script language="javascript" src="Scripts/shCore.js"></script>

        <script language="javascript" src="Scripts/shBrushXml.js"></script>

    </head>

    <body>

    <textarea name="code" class="xml" rows="15" cols="100">

    程序源代码放在这儿afds

    dp.SyntaxHighlighter.HighlightAll('code');

    dp.SyntaxHighlighter.HighlightAll('code2');

    请注译掉这二句查看效果,注意 textarea  pre 的分别。pre中的 《 号需要转译,要不然就原样输出了,在高亮代码没有生效的情况下。

        <h1>adsfadfadf</h1>

        -------------------

    &lt;h1>adsfadfadf&lt;/h1>

    </textarea>

    <pre name="code2" class="xml" rows="15" cols="100">

    程序源代码放在这儿afds

    dp.SyntaxHighlighter.HighlightAll('code');

    dp.SyntaxHighlighter.HighlightAll('code2');

        <h1>adsfadfadf</h1>

        -------------------

    &lt;h1>adsfadfadf&lt;/h1>

    </pre>

    <script class="javascript">

    dp.SyntaxHighlighter.HighlightAll('code');

    dp.SyntaxHighlighter.HighlightAll('code2');

    </script>

    </body>

    </html>

     

  • 相关阅读:
    Docker入门
    15个Docker基本命令及用法
    Docker系列
    docker
    Docker 常用命令
    查看用户列表在Linux
    Spring boot Mybatis
    CountDownLatch和CyclicBarrier 专题
    Spring Boot MyBatis 连接数据库
    Spring Boot MyBatis 通用Mapper插件集成 good
  • 原文地址:https://www.cnblogs.com/caigen029/p/3515431.html
Copyright © 2011-2022 走看看