Pure Highlightjs 介紹

喺WordPress生態系統入面,代碼高亮一直係技術博客同開發者網站嘅重要功能。最近,沉寂咗好多年嘅Pure Highlightjs插件終於迎嚟重大更新,將佢核心嘅Highlight.js庫由過時版本升級到最新嘅v11.11.1。

插件下載

Pure Highlightjs代碼高亮

Pure Highlightjs代碼高亮

本站升級 v2.1.3
308 次下載
2025年8月22號更新
密碼:cloud 網盤密碼已複製!
支援WordPress經典編輯器同區塊編輯器嘅原生代碼高亮,支援過百種語言

下載解壓之後,將 Pure-Highlightjs 檔案夾上載到插件目錄,後台啟用就得喇!

忘記咗、更新咗

Pure Highlightjs係WordPress平台上嘅一款輕量級代碼高亮插件,由開發者icodechef喺2016年發佈之後就停止咗更新。呢個插件以其簡潔高效嘅特點受到唔少WordPress用戶嘅青睞,但隨住時間推移,佢內置嘅Highlight.js版本已經嚴重落後於主流。因為我唔鍾意其他插件嘅簡碼,比較鍾意內置嘅pre,所以...我將佢升級咗,重點係WordPress原生pre代碼。

呢個插件雖然細細個,但啱啱好滿足到我嘅需求,「見到佢多年冇更新,」本站小編決定自己動手將佢升級到最新版嘅Highlight.js。

升級帶嚟嘅改進

今次升級到Highlight.js 11.11.1版本帶嚟咗多項重要改進:

  1. 代碼工具欄:新增工具欄展開、複製同全選掣,而且喺視口內浮動顯示,好順滑
  2. 雙擊全選:新增雙擊全選功能,喺電腦端代碼區域雙擊就可以全選代碼
  3. 代碼塊高度:新增代碼塊最大高度,大量長段代碼可以設定一個最大高度,橫向豎向都會有滾動條
  4. 摺疊展開:新增展開按鈕,代碼塊添加咗高度時,可以展開同收埋
  5. 暗黑主題:新增暗黑主題,插件可以揀日間同夜間嘅代碼主題樣式,WordPress主題有暗黑主題嗰陣可以切換,可以試下本站效果
  6. 優化捲軸:插件入面加咗simplebar捲軸,優化代碼捲軸嘅樣式,兼容主流瀏覽器,亦可以對全站使用
  7. 支援更多現代編程語言:新增咗對TypeScript、Kotlin、Dart等現代語言嘅支援,總共支援192種語言同80種風格主題
  8. 原生官方JS:冇精簡過,亦冇對JS做過任何改動,優化咗經典編輯器同區塊編輯器
  9. ​更好嘅語法分析​:改善咗對JSX、Vue模板等語法嘅辨識
  10. 兼容修復​:解決咗舊版本中潛在嘅兼容問題

點解要揀Highlightjs?

喺眾多WordPress代碼高亮插件之中,Pure Highlightjs憑住佢獨特嘅優勢,依然佔有一席位:

  • 輕量級設計​:唔使依賴jQuery,對網站性能影響極細
  • 原生支援:直接使用WordPress嘅pre標籤,唔使複雜設定,唔似其他插件咁需要用插件嘅簡碼
  • 簡潔美觀:預設樣式乾淨俐落,啱晒技術文件

代碼示範

代碼滾動條示範

滾動條用咗simplebar滾動條樣式,兼容多種主流瀏覽器,可以用多個唔同嘅瀏覽器測試睇效果!

<?php
/**
 * PHP长行代码演示示例
 * 用于测试滚动条效果
 */

// 基本变量定义
$testString = "这是一个普通的字符串变量,用于演示PHP的基本语法特性";
$numberValue = 123456;
$arrayData = [
    'name' => '测试数据',
    'type' => '演示',
    'values' => [10, 20, 30, 40, 50]
];

// 这是一行很长的代码,包含了多个函数调用和字符串拼接,目的是测试滚动条效果。这里我们模拟一个复杂的数据处理过程,包含字符串操作、数组处理和数学计算等多种操作的组合。这段代码会将多个不同类型的数据进行转换和组合,生成一个复杂的结果字符串。
$longLine1 = "处理结果: " . strtoupper(trim(json_encode(array_merge($arrayData, ['timestamp' => time(), 'random' => rand(1000, 9999), 'status' => 'completed', 'message' => '这是一条很长的消息,用于增加字符串长度,测试滚动效果。这里继续添加一些内容,让这行代码变得足够长,以便在显示时需要滚动条才能完全查看。']), " \t\n\r\0\x0B"))) . " | 计算结果: " . (sqrt(pow($numberValue, 2) + pow($numberValue / 2, 2)) * 1.5) . " | 状态信息: 操作已完成,耗时 " . microtime(true) . " 毫秒,内存使用: " . memory_get_usage() . " 字节";

// 另一个长行代码,演示条件判断和函数嵌套的复杂情况
if (strlen($testString) > 10 && is_array($arrayData) && count($arrayData['values']) > 3 && $numberValue > 100000 && strpos($testString, 'PHP') !== false && (time() % 2 == 0)) {
    $longLine2 = "满足所有条件 | 数组信息: " . print_r($arrayData, true) . " | 字符串长度: " . strlen($testString) . " | 随机数: " . rand(1, 1000) . " | 当前时间: " . date('Y-m-d H:i:s') . " | 这是为了测试滚动条而添加的额外内容,继续增加长度直到足够长,确保在大多数编辑器或显示窗口中都需要滚动才能看到完整内容。这里再添加一些文字,让这行代码变得更长一些,以达到测试目的。";
} else {
    $longLine2 = "不满足所有条件的默认值";
}

// 函数定义
function processData($input) {
    if (!is_array($input)) {
        return "无效输入: 必须提供数组类型";
    }
    
    // 处理数据的逻辑
    $result = [];
    foreach ($input as $key => $value) {
        $result[strtoupper($key)] = is_string($value) ? strrev($value) : $value;
    }
    
    return $result;
}

// 类定义
class DemoClass {
    private $property1;
    protected $property2;
    public $property3;
    
    public function __construct($param1, $param2) {
        $this->property1 = $param1;
        $this->property2 = $param2;
        $this->property3 = "默认值: " . $param1 . " - " . $param2;
    }
    
    public function getCombined() {
        return $this->property1 . "|" . $this->property2 . "|" . $this->property3;
    }
}

// 执行演示
echo "PHP长行代码测试演示\n";
echo "=====================\n";
echo "1. 长行字符串1: " . $longLine1 . "\n\n";
echo "2. 长行字符串2: " . $longLine2 . "\n\n";
echo "3. 处理后的数据: " . print_r(processData($arrayData), true) . "\n\n";

$demoObj = new DemoClass("参数1", "参数2");
echo "4. 对象信息: " . $demoObj->getCombined() . "\n";
?>

經典編輯器代碼示範

經典編輯器加代碼可以設定最高高度,根據高度顯示展開摺疊掣

<?php
/**
 * PHP长行代码演示示例
 * 用于测试滚动条效果
 */

// 基本变量定义
$testString = "这是一个普通的字符串变量,用于演示PHP的基本语法特性";
$numberValue = 123456;
$arrayData = [
    'name' => '测试数据',
    'type' => '演示',
    'values' => [10, 20, 30, 40, 50]
];

// 这是一行很长的代码,包含了多个函数调用和字符串拼接,目的是测试滚动条效果。这里我们模拟一个复杂的数据处理过程,包含字符串操作、数组处理和数学计算等多种操作的组合。这段代码会将多个不同类型的数据进行转换和组合,生成一个复杂的结果字符串。
$longLine1 = "处理结果: " . strtoupper(trim(json_encode(array_merge($arrayData, ['timestamp' => time(), 'random' => rand(1000, 9999), 'status' => 'completed', 'message' => '这是一条很长的消息,用于增加字符串长度,测试滚动效果。这里继续添加一些内容,让这行代码变得足够长,以便在显示时需要滚动条才能完全查看。']), " \t\n\r\0\x0B"))) . " | 计算结果: " . (sqrt(pow($numberValue, 2) + pow($numberValue / 2, 2)) * 1.5) . " | 状态信息: 操作已完成,耗时 " . microtime(true) . " 毫秒,内存使用: " . memory_get_usage() . " 字节";

// 另一个长行代码,演示条件判断和函数嵌套的复杂情况
if (strlen($testString) > 10 && is_array($arrayData) && count($arrayData['values']) > 3 && $numberValue > 100000 && strpos($testString, 'PHP') !== false && (time() % 2 == 0)) {
    $longLine2 = "满足所有条件 | 数组信息: " . print_r($arrayData, true) . " | 字符串长度: " . strlen($testString) . " | 随机数: " . rand(1, 1000) . " | 当前时间: " . date('Y-m-d H:i:s') . " | 这是为了测试滚动条而添加的额外内容,继续增加长度直到足够长,确保在大多数编辑器或显示窗口中都需要滚动才能看到完整内容。这里再添加一些文字,让这行代码变得更长一些,以达到测试目的。";
} else {
    $longLine2 = "不满足所有条件的默认值";
}

// 函数定义
function processData($input) {
    if (!is_array($input)) {
        return "无效输入: 必须提供数组类型";
    }
    
    // 处理数据的逻辑
    $result = [];
    foreach ($input as $key => $value) {
        $result[strtoupper($key)] = is_string($value) ? strrev($value) : $value;
    }
    
    return $result;
}

// 类定义
class DemoClass {
    private $property1;
    protected $property2;
    public $property3;
    
    public function __construct($param1, $param2) {
        $this->property1 = $param1;
        $this->property2 = $param2;
        $this->property3 = "默认值: " . $param1 . " - " . $param2;
    }
    
    public function getCombined() {
        return $this->property1 . "|" . $this->property2 . "|" . $this->property3;
    }
}

// 执行演示
echo "PHP长行代码测试演示\n";
echo "=====================\n";
echo "1. 长行字符串1: " . $longLine1 . "\n\n";
echo "2. 长行字符串2: " . $longLine2 . "\n\n";
echo "3. 处理后的数据: " . print_r(processData($arrayData), true) . "\n\n";

$demoObj = new DemoClass("参数1", "参数2");
echo "4. 对象信息: " . $demoObj->getCombined() . "\n";
?>

PHP代碼示範

<?php
// 简单的PHP类示例
class Greeting {
    private $name;
    
    public function __construct($name) {
        $this->name = $name;
    }
    
    public function sayHello() {
        return "Hello, " . $this->name . "!";
    }
}

$greeter = new Greeting("World");
echo $greeter->sayHello();
?>

CSS代碼示範

/* 响应式卡片样式 */
.card {
    width: 300px;
    border-radius: 8px;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
    transition: transform 0.3s ease;
    background: #fff;
}

.card:hover {
    transform: translateY(-5px);
}

@media (max-width: 768px) {
    .card {
        width: 100%;
    }
}

JavaScript代碼示範

// 异步获取数据示例
async function fetchUserData(userId) {
    try {
        const response = await fetch(`https://api.example.com/users/${userId}`);
        if (!response.ok) {
            throw new Error('Network response was not ok');
        }
        const data = await response.json();
        console.log('User data:', data);
        return data;
    } catch (error) {
        console.error('Error fetching user data:', error);
    }
}

// 使用示例
fetchUserData(123);

GO語言代碼示範

package main

import (
	"fmt"
	"net/http"
)

// 简单的HTTP服务器
func handler(w http.ResponseWriter, r *http.Request) {
	fmt.Fprintf(w, "Hello, %s!", r.URL.Path[1:])
}

func main() {
	http.HandleFunc("/", handler)
	fmt.Println("Server starting on port 8080...")
	http.ListenAndServe(":8080", nil)
}

MySQL代碼示範

-- 创建用户表并查询示例
CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    username VARCHAR(50) NOT NULL,
    email VARCHAR(100) NOT NULL UNIQUE,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

-- 插入数据
INSERT INTO users (username, email) 
VALUES ('john_doe', '[email protected]');

-- 查询数据
SELECT * FROM users WHERE email LIKE '%@example.com';

Node.js代碼示範

// Express.js 简单API示例
const express = require('express');
const app = express();
const port = 3000;

app.use(express.json());

app.get('/api/greet', (req, res) => {
    const name = req.query.name || 'World';
    res.json({ message: `Hello, ${name}!` });
});

app.listen(port, () => {
    console.log(`Server running at http://localhost:${port}`);
});

Python代碼示範

# 使用Flask创建Web服务
from flask import Flask, jsonify

app = Flask(__name__)

@app.route('/api/square/<int:num>')
def square(num):
    return jsonify({"result": num ** 2})

if __name__ == '__main__':
    app.run(debug=True)

# 列表推导式示例
squares = [x**2 for x in range(10) if x % 2 == 0]
print(squares)

C++代碼示範

#include <iostream>
#include <vector>
#include <algorithm>

// 简单的C++程序示例
int main() {
    std::vector<int> numbers = {5, 2, 8, 1, 9};
    
    // 排序并输出
    std::sort(numbers.begin(), numbers.end());
    
    std::cout << "Sorted numbers: ";
    for (int num : numbers) {
        std::cout << num << " ";
    }
    std::cout << std::endl;
    
    return 0;
}

Java代碼示範

// 简单的Java类和接口示例
public class Main {
    public static void main(String[] args) {
        Calculator calc = new BasicCalculator();
        System.out.println("5 + 3 = " + calc.add(5, 3));
    }
}

interface Calculator {
    int add(int a, int b);
}

class BasicCalculator implements Calculator {
    @Override
    public int add(int a, int b) {
        return a + b;
    }
}

示範截圖

後台示範

WordPress原生pre代碼高亮插件Pure Highlightjs重大更新:升級至Highlight.js v11.11.1版本 - LikaCloud
增加日間同夜間切換,都係本網站用緊嘅主題

經典編輯器示範

WordPress原生pre代碼高亮插件Pure Highlightjs重大更新:升級至Highlight.js v11.11.1版本 - LikaCloud
經典編輯器插入代碼設定代碼塊最大高度
WordPress原生pre代碼高亮插件Pure Highlightjs重大更新:升級至Highlight.js v11.11.1版本 - LikaCloud
用嘅WordPress原生pre方式

區塊編輯器示範

WordPress原生pre代碼高亮插件Pure Highlightjs重大更新:升級至Highlight.js v11.11.1版本 - LikaCloud
區塊編輯器用內置代碼區塊

支援192種語言

WordPress原生pre代碼高亮插件Pure Highlightjs重大更新:升級至Highlight.js v11.11.1版本 - LikaCloud
插件支援192種語言

80個風格主題

WordPress原生pre代碼高亮插件Pure Highlightjs重大更新:升級至Highlight.js v11.11.1版本 - LikaCloud
主題自帶80個風格主題,包含日間同夜間模式

對於技術博客作者同文檔編寫者嚟講,一個更新及時、運行高效嘅代碼高亮工具仍然係剛需。Pure Highlightjs嘅呢次重生,或者可以為WordPress嘅代碼展示功能帶嚟新嘅活力。

插件設定幫助文檔