导航

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

侧边栏
热门文章
1推文
飞猪说这一班飞机没有餐食,结果特意吃饱了上飞机,结果突然端出来量大管饱的飞机餐我都懵了。 这是一条来自高空的推文。
热度
519
2推文
酒店免费把我的双人床升级成了2张双人床!空间是大了许多,但是1个住有些浪费呀。
热度
466
3页面
程序员老黄历&求签
热度
351
4推文
抵达台北开始6天5夜的台湾之旅!
热度
180
5推文
最新一集的《mono女孩》里的《摇曳露营△》彩蛋真的太多啦!
热度
104
6博文
《孤独摇滚》圣地巡礼——下北泽&下北泽咖喱节2023
热度
104
7推文
又到了日本5月黄金周的时期了。 去年的黄金周去了秩父和长瀞,今年的黄金周决定去一个远一点的地方,去一个不在日本国内的地方。
热度
91
8博文
探访《蜡笔小新》老家——春日部游记
热度
91
9推文
《苍之彼方的四重奏 10th Anniversary Box》预计2025年3月28日发售,售价为含税19800日元(约922人民币)。 其中如果购买了sprite LIMITED EDITION或FILMIC EDITION版的话,还有机会将名字(猜测)登在结尾字幕中! sprite LIMITED EDITION版售价39800日元(约1853人民币),FILMIC EDITION版售价149800日元(约6973人民币)。 感觉如果花1853人民币就能把"维基萌"打在游戏结尾字幕中也似乎不错的样子?🤔 《苍之彼方的四重奏 10th Anniversary Box》专题页面:https://sprite.net/aokana/10thanniversary/box
热度
65
10页面
友链
热度
65
最新评论
广树管理员
2025-04-29 22:48
@夕阳西下:哈哈哈,是这么操作的
夕阳西下
2025-04-29 22:46
一个睡觉,另外一个放衣服
广树管理员
2025-04-29 21:37
@Zrzzz:期待第四季的摇曳露营吧
广树管理员
2025-04-29 21:37
@mikusa:哈哈哈,确实有点出戏
广树管理员
2025-04-29 21:37
@ZeroCounter:是吗?真的被飞机的量吓到了。2块面包,1盒咖喱米饭,1碗沙拉,1碗水果,1杯茶,1杯水。
攻略中
星空列车与白的旅行
暂无评分
Steam星空列车与白的旅行
2025年2月22日 22时 ~ 攻略中
已累计游玩2个月6天
乘坐的列车,划破夜空,飞驰在星空之下,令人心旷神怡——这可真是场超值之旅。舒爽夜风吹拂下的随心独旅中,我邂逅了随性的乘客,可人怜爱的乘务员。以及……猫耳少女?这场旅行,究竟会在她身上,留下了些什么呢?
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