




















这里提供两种在WordPress小工具中实现“一言”功能的完整代码方案:基础版和API版。这两种方案都已整合进WordPress小工具系统中,你可以直接使用。
| 特性 | 基础版 (本地句子库) | API版 (远程数据源) |
|---|---|---|
| 数据来源 | 本地存储的句子 | 远程API接口 |
| 性能 | 加载更快,不依赖外部服务 | 依赖API响应速度 |
| 稳定性 | 更稳定,不受第三方服务影响 | 依赖API的稳定性 |
| 内容多样性 | 固定,需手动更新 | 自动更新,内容更丰富 |
| 适用场景 | 需要稳定、快速展示,内容固定的用户 | 希望内容常换常新,不介意外部调用的用户 |
基础版小工具使用本地存储的句子,加载速度快且稳定。
将以下代码添加到您当前主题的 functions.php 文件中:
<?php
// 基础版一言小工具 - 使用本地句子库
class Local_Hitokoto_Widget extends WP_Widget {
// 初始化小工具
function __construct() {
parent::__construct(
'local_hitokoto_widget',
__('一言(基础版)', 'text_domain'),
array('description' => __('显示本地随机一言', 'text_domain'))
);
}
// 小工具前台显示
public function widget($args, $instance) {
$title = apply_filters('widget_title', $instance['title']);
echo $args['before_widget'];
if (!empty($title)) {
echo $args['before_title'] . $title . $args['after_title'];
}
echo '<div class="hitokoto-content">';
echo $this->get_random_hitokoto();
echo '</div>';
echo $args['after_widget'];
}
// 小工具后台表单
public function form($instance) {
$title = !empty($instance['title']) ? $instance['title'] : __('一言', 'text_domain');
?>
<p>
<label for="<?php echo $this->get_field_id('title'); ?>">标题:</label>
<input class="widefat" id="<?php echo $this->get_field_id('title'); ?>"
name="<?php echo $this->get_field_name('title'); ?>" type="text"
value="<?php echo esc_attr($title); ?>" />
</p>
<p>此小工具从本地句子库中随机显示一句话。</p>
<?php
}
// 更新小工具设置
public function update($new_instance, $old_instance) {
$instance = array();
$instance['title'] = (!empty($new_instance['title'])) ? strip_tags($new_instance['title']) : '';
return $instance;
}
// 获取随机一言(核心函数)
private function get_random_hitokoto() {
// 本地句子库 - 在此处添加或修改您喜欢的句子
$sayings = array(
"道可道,非常道。名可名,非常名。",
"路漫漫其修远兮,吾将上下而求索。",
"不积跬步,无以至千里;不积小流,无以成江海。",
"Hello, World!",
"Stay Hungry, Stay Foolish.",
"代码如诗,简约至上。",
"我们遇到的每个平凡瞬间,都是连续发生的奇迹。",
"长太息以掩涕兮,哀民生之多艰。",
"敏而好学,不耻下问。",
"桃李不言,下自成蹊。"
);
// 随机返回一句话
return $sayings[array_rand($sayings)];
}
}
// 注册小工具
function register_local_hitokoto_widget() {
register_widget('Local_Hitokoto_Widget');
}
add_action('widgets_init', 'register_local_hitokoto_widget');
?>
functions.php 文件中要修改显示的句子,请编辑代码中的 $sayings 数组,您可以在其中添加、删除或修改任何句子,每句用双引号包围,用英文逗号分隔。
如果您希望更方便地管理句子,可以修改基础版的 get_random_hitokoto 方法,使其从文本文件读取:
private function get_random_hitokoto() {
// 从主题目录下的 hitokoto.txt 文件读取句子
$file_path = get_template_directory() . '/hitokoto.txt';
if (file_exists($file_path)) {
$sayings = file($file_path, FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES);
if (!empty($sayings)) {
return $sayings[array_rand($sayings)];
}
}
// 如果文件不存在或为空,返回默认句子
return "细水长流,宁静致远。";
}
使用此方法,您需要在主题根目录创建 hitokoto.txt 文件,每行存放一句话。
API版小工具调用远程一言接口,内容更加丰富多样。
将以下代码添加到您当前主题的 functions.php 文件中:
<?php
// API版一言小工具 - 调用远程接口
class API_Hitokoto_Widget extends WP_Widget {
// 初始化小工具
function __construct() {
parent::__construct(
'api_hitokoto_widget',
__('一言(API版)', 'text_domain'),
array('description' => __('调用远程API显示随机一言', 'text_domain'))
);
}
// 小工具前台显示
public function widget($args, $instance) {
$title = apply_filters('widget_title', $instance['title']);
echo $args['before_widget'];
if (!empty($title)) {
echo $args['before_title'] . $title . $args['after_title'];
}
echo '<div class="hitokoto-content" id="' . $this->id . '-content">';
echo $this->get_hitokoto_content();
echo '</div>';
echo $args['after_widget'];
}
// 小工具后台表单
public function form($instance) {
$title = !empty($instance['title']) ? $instance['title'] : __('一言', 'text_domain');
$api_type = !empty($instance['api_type']) ? $instance['api_type'] : 'hitokoto';
?>
<p>
<label for="<?php echo $this->get_field_id('title'); ?>">标题:</label>
<input class="widefat" id="<?php echo $this->get_field_id('title'); ?>"
name="<?php echo $this->get_field_name('title'); ?>" type="text"
value="<?php echo esc_attr($title); ?>" />
</p>
<p>
<label for="<?php echo $this->get_field_id('api_type'); ?>">API源:</label>
<select class="widefat" id="<?php echo $this->get_field_id('api_type'); ?>"
name="<?php echo $this->get_field_name('api_type'); ?>">
<option value="hitokoto" <?php selected($api_type, 'hitokoto'); ?>>一言官网 (hitokoto.cn)</option>
<option value="other" <?php selected($api_type, 'other'); ?>>其他API</option>
</select>
</p>
<p>此小工具调用远程API获取随机一言。</p>
<?php
}
// 更新小工具设置
public function update($new_instance, $old_instance) {
$instance = array();
$instance['title'] = (!empty($new_instance['title'])) ? strip_tags($new_instance['title']) : '';
$instance['api_type'] = (!empty($new_instance['api_type'])) ? strip_tags($new_instance['api_type']) : 'hitokoto';
return $instance;
}
// 获取一言内容
private function get_hitokoto_content() {
$api_type = !empty($this->instance['api_type']) ? $this->instance['api_type'] : 'hitokoto';
// 根据选择的API类型调用不同的接口
if ($api_type === 'hitokoto') {
return $this->get_hitokoto_api();
} else {
// 这里可以扩展其他API接口
return $this->get_hitokoto_api();
}
}
// 调用一言官网API
private function get_hitokoto_api() {
$response = wp_remote_get('https://v1.hitokoto.cn/', array(
'timeout' => 10 // 设置10秒超时
));
// 检查API响应是否正常
if (is_wp_error($response)) {
return '微风起时,沉默亦被聆听。'; // API调用失败时的备用句子
}
$body = wp_remote_retrieve_body($response);
$data = json_decode($body, true);
// 检查JSON解析是否成功且包含所需字段
if (json_last_error() === JSON_ERROR_NONE && isset($data['hitokoto'])) {
$result = $data['hitokoto'];
if (isset($data['from']) && !empty($data['from'])) {
$result .= " ——" . $data['from'];
}
return $result;
} else {
return '溪流汇海,聚萤映夜。'; // JSON解析失败时的备用句子
}
}
}
// 注册小工具
function register_api_hitokoto_widget() {
register_widget('API_Hitokoto_Widget');
}
add_action('widgets_init', 'register_api_hitokoto_widget');
?>
functions.php 文件中将以下CSS代码添加到主题的 style.css 文件中,可以美化一言的显示效果:
/* 一言小工具样式 */
.hitokoto-content {
font-style: italic;
color: #555;
text-align: center;
padding: 15px;
margin: 10px 0;
border-left: 3px solid #4CAF50;
background-color: #f9f9f9;
line-height: 1.6;
}
/* 鼠标悬停效果 */
.hitokoto-content:hover {
background-color: #f0f0f0;
transition: background-color 0.3s ease;
}
functions.php 文件前,建议先备份该文件functions.php 文件中这两种方案各有优势,您可以根据自己的需求选择使用。如果有任何疑问或需要进一步的帮助,请在下方留言。
此内容由惯性聚合(RSS阅读器)自动聚合整理,仅供阅读参考。 原文来自 — 版权归原作者所有。