技术干货

wordpress小工具添加恋爱天数

果壳 · 7月25日 · 2020年 · · · 5389次已读

前言

之前发表过一篇为博客添加恋爱天数小工具(如下),但是实际使用过程中存在bug,比如夜间模式不会变黑等,昨天看到博友发表的WordPress如何添加“博客统计”信息,受到启发,把这个改成恋爱天数不就行了嘛,所以出现了此文章。

效果预览

教程

1、复制下面代码并创建 lovetime.php 文件。

<?php


// 定义小工具的类 lovetime
class lovetime extends WP_Widget{

	function lovetime(){
		// 定义小工具的构造函数
		$widget_ops = array('classname' => 'widget_blogstat', 'description' => '显示恋爱天数信息');
		$this->WP_Widget(false, '恋爱天数', $widget_ops);
	}
	
	function form($instance){
		// 表单函数,控制后台显示
		// $instance 为之前保存过的数据
		// 如果之前没有数据的话,设置默认量
		$instance = wp_parse_args(
			(array)$instance,
			array(
				'title' => '我们相爱了!',
				'establish_time' => '2018-05-13', 
				'boyimage' => 'https://api.gksir.top/zhutitupian/boytx.png',
				'girlimage' => 'https://api.gksir.top/zhutitupian/girltx.png'
			)
		);
		$title = htmlspecialchars($instance['title']);
		$establish_time = htmlspecialchars($instance['establish_time']);
		// establish_time => 恋爱天数
		$boyimage = htmlspecialchars($instance['boyimage']);
		$girlimage = htmlspecialchars($instance['girlimage']);
		
		// 表格布局输出表单
		$output = '<table>';
		$output .= '<tr><td>标题</td><td>';
		$output .= '<input id="'.$this->get_field_id('title') .'" name="'.$this->get_field_name('title').'" type="text" value="'.$instance['title'].'" />';
		$output .= '</td></tr><tr><td>恋爱天数:</td><td>';   
		$output .= '<input id="'.$this->get_field_id('establish_time') .'" name="'.$this->get_field_name('establish_time').'" type="text" value="'.$instance['establish_time'].'" />';
		$output .= '</td></tr><tr><td>男生头像:</td><td>';   
		$output .= '<input id="'.$this->get_field_id('boyimage') .'" name="'.$this->get_field_name('boyimage').'" type="text" value="'.$instance['boyimage'].'" />'; 
		$output .= '</td></tr><tr><td>女生头像:</td><td>';   
		$output .= '<input id="'.$this->get_field_id('girlimage') .'" name="'.$this->get_field_name('girlimage').'" type="text" value="'.$instance['girlimage'].'" />';
		$output .= '</td></tr></table>';  
		echo $output;   
	}
	
	function update($new_instance, $old_instance){
		// 更新数据的函数
		$instance = $old_instance;
		// 数据处理
		$instance['title'] = strip_tags(stripslashes($new_instance['title']));
		$instance['establish_time'] = strip_tags(stripslashes($new_instance['establish_time']));
		$instance['boyimage'] = strip_tags(stripslashes($new_instance['boyimage']));
		$instance['girlimage'] = strip_tags(stripslashes($new_instance['girlimage']));
		return $instance;
	}
	
	function widget($args, $instance){
		extract($args); //展开数组
		$title = apply_filters('widget_title',empty($instance['title']) ? ' ' : $instance['title']);
		$establish_time = empty($instance['establish_time']) ? '2013-01-27' : $instance['establish_time'];
		$boyimage = empty($instance['boyimage']) ? 'https://api.gksir.top/zhutitupian/boytx.png' : $instance['boyimage'];
		$girlimage = empty($instance['girlimage']) ? 'https://api.gksir.top/zhutitupian/girltx.png' : $instance['girlimage'];
		echo $before_widget;
		echo $before_title . $title . $after_title;
		echo '<div style="margin-top: 15px;"><section class="widget widget_categories wrapper-md clear"><ul class="list-group">';
		$this->efan_get_blogstat($boyimage,$girlimage,$establish_time);
		echo '</ul></section></div>';
		echo $after_widget;
	}
	
	function efan_get_blogstat($boyimage,$girlimage,$establish_time /*, $instance */){
		// 相关数据的获取
		$time = floor((time()-strtotime($establish_time))/86400); 

		$this->statItem($boyimage,$girlimage, '一起走过', $time . ' 天');
	}

	function statItem($boy, $girl, $desc, $data) {
		
		echo '<div id="lovexhj"><div id="lovexhjImage">';
        //<!-- 左边的头像 -->
        echo '<img src="' . $boy . '" alt="love">';
        //<!-- 中间的图片 -->
        echo '<img src="https://cdn.nutssss.cn/wp-content/uploads/2020/02/1582858549-lovexhjlogo.gif" alt="love">';
        //<!-- 右边的头像 -->
        echo '<img src="' . $girl . '" alt="love"></div>';
        echo '<br/><div id="lovetime"><p>' . $desc . $data. '</p></div></div>';
	}
}

function lovetime(){
	// 注册小工具
	register_widget('lovetime');
}
add_action('widgets_init','lovetime');
?>

2、放到主题的根目录下。

3、在主题里的 function.php 函数里 ?>前 添加 include(“lovetime.php”);

4、到“后台——外观——小工具”中添加“恋爱天数”小工具。

5、 这个css代码放在主题自定义css里就行 。

/*相恋时间夜间模式*/
body.night #htmer_time {
      color:#738192;
}
/*相恋时间夜间模式结束*/

/*相恋时间*/
#lovetime {
    text-align: center;
    font-size: 16px;
    color:#738192;
}
#lovexhj {
    width: 100%;
    height: 100px;
    text-align: center;
    font-size: 1rem;
}
#lovexhjImage {
    width: 220px;
    margin: 0 auto;
}
#lovexhj img {
    width: 60px;
    border-radius: 50%;
}
/*相恋时间结束*/
这个方法适用于本站,其他站点请自测

本文作者:果壳
原文链接:https://muuzi.cc/702.html
版权声明:知识共享署名-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)协议进行许可
转载时请以超链接形式标明文章原始出处和作者信息

1 条回应

  1. 夏沫2020-11-29 · 16:01

    扒了扒了

页面加载用时0.443 s
×