博客园代码高亮美化教程

先简单展示下效果吧:

首先需要导入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
原文地址:https://www.cnblogs.com/zjlyyq/p/10594223.html