导航

萌即是正义!时不时分享一些ACG活动记录与有趣代码的小站!

侧边栏
热门文章
1页面
程序员老黄历&求签
热度
429
2推文
在结束了高尾食堂的圣地巡礼之后,在沿着浅川去西八王子的路上发现了许多美景于是就拍摄了下来。 横屏的照片是我拍摄的,竖屏的照片是同行的大佬拍的。 沿途有非常多的八重樱盛开真的非常漂亮。以及居然还有春季出现的红叶!?好神奇呀! 河边的鲤鱼旗也非常壮观,所以拍摄了全景照片。 看来浅川的沿岸也是春季非常不错的踏青圣地呢!
热度
363
3博文
探访《蜡笔小新》老家——春日部游记
热度
143
4页面
友链
热度
143
5博文
动画刚开播就要消失的圣地:《时光流逝,饭菜依旧美味》圣地巡礼之高尾与西八王子
热度
104
6博文
3DS模拟器简体中文字库 | Citra3ds字库 | 符文工房4乱码解决字库 | shared_font.bin
热度
91
7博文
《孤独摇滚》圣地巡礼——金泽八景
热度
78
8博文
利用Tshock搭建强行开荒的《泰拉瑞亚》服务器
热度
78
9推文
《摇曳露营△》联合日本静冈县推出了新的圣地巡礼地图。 这周要去的圣地巡礼正是《摇曳露营△》第二季中的伊豆半岛,也就是巡礼地图的右下角这块区域。 可以看到光是伊豆半岛这块区域的巡礼地点就非常多。 此次行程准备用时2天,能逛多少就算多少。 《摇曳露营△》× 静冈县官方:https://yurucamp-shizuoka.com
热度
65
10博文
那些评测软文不会告诉你的 文石BOOX Leaf3C 细节体验报告
热度
52
最新评论
广树管理员
2025-04-23 21:51
@Zrzzz:是的捏
Zrzzz
2025-04-23 21:33
风景真好捏(˶‾᷄ ⁻̫ ‾᷅˵)
广树管理员
2025-04-22 19:50
@某科学的贝壳:其实天气之子也出现过,只不过是这里的屋顶
某科学的贝壳
2025-04-22 19:48
位置 加那一张烟花,总让我想到天气之子的场面OωO
广树管理员
2025-04-22 19:48
@智慧哥哥:感谢大佬的捧场,大佬的评论好文艺呀
攻略中
星空列车与白的旅行
暂无评分
Steam星空列车与白的旅行
2025年2月22日 22时 ~ 攻略中
已累计游玩2个月
乘坐的列车,划破夜空,飞驰在星空之下,令人心旷神怡——这可真是场超值之旅。舒爽夜风吹拂下的随心独旅中,我邂逅了随性的乘客,可人怜爱的乘务员。以及……猫耳少女?这场旅行,究竟会在她身上,留下了些什么呢?
界之轨迹
暂无评分
PS5界之轨迹
2024年9月28日 14时 ~ 攻略中
已累计游玩6个月27天
导力之父爱普斯泰因预言的世界末日即将到来,此时东大陆共和国所研发的导力火箭划破天空,即将探访这个世界的边界。 与此同时万事屋的青年们,正聚集在奥雷德自治州,与集结而来的各方势力,一同看望着这科技奇点。 人们这次是否能认识到世界的真实呢?
PSN奖杯卡

PSN奖杯卡

归档
赞助商广告

给emlog加上显示评论者等级功能

作者:广树时间:2018-04-13 09:25:51分类:PHP

前段时间看到别人的博客有评论者等级的机制于是自己也就想弄一个。在网上查了许多资料后自己也写了一个评论等级功能。

因为没有用户注册机制,所以我们就只能依据评论者留下的邮箱来判断这名用户在网站评论过多少次。


下面是代码部分:

PHP

推荐写在emlog模版文件的module.php下面

<?php
//comment:输出等级
function echo_levels($comment_author_email){
  if($comment_author_email == '""'){
	echo 'null';
  }else{
	  $DB = MySql::getInstance();
	  $sql = "SELECT cid as author_count FROM 评论数据的表单 WHERE mail = ".$comment_author_email."and hide ='n'";
	  $res = $DB->query($sql);
	  $author_count = mysql_num_rows($res);
	  if($author_count>9999){
		  $author_count = 9999;
	  }
	  echo $author_count;
  }
}
?>


注意下 【$sql = "SELECT cid as author_count FROM 评论数据的表单 WHERE mail = ".$comment_author_email."and hide ='n'";】

其中【评论数据的表单】换成自己的,一般来说是emlog_comment


然后使用下面的代码来导出这个用户发过多少次评论。

<?php $mail_str="\"".strip_tags($comment['mail'])."\"";echo_levels($mail_str); ?>

我这里是定义了input的值然后用js去循环出等级。


JSON

这里来定义发多少次评论所对应的等级。

下面是我写的等级表。

{
	"lv_exp": [{
			"name": "Lv.萌新",
			"exp": 3,
			"color": "Magenta"
		},
		{
			"name": "Lv.初学者",
			"exp": 10,
			"color": "BlueViolet"
		},
		{
			"name": "Lv.进阶者",
			"exp": 26,
			"color": "Blue"
		},
		{
			"name": "Lv.高阶者",
			"exp": 40,
			"color": "LightSeaGreen"
		},
		{
			"name": "Lv.半大佬",
			"exp": 70,
			"color": "YellowGreen"
		},
		{
			"name": "Lv.大佬",
			"exp": 110,
			"color": "GoldenRod"
		},
		{
			"name": "Lv.顶级大佬",
			"exp": 160,
			"color": "DarkRed"
		},
		{
			"name": "Lv.世界大佬",
			"exp": 220,
			"color": "Crimson"
		},
		{
			"name": "Lv.传说",
			"exp": 380,
			"color": "Red"
		},
		{
			"name": "Lv.永恒传说",
			"exp": 9999,
			"color": "ForestGreen"
		}
	],
	"lv_null": [{
		"name": "Lv.神秘人",
		"color": "gray"
	}]
}

lv_exp是评论者有留下邮箱时的等级配置。

以如下配置为例


"name": "Lv.萌新",
"exp": 3,
"color": "Magenta"


name为等级名称。

exp如果为3则表示评论数小于等于3为萌新。

color定义了这个等级的色值。


lv_null是评论者没有留下邮箱时定义的名字和颜色。


JS

$(document).ready(function(e) {
    $.ajax({
		url:"<?php echo TEMPLATE_URL; ?>/lvList/lv.json",
		success:function(result){
        	var lvList = result.lv_exp;
			var lv_exp = $('.lv_exp');
			for(var i=0;i<lv_exp.length;i++){
				var num = lv_exp.eq(i).val();
				if(num != 'null'){
					var lvName = '';
					var lvColor='';
					var listCount = 0;
					for(var j=0;j<lvList.length;j++){
						if(parseFloat(num) <= lvList[j-listCount].exp){
							console.log(num);
							lvName = lvList[j-listCount].name;
							lvColor = lvList[j-listCount].color;
							break;
						}
					}
					$('.alv_body').eq(i).append('<div><span class="wikimoe_level_label" style="color:'+lvColor+';border-color:'+lvColor+'">'+lvName+'</span></div>');
				}else{
					var nullName = result.lv_null[0].name;
					var nullColor = result.lv_null[0].color;
					$('.alv_body').eq(i).append('<div><span class="wikimoe_level_label" style="color:'+nullColor+';border-color:'+nullColor+'">'+nullName+'</span></div>');
				}
			}
			
			$('.alv_body').fadeIn();
			
    	}
	});
});


就是循环一遍json数据然后添加到对应的元素内,这里的$('.alv_body')等元素要改成自己的元素。


CSS

/*等级*/
.alv_body{
	font-weight:bold;
	display:none;
	margin-top:5px;
	opacity: 0.6;
}
.wikimoe_level_label{
	border-style: solid;
    border-width: 1px;
    border-radius: 5px;
    padding: 0px 5px;
    display: inline-block;
	line-height: 20px;
    font-size: 12px;
}

样式其实可以无所谓,根据自己的情况进行更改。


最终效果:

donate.png

1210 x 50(蓝底).png

cloudcone