• 博客园代码高亮美化教程


    先简单展示下效果吧:

    首先需要导入js代码,在侧边栏公告处将以下代码复制进入:

    ! function () {
        var q = null;
        window.PR_SHOULD_USE_CONTINUATION = !0;
        (function () {
            function S(a) {
                function d(e) {
                    var b = e.charCodeAt(0);
                    if (b !== 92) return b;
                    var a = e.charAt(1);
                    return (b = r[a]) ? b : "0" <= a && a <= "7" ? parseInt(e.substring(1), 8) : a === "u" || a === "x" ? parseInt(e.substring(2), 16) : e.charCodeAt(1)
                }
    
                function g(e) {
                    if (e < 32) return (e < 16 ? "\x0" : "\x") + e.toString(16);
                    e = String.fromCharCode(e);
                    return e === "\" || e === "-" || e === "]" || e === "^" ? "\" + e : e
                }
    
                function b(e) {
                    var b = e.substring(1, e.length - 1).match(/\u[dA-Fa-f]{4}|\x[dA-Fa-f]{2}|\[0-3][0-7]{0,2}|\[0-7]{1,2}|\[Ss]|[^\]/g),
                        e = [],
                        a =
                        b[0] === "^",
                        c = ["["];
                    a && c.push("^");
                    for (var a = a ? 1 : 0, f = b.length; a < f; ++a) {
                        var h = b[a];
                        if (/\[bdsw]/i.test(h)) c.push(h);
                        else {
                            var h = d(h),
                                l;
                            a + 2 < f && "-" === b[a + 1] ? (l = d(b[a + 2]), a += 2) : l = h;
                            e.push([h, l]);
                            l < 65 || h > 122 || (l < 65 || h > 90 || e.push([Math.max(65, h) | 32, Math.min(l, 90) | 32]), l < 97 || h > 122 || e.push([Math.max(97, h) & -33, Math.min(l, 122) & -33]))
                        }
                    }
                    e.sort(function (e, a) {
                        return e[0] - a[0] || a[1] - e[1]
                    });
                    b = [];
                    f = [];
                    for (a = 0; a < e.length; ++a) h = e[a], h[0] <= f[1] + 1 ? f[1] = Math.max(f[1], h[1]) : b.push(f = h);
                    for (a = 0; a < b.length; ++a) h = b[a], c.push(g(h[0])),
                        h[1] > h[0] && (h[1] + 1 > h[0] && c.push("-"), c.push(g(h[1])));
                    c.push("]");
                    return c.join("")
                }
    
                function s(e) {
                    for (var a = e.source.match(/[(?:[^\]]|\[Ss])*]|\u[dA-Fa-f]{4}|\x[dA-Fa-f]{2}|\d+|\[^dux]|(?[!:=]|[()^]|[^()[\^]+/g), c = a.length, d = [], f = 0, h = 0; f < c; ++f) {
                        var l = a[f];
                        l === "(" ? ++h : "\" === l.charAt(0) && (l = +l.substring(1)) && (l <= h ? d[l] = -1 : a[f] = g(l))
                    }
                    for (f = 1; f < d.length; ++f) - 1 === d[f] && (d[f] = ++x);
                    for (h = f = 0; f < c; ++f) l = a[f], l === "(" ? (++h, d[h] || (a[f] = "(?:")) : "\" === l.charAt(0) && (l = +l.substring(1)) && l <= h &&
                        (a[f] = "\" + d[l]);
                    for (f = 0; f < c; ++f) "^" === a[f] && "^" !== a[f + 1] && (a[f] = "");
                    if (e.ignoreCase && m)
                        for (f = 0; f < c; ++f) l = a[f], e = l.charAt(0), l.length >= 2 && e === "[" ? a[f] = b(l) : e !== "\" && (a[f] = l.replace(/[A-Za-z]/g, function (a) {
                            a = a.charCodeAt(0);
                            return "[" + String.fromCharCode(a & -33, a | 32) + "]"
                        }));
                    return a.join("")
                }
                for (var x = 0, m = !1, j = !1, k = 0, c = a.length; k < c; ++k) {
                    var i = a[k];
                    if (i.ignoreCase) j = !0;
                    else if (/[a-z]/i.test(i.source.replace(/\u[da-f]{4}|\x[da-f]{2}|\[^UXux]/gi, ""))) {
                        m = !0;
                        j = !1;
                        break
                    }
                }
                for (var r = {
                        b: 8,
                        t: 9,
                        n: 10,
                        v: 11,
                        f: 12,
                        r: 13
                    }, n = [], k = 0, c = a.length; k < c; ++k) {
                    i = a[k];
                    if (i.global || i.multiline) throw Error("" + i);
                    n.push("(?:" + s(i) + ")")
                }
                return RegExp(n.join("|"), j ? "gi" : "g")
            }
    
            function T(a, d) {
                function g(a) {
                    var c = a.nodeType;
                    if (c == 1) {
                        if (!b.test(a.className)) {
                            for (c = a.firstChild; c; c = c.nextSibling) g(c);
                            c = a.nodeName.toLowerCase();
                            if ("br" === c || "li" === c) s[j] = "
    ", m[j << 1] = x++, m[j++ << 1 | 1] = a
                        }
                    } else if (c == 3 || c == 4) c = a.nodeValue, c.length && (c = d ? c.replace(/
    ?/g, "
    ") : c.replace(/[	
    
     ]+/g, " "), s[j] = c, m[j << 1] = x, x += c.length, m[j++ << 1 | 1] =
                        a)
                }
                var b = /(?:^|s)nocode(?:s|$)/,
                    s = [],
                    x = 0,
                    m = [],
                    j = 0;
                g(a);
                return {
                    a: s.join("").replace(/
    $/, ""),
                    d: m
                }
            }
    
            function H(a, d, g, b) {
                d && (a = {
                    a: d,
                    e: a
                }, g(a), b.push.apply(b, a.g))
            }
    
            function U(a) {
                for (var d = void 0, g = a.firstChild; g; g = g.nextSibling) var b = g.nodeType,
                    d = b === 1 ? d ? a : g : b === 3 ? V.test(g.nodeValue) ? a : d : d;
                return d === a ? void 0 : d
            }
    
            function C(a, d) {
                function g(a) {
                    for (var j = a.e, k = [j, "pln"], c = 0, i = a.a.match(s) || [], r = {}, n = 0, e = i.length; n < e; ++n) {
                        var z = i[n],
                            w = r[z],
                            t = void 0,
                            f;
                        if (typeof w === "string") f = !1;
                        else {
                            var h = b[z.charAt(0)];
                            if (h) t = z.match(h[1]), w = h[0];
                            else {
                                for (f = 0; f < x; ++f)
                                    if (h = d[f], t = z.match(h[1])) {
                                        w = h[0];
                                        break
                                    } t || (w = "pln")
                            }
                            if ((f = w.length >= 5 && "lang-" === w.substring(0, 5)) && !(t && typeof t[1] === "string")) f = !1, w = "src";
                            f || (r[z] = w)
                        }
                        h = c;
                        c += z.length;
                        if (f) {
                            f = t[1];
                            var l = z.indexOf(f),
                                B = l + f.length;
                            t[2] && (B = z.length - t[2].length, l = B - f.length);
                            w = w.substring(5);
                            H(j + h, z.substring(0, l), g, k);
                            H(j + h + l, f, I(w, f), k);
                            H(j + h + B, z.substring(B), g, k)
                        } else k.push(j + h, w)
                    }
                    a.g = k
                }
                var b = {},
                    s;
                (function () {
                    for (var g = a.concat(d), j = [], k = {}, c = 0, i = g.length; c < i; ++c) {
                        var r =
                            g[c],
                            n = r[3];
                        if (n)
                            for (var e = n.length; --e >= 0;) b[n.charAt(e)] = r;
                        r = r[1];
                        n = "" + r;
                        k.hasOwnProperty(n) || (j.push(r), k[n] = q)
                    }
                    j.push(/[Ss]/);
                    s = S(j)
                })();
                var x = d.length;
                return g
            }
    
            function v(a) {
                var d = [],
                    g = [];
                a.tripleQuotedStrings ? d.push(["str", /^(?:'''(?:[^'\]|\[Ss]|''?(?=[^']))*(?:'''|$)|"""(?:[^"\]|\[Ss]|""?(?=[^"]))*(?:"""|$)|'(?:[^'\]|\[Ss])*(?:'|$)|"(?:[^"\]|\[Ss])*(?:"|$))/, q, "'""]) : a.multiLineStrings ? d.push(["str", /^(?:'(?:[^'\]|\[Ss])*(?:'|$)|"(?:[^"\]|\[Ss])*(?:"|$)|`(?:[^\`]|\[Ss])*(?:`|$))/,
                    q, "'"`"
                ]) : d.push(["str", /^(?:'(?:[^
    
    '\]|\.)*(?:'|$)|"(?:[^
    
    "\]|\.)*(?:"|$))/, q, ""'"]);
                a.verbatimStrings && g.push(["str", /^@"(?:[^"]|"")*(?:"|$)/, q]);
                var b = a.hashComments;
                b && (a.cStyleComments ? (b > 1 ? d.push(["com", /^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/, q, "#"]) : d.push(["com", /^#(?:(?:define|e(?:l|nd)if|else|error|ifn?def|include|line|pragma|undef|warning)|[^
    
    ]*)/, q, "#"]), g.push(["str", /^<(?:(?:(?:../)*|/?)(?:[w-]+(?:/[w-]+)+)?[w-]+.h(?:h|pp|++)?|[a-z]w*)>/, q])) : d.push(["com",
                    /^#[^
    
    ]*/, q, "#"
                ]));
                a.cStyleComments && (g.push(["com", /^//[^
    
    ]*/, q]), g.push(["com", /^/*[Ss]*?(?:*/|$)/, q]));
                if (b = a.regexLiterals) {
                    var s = (b = b > 1 ? "" : "
    
    ") ? "." : "[\S\s]";
                    g.push(["lang-regex", RegExp("^(?:^^\.?|[+-]|[!=]=?=?|\#|%=?|&&?=?|\(|\*=?|[+\-]=|->|\/=?|::?|<<?=?|>>?>?=?|,|;|\?|@|\[|~|{|\^\^?=?|\|\|?=?|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\s*(" + ("/(?=[^/*" + b + "])(?:[^/\x5B\x5C" + b + "]|\x5C" + s + "|\x5B(?:[^\x5C\x5D" + b + "]|\x5C" +
                        s + ")*(?:\x5D|$))+/") + ")")])
                }(b = a.types) && g.push(["typ", b]);
                b = ("" + a.keywords).replace(/^ | $/g, "");
                b.length && g.push(["kwd", RegExp("^(?:" + b.replace(/[s,]+/g, "|") + ")\b"), q]);
                d.push(["pln", /^s+/, q, " 
    	u00a0"]);
                b = "^.[^\s\w.$@'"`/\\]*";
                a.regexLiterals && (b += "(?!s*/)");
                g.push(["lit", /^@[$_a-z][w$@]*/i, q], ["typ", /^(?:[@_]?[A-Z]+[a-z][w$@]*|w+_t)/, q], ["pln", /^[$_a-z][w$@]*/i, q], ["lit", /^(?:0x[da-f]+|(?:d(?:_d+)*d*(?:.d*)?|.d+)(?:e[+-]?d+)?)[a-z]*/i, q, "0123456789"], ["pln", /^\[Ss]?/,
                    q
                ], ["pun", RegExp(b), q]);
                return C(d, g)
            }
    
            function J(a, d, g) {
                function b(a) {
                    var c = a.nodeType;
                    if (c == 1 && !x.test(a.className))
                        if ("br" === a.nodeName) s(a), a.parentNode && a.parentNode.removeChild(a);
                        else
                            for (a = a.firstChild; a; a = a.nextSibling) b(a);
                    else if ((c == 3 || c == 4) && g) {
                        var d = a.nodeValue,
                            i = d.match(m);
                        if (i) c = d.substring(0, i.index), a.nodeValue = c, (d = d.substring(i.index + i[0].length)) && a.parentNode.insertBefore(j.createTextNode(d), a.nextSibling), s(a), c || a.parentNode.removeChild(a)
                    }
                }
    
                function s(a) {
                    function b(a, c) {
                        var d =
                            c ? a.cloneNode(!1) : a,
                            e = a.parentNode;
                        if (e) {
                            var e = b(e, 1),
                                g = a.nextSibling;
                            e.appendChild(d);
                            for (var i = g; i; i = g) g = i.nextSibling, e.appendChild(i)
                        }
                        return d
                    }
                    for (; !a.nextSibling;)
                        if (a = a.parentNode, !a) return;
                    for (var a = b(a.nextSibling, 0), d;
                        (d = a.parentNode) && d.nodeType === 1;) a = d;
                    c.push(a)
                }
                for (var x = /(?:^|s)nocode(?:s|$)/, m = /
    ?|
    /, j = a.ownerDocument, k = j.createElement("li"); a.firstChild;) k.appendChild(a.firstChild);
                for (var c = [k], i = 0; i < c.length; ++i) b(c[i]);
                d === (d | 0) && c[0].setAttribute("value", d);
                var r = j.createElement("ol");
                r.className = "linenums";
                for (var d = Math.max(0, d - 1 | 0) || 0, i = 0, n = c.length; i < n; ++i) k = c[i], k.className = "L" + (i + d) % 10, k.firstChild || k.appendChild(j.createTextNode("u00a0")), r.appendChild(k);
                a.appendChild(r)
            }
    
            function p(a, d) {
                for (var g = d.length; --g >= 0;) {
                    var b = d[g];
                    F.hasOwnProperty(b) ? D.console && console.warn("cannot override language handler %s", b) : F[b] = a
                }
            }
    
            function I(a, d) {
                if (!a || !F.hasOwnProperty(a)) a = /^s*</.test(d) ? "default-markup" : "default-code";
                return F[a]
            }
    
            function K(a) {
                var d = a.h;
                try {
                    var g = T(a.c, a.i),
                        b = g.a;
                    a.a = b;
                    a.d = g.d;
                    a.e = 0;
                    I(d, b)(a);
                    var s = /MSIEs(d+)/.exec(navigator.userAgent),
                        s = s && +s[1] <= 8,
                        d = /
    /g,
                        x = a.a,
                        m = x.length,
                        g = 0,
                        j = a.d,
                        k = j.length,
                        b = 0,
                        c = a.g,
                        i = c.length,
                        r = 0;
                    c[i] = m;
                    var n, e;
                    for (e = n = 0; e < i;) c[e] !== c[e + 2] ? (c[n++] = c[e++], c[n++] = c[e++]) : e += 2;
                    i = n;
                    for (e = n = 0; e < i;) {
                        for (var p = c[e], w = c[e + 1], t = e + 2; t + 2 <= i && c[t + 1] === w;) t += 2;
                        c[n++] = p;
                        c[n++] = w;
                        e = t
                    }
                    c.length = n;
                    var f = a.c,
                        h;
                    if (f) h = f.style.display, f.style.display = "none";
                    try {
                        for (; b < k;) {
                            var l = j[b + 2] || m,
                                B = c[r + 2] || m,
                                t = Math.min(l, B),
                                A = j[b + 1],
                                G;
                            if (A.nodeType !== 1 && (G = x.substring(g,
                                    t))) {
                                s && (G = G.replace(d, "
    "));
                                A.nodeValue = G;
                                var L = A.ownerDocument,
                                    o = L.createElement("span");
                                o.className = c[r + 1];
                                var v = A.parentNode;
                                v.replaceChild(o, A);
                                o.appendChild(A);
                                g < l && (j[b + 1] = A = L.createTextNode(x.substring(t, l)), v.insertBefore(A, o.nextSibling))
                            }
                            g = t;
                            g >= l && (b += 2);
                            g >= B && (r += 2)
                        }
                    } finally {
                        if (f) f.style.display = h
                    }
                } catch (u) {
                    D.console && console.log(u && u.stack || u)
                }
            }
            var D = window,
                y = ["break,continue,do,else,for,if,return,while"],
                E = [
                    [y, "auto,case,char,const,default,double,enum,extern,float,goto,inline,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"],
                    "catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"
                ],
                M = [E, "alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,delegate,dynamic_cast,explicit,export,friend,generic,late_check,mutable,namespace,nullptr,property,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"],
                N = [E, "abstract,assert,boolean,byte,extends,final,finally,implements,import,instanceof,interface,null,native,package,strictfp,super,synchronized,throws,transient"],
                O = [N, "as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,internal,into,is,let,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var,virtual,where"],
                E = [E, "debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"],
                P = [y, "and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"],
                Q = [y, "alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"],
                W = [y, "as,assert,const,copy,drop,enum,extern,fail,false,fn,impl,let,log,loop,match,mod,move,mut,priv,pub,pure,ref,self,static,struct,true,trait,type,unsafe,use"],
                y = [y, "case,done,elif,esac,eval,fi,function,in,local,set,then,until"],
                R = /^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)d*)/,
                V = /S/,
                X = v({
                    keywords: [M, O, E, "caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END", P, Q, y],
                    hashComments: !0,
                    cStyleComments: !0,
                    multiLineStrings: !0,
                    regexLiterals: !0
                }),
                F = {};
            p(X, ["default-code"]);
            p(C([], [
                ["pln", /^[^<?]+/],
                ["dec", /^<!w[^>]*(?:>|$)/],
                ["com", /^<!--[Ss]*?(?:-->|$)/],
                ["lang-", /^<?([Ss]+?)(?:?>|$)/],
                ["lang-", /^<%([Ss]+?)(?:%>|$)/],
                ["pun", /^(?:<[%?]|[%?]>)/],
                ["lang-",
                    /^<xmp[^>]*>([Ss]+?)</xmp[^>]*>/i
                ],
                ["lang-js", /^<script[^>]*>([Ss]*?)(</script[^>]*>)/i],
                ["lang-css", /^<style[^>]*>([Ss]*?)(</style[^>]*>)/i],
                ["lang-in.tag", /^(</?[a-z][^<>]*>)/i]
            ]), ["default-markup", "htm", "html", "mxml", "xhtml", "xml", "xsl"]);
            p(C([
                ["pln", /^s+/, q, " 	
    "],
                ["atv", /^(?:"[^"]*"?|'[^']*'?)/, q, ""'"]
            ], [
                ["tag", /^^</?[a-z](?:[w-.:]*w)?|/?>$/i],
                ["atn", /^(?!style[s=]|on)[a-z](?:[w:-]*w)?/i],
                ["lang-uq.val", /^=s*([^s"'>]*(?:[^s"'/>]|/(?=s)))/],
                ["pun", /^[/<->]+/],
                ["lang-js", /^onw+s*=s*"([^"]+)"/i],
                ["lang-js", /^onw+s*=s*'([^']+)'/i],
                ["lang-js", /^onw+s*=s*([^s"'>]+)/i],
                ["lang-css", /^styles*=s*"([^"]+)"/i],
                ["lang-css", /^styles*=s*'([^']+)'/i],
                ["lang-css", /^styles*=s*([^s"'>]+)/i]
            ]), ["in.tag"]);
            p(C([], [
                ["atv", /^[Ss]+/]
            ]), ["uq.val"]);
            p(v({
                keywords: M,
                hashComments: !0,
                cStyleComments: !0,
                types: R
            }), ["c", "cc", "cpp", "cxx", "cyc", "m"]);
            p(v({
                keywords: "null,true,false"
            }), ["json"]);
            p(v({
                    keywords: O,
                    hashComments: !0,
                    cStyleComments: !0,
                    verbatimStrings: !0,
                    types: R
                }),
                ["cs"]);
            p(v({
                keywords: N,
                cStyleComments: !0
            }), ["java"]);
            p(v({
                keywords: y,
                hashComments: !0,
                multiLineStrings: !0
            }), ["bash", "bsh", "csh", "sh"]);
            p(v({
                keywords: P,
                hashComments: !0,
                multiLineStrings: !0,
                tripleQuotedStrings: !0
            }), ["cv", "py", "python"]);
            p(v({
                keywords: "caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END",
                hashComments: !0,
                multiLineStrings: !0,
                regexLiterals: 2
            }), ["perl", "pl", "pm"]);
            p(v({
                keywords: Q,
                hashComments: !0,
                multiLineStrings: !0,
                regexLiterals: !0
            }), ["rb", "ruby"]);
            p(v({
                keywords: E,
                cStyleComments: !0,
                regexLiterals: !0
            }), ["javascript", "js"]);
            p(v({
                keywords: "all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,throw,true,try,unless,until,when,while,yes",
                hashComments: 3,
                cStyleComments: !0,
                multilineStrings: !0,
                tripleQuotedStrings: !0,
                regexLiterals: !0
            }), ["coffee"]);
            p(v({
                keywords: W,
                cStyleComments: !0,
                multilineStrings: !0
            }), ["rc", "rs", "rust"]);
            p(C([], [
                ["str", /^[Ss]+/]
            ]), ["regex"]);
            var Y = D.PR = {
                createSimpleLexer: C,
                registerLangHandler: p,
                sourceDecorator: v,
                PR_ATTRIB_NAME: "atn",
                PR_ATTRIB_VALUE: "atv",
                PR_COMMENT: "com",
                PR_DECLARATION: "dec",
                PR_KEYWORD: "kwd",
                PR_LITERAL: "lit",
                PR_NOCODE: "nocode",
                PR_PLAIN: "pln",
                PR_PUNCTUATION: "pun",
                PR_SOURCE: "src",
                PR_STRING: "str",
                PR_TAG: "tag",
                PR_TYPE: "typ",
                prettyPrintOne: D.prettyPrintOne = function (a, d, g) {
                    var b = document.createElement("div");
                    b.innerHTML = "<pre>" + a + "</pre>";
                    b = b.firstChild;
                    g && J(b, g, !0);
                    K({
                        h: d,
                        j: g,
                        c: b,
                        i: 1
                    });
                    return b.innerHTML
                },
                prettyPrint: D.prettyPrint = function (a, d) {
                    function g() {
                        for (var b = D.PR_SHOULD_USE_CONTINUATION ? c.now() + 250 : Infinity; i < p.length && c.now() < b; i++) {
                            for (var d = p[i], j = h, k = d; k = k.previousSibling;) {
                                var m = k.nodeType,
                                    o = (m === 7 || m === 8) && k.nodeValue;
                                if (o ? !/^??prettify/.test(o) : m !== 3 || /S/.test(k.nodeValue)) break;
                                if (o) {
                                    j = {};
                                    o.replace(/(w+)=([w%+-.:]+)/g, function (a, b, c) {
                                        j[b] = c
                                    });
                                    break
                                }
                            }
                            k = d.className;
                            if ((j !== h || e.test(k)) && !v.test(k)) {
                                m = !1;
                                for (o = d.parentNode; o; o = o.parentNode)
                                    if (f.test(o.tagName) &&
                                        o.className && e.test(o.className)) {
                                        m = !0;
                                        break
                                    } if (!m) {
                                    d.className += " prettyprinted";
                                    m = j.lang;
                                    if (!m) {
                                        var m = k.match(n),
                                            y;
                                        if (!m && (y = U(d)) && t.test(y.tagName)) m = y.className.match(n);
                                        m && (m = m[1])
                                    }
                                    if (w.test(d.tagName)) o = 1;
                                    else var o = d.currentStyle,
                                        u = s.defaultView,
                                        o = (o = o ? o.whiteSpace : u && u.getComputedStyle ? u.getComputedStyle(d, q).getPropertyValue("white-space") : 0) && "pre" === o.substring(0, 3);
                                    u = j.linenums;
                                    if (!(u = u === "true" || +u)) u = (u = k.match(/linenums(?::(d+))?/)) ? u[1] && u[1].length ? +u[1] : !0 : !1;
                                    u && J(d, u, o);
                                    r = {
                                        h: m,
                                        c: d,
                                        j: u,
                                        i: o
                                    };
                                    K(r)
                                }
                            }
                        }
                        i < p.length ? setTimeout(g, 250) : "function" === typeof a && a()
                    }
                    for (var b = d || document.body, s = b.ownerDocument || document, b = [b.getElementsByTagName("pre"), b.getElementsByTagName("code"), b.getElementsByTagName("xmp")], p = [], m = 0; m < b.length; ++m)
                        for (var j = 0, k = b[m].length; j < k; ++j) p.push(b[m][j]);
                    var b = q,
                        c = Date;
                    c.now || (c = {
                        now: function () {
                            return +new Date
                        }
                    });
                    var i = 0,
                        r, n = /lang(?:uage)?-([w.]+)(?!S)/,
                        e = /prettyprint/,
                        v = /prettyprinted/,
                        w = /pre|xmp/i,
                        t = /^code$/i,
                        f = /^(?:pre|code|xmp)$/i,
                        h = {};
                    g()
                }
            };
            typeof define === "function" && define.amd && define("google-code-prettify", [], function () {
                return Y
            })
        })();
    }()
    
    var link = document.createElement('link');
    link.rel = "stylesheet";
    link.href = "http://www.css88.com/wp-content/plugins/wp-googlecodeprettify/js/prettify.css?ver=4.8";
    link.type = "text/css";
    link.media = "all";
    document.getElementsByTagName('head').item(0).appendChild(link);
    /*初始化prettyPrint*/
    if (typeof jQuery != 'undefined') {
        jQuery(window).load(function () {
            jQuery("pre").addClass("prettyprint");
            prettyPrint();
        })
    } else {
        //IE暂时只支持到IE10
        window.onload = function () {
            var pres = document.getElementsByTagName('pre');
            //这个其实是执行forEach方法,只不过那个数组的this变成了pres而已,可以看成换了数组元素
            //由于forEach原本接受的参数就是函数,所以这里第二个参数可以是函数。
            [].forEach.call(pres, function (item, i) {
                item.classList.add('prettyprint', 'linenums');
            });
            prettyPrint();
        }
    }
    View Code

    还需要一些css,在页面定制css代码处将以下css样式复制进入

    /* Tomorrow Night Eighties Theme */
    /* Original theme - https://github.com/chriskempson/tomorrow-theme */
    /* css88 0.1*/
    .prettyprint,pre.prettyprint {
        background-color: #444444;
        border: 1px solid #272822;
        overflow: hidden;
        padding: 0px;
        margin: 20px 0;
        font: 14px/20px 'courier new';
        color: #666;
        -webkit-border-radius: 3px;
        -moz-border-radius: 3px;
        border-radius: 3px;
    }
    
    .prettyprint.linenums,
    pre.prettyprint.linenums {
      -webkit-box-shadow: inset 40px 0 0 #39382E, inset 41px 0 0 #464741;
      -moz-box-shadow: inset 40px 0 0 #39382E, inset 41px 0 0 #464741;
      box-shadow: inset 40px 0 0 #39382E, inset 41px 0 0 #464741;
    }
    .prettyprint.linenums ol,
    pre.prettyprint.linenums ol {
        margin: 0 0 0 33px;
    }
    .prettyprint.linenums ol li,
    pre.prettyprint.linenums ol li {
        padding-left: 12px;
      color: #bebec5;
      line-height: 20px;
      margin-left: 0;
      list-style: decimal;
    }
    .prettyprint ol.linenums{ margin-bottom: 0;/*margin-bottom: -8px; margin-top:-8px; margin-right: -8px; position:relative;*/background-color: #272822; padding: 8px}
    .prettyprint .com { color: #93a1a1; }
    .prettyprint .lit { color: #AE81FF; }
    .prettyprint .pun,
    .prettyprint .opn,
    .prettyprint .clo { color: #F8F8F2; }
    .prettyprint .fun { color: #dc322f; }
    .prettyprint .str,
    .prettyprint .atv { color: #E6DB74; }
    .prettyprint .kwd,
    .prettyprint .tag { color: #F92659; }
    .prettyprint .typ,
    .prettyprint .atn,
    .prettyprint .dec,
    .prettyprint .var { color: #A6E22E; }
    .prettyprint .pln { color: #66D9EF; }
    View Code
  • 相关阅读:
    KafkaSpout 重复消费问题解决
    FastJson 输出值 首字母大小写问题
    Kafka0.7运行时报错 kafka/javaapi/consumer/ConsumerConnector : Unsupported major.minor version 51.0 解决
    Zookeeper原理与Curator使用
    Strom 消息处理机制 中英对照翻译 (Storm如何保证消息被完全处理)
    Mac安装 Storm 小结
    linux下实现ftp上传文件
    Task 0.0 in stage 1.0 (TID 1) had a not serializable result: org.apache.hadoop.hbase.client.Result
    Spark操作HBase
    maven-pom-project文件报错
  • 原文地址:https://www.cnblogs.com/zjlyyq/p/10594223.html
Copyright © 2020-2023  润新知