会员登录 | 注册

来去留技术信息资源

来去留技术信息资源
来去留网 > 去看信息 > 程序系统 > cms评论系统增加表情、QQ秀、ajax无刷新功能

cms评论系统增加表情、QQ秀、ajax无刷新功能

2012-05-08 20:56来源:来去留发布者:laiquliu 查看:
cms评论系统增加表情、QQ秀、ajax无刷新功能

最近用cms做了个站,觉得的评论系统不太好用,就自己对它进行了一番改造,增加了表情、QQ秀、ajax无刷新等功能。国内有一大批站长用的是dede,今天我先分享下怎样为评论加上表情。

首先大家思考一下怎样才能让dede评论里面显示表情图片?直接内容里面写<img src="********" />肯定是不行的,dede会在保存评论前把它转换成普通的文本。我们要的是要保证以后能顺利升级,所以尽量不改dede的系统文件。

现在换个思路,看看那些论坛,它们添加表情的时候都是添加的一个表情标记,发帖后就变成表情图片了。看来是在保存帖子的时候对表情标记做了转换。咱们也来依葫芦画瓢。

先找一个表情图片传到服务器上,假设是在http://www.yingsheji.com/01.gif,表情标记假设为[em01],现在我只要让dede在保存评论的时候把[em01]转换成<img src="http://www.yingsheji.com/01.gif" />就行了。

这里又涉及到2个问题,是先转换之后再保存,还是直接保存,显示的时候再转换?

如果转换之后再保存,也就是说你的数据库里存的是<img src="http://www.yingsheji.com/01.gif" />,这个链接就固定了,你的表情目录就不能变了,而且这必需改dede的系统文件才行。

如果是显示的时候再转换,那你的数据库里就保存的是[em01]这样的表情标记,显示的时候根据规则进行转换,非常灵活,而且不用改dede的系统文件,只需要改就行了。只是显示一次就要转换一次,会增加一点儿系统负担。

我们用第二种方法。打开/plus/feedback_templet.htm,这个是dede的评论系统模板,我们发现它里面是可以直接写php代码的,<?php echo $row['msg']?>这里就是输出的评论内容。先把它改成<?php echo convertem($row['msg']) ?>。

convertem()就是转换表情的方法,就是用它把[em01]转换成<img>标记,现在我们要给这个方法写点内容,让它按我们的意思来转换。

还是这个文件,在顶部添加
<?php
function convertem($message){
$message = str_replace('[em01]','<img src="http://www.yingsheji.com/01.gif" />', $message );
return $message;
}
?>

这里的str_replace可以进行替换操作,比如str_replace(A,B,C)大概意思就是把C里面的A替换成B。
所以我们用convertem($row['msg'])就能把$row['msg']里面的[em01]给替换了。

现在你在评论里输入[em01],发表,应该能看到显示的图片了。不过这还没完,你总不可能让用户也要输入代码才能发表情吧?所以你还得找个合适的地方,加上
<img src="http://www.www.yingsheji.com/01.gif" onclick="javascript:document.getElementById('msg').value+='[em01]';" />

用户点击这个图片后,会自动在评论框里加上[em01]。

这就大功告成了,其实从头到尾只改了feedback_templet.htm这个模板就实现了表情功能。 (责任编辑:laiquliu)

关注技术,信息,资源,扫描来去留网微信二维码交流。

来去留我李俊

搜索

------分隔线----------------------------
相关栏目

热点推荐
来去留技术信息资源
来去留网为您提供平台咨询交流学习方法及各类热门技术;电器,服装,保健,行业快讯等二十几个类别的资讯