Introdução ao Pure Highlightjs
No ecossistema do WordPress, o destaque de código sempre foi um recurso importante para blogs de tecnologia e sites de desenvolvedores. Recentemente, o plug-in Pure Highlightjs, que estava inativo há anos, finalmente recebeu uma grande atualização, que levou a biblioteca principal Highlight.js de uma versão desatualizada para a versão 11.11.1 mais recente.
Download do plug-in
Pure Highlightjs Code Highlighting
Atualização do site v2.1.3Faça download e descompacte a pasta Pure-Highlightjs e carregue-a no diretório do plug-in para ativá-lo no backend!
Esquecido, Atualizado
O Pure Highlightjs é um plug-in leve de destaque de código para a plataforma WordPress que foi lançado pelo desenvolvedor icodechef em 2016 e depois parou de ser atualizado. O plug-in foi preferido por muitos usuários do WordPress por sua simplicidade e eficiência, mas, com o tempo, sua versão integrada do Highlight.js ficou seriamente atrás do mainstream, pois não gosto dos outros códigos de acesso do plug-in e prefiro o pré-integrado, então... Eu o atualizei para focar no pré-código nativo do WordPress.
Esse plug-in é pequeno, mas ideal para minhas necessidades. "Como ele não é atualizado há anos, oEditor do siteDecidi tomar para mim a responsabilidade de atualizá-lo para a versão mais recente do Highlight.js.
Aprimoramentos resultantes da atualização
Essa atualização para a versão 11.11.1 do Highlight.js traz vários aprimoramentos importantes:
- Barra de ferramentas de código:Nova barra de ferramentas para expandir, copiar e selecionar todos os botões com exibição flutuante na janela de visualização, muito suave!
- Clique duas vezes para selecionar tudo:Novo clique duplo em select all, clique duplo na área de código do computador para selecionar todo o código
- Altura do bloco de código:Novo bloco de código com altura máxima, um grande número de códigos longos pode ser definido com uma altura máxima, horizontal e vertical terá uma barra de rolagem
- Dobre para desdobrar:Novo botão Expandir para expandir e recolher o bloco de código quando ele adiciona uma altura
- Modo escuroNovo modo escuro, os plug-ins podem escolher o estilo de tema de código diurno e noturno, os temas do WordPress com modo escuro podem ser alternados, você pode experimentar o efeito desse site!
- Otimize as barras de rolagem:O plug-in adiciona uma barra de rolagem simplebar para otimizar o estilo da barra de rolagem de código, que é compatível com os navegadores mais comuns e também pode ser usada em todo o site
- Suporte para linguagens de programação mais modernasSuporte adicional a linguagens modernas, como TypeScript, Kotlin, Dart etc., com um total de 192 linguagens e 80 estilos de temas.
- JS oficial nativo:Sem simplificação, sem alterações no JS, editor clássico e editor de blocos otimizados
- Melhor análise gramaticalReconhecimento aprimorado de sintaxes, como JSX, modelos Vue, etc.
- Correções de compatibilidadeProblemas potenciais de compatibilidade em versões mais antigas foram resolvidos
Por que o Highlightjs?
Entre os vários plug-ins de destaque de código do WordPress, o Pure Highlightjs ainda tem seu lugar devido às suas vantagens exclusivas:
- Design leveNão depende do jQuery e tem impacto mínimo no desempenho do site
- suporte nativousa as pré-etiquetas do WordPress diretamente, sem configurações complexas, e não requer um shortcode de plug-in, como fazem outros plug-ins
- simples e bonitoEstilo padrão: O estilo padrão é limpo e nítido, adequado para documentação técnica
Demonstração do código
Demonstração da barra de rolagem de código
Barra de rolagem com estilo de barra de rolagem simplebar, compatível com uma variedade de navegadores convencionais, você pode testar com vários navegadores diferentes para ver o efeito!
<?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";
?>
Demonstração do código do editor clássico
O editor clássico adiciona código para definir a altura máxima, de acordo com a altura do botão de expansão e recolhimento da tela
<?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";
?>
Demonstração do código 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();
?> Demonstração do código 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%;
}
} Demonstração do código 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); Demonstração do código da linguagem 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)
} Demonstração do código 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'; Demonstração de código do 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}`);
}); Demonstração do código 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) Demonstração de código 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;
} Demonstração do código 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;
}
} Capturas de tela da demonstração
Demonstração dos bastidores

Demonstração do Editor Clássico


Demonstração do Block Editor

Suporte para 192 idiomas

80 temas de estilo

Para blogueiros técnicos e redatores de documentos, uma ferramenta de destaque de código atualizada e eficiente ainda é necessária, e esse renascimento do Pure Highlightjs pode dar nova vida aos recursos de apresentação de código do WordPress.
