免插件帝国cms内置的ajax评分实现评分投票功能

 更新时间:2016年1月27日 12:11  点击:1632

信息投票评分已经很流行很通用了,几乎所有网站都有,但帝国CMS必未有好的解决办法。

但实现上帝国CMS已经有了基础功能,只是没有体现出来而已,本教程就是利用帝国CMS本身的评分实现这个功能


帝国cms评分投票功能实际已经内置ajax中了,竟然没有说明。下面奇芳阁分析下通过帝国cms内置的ajax评分代码实现评分投票功能!

首先在模板的head区内调用ajax.js文件,如果已经使用了dig功能则不必重复调用这个js了:

<script type="text/javascript" src="[!--news.url--]e/data/js/ajax.js"></script>

将下面的css样式复制到你原有的样式表文件中,当然也可以直接写在模板中:

<style>
.star-rating{
list-style:none;
margin: 0px;
padding:0px;
width: 150px;
height: 30px;
position: relative;
background: url(star_rating.gif) top left repeat-x;
}
.star-rating li{
padding:0px;
margin:0px;
/*\*/
float: left;
/* */
}
.star-rating li a{
display:block;
width:30px;
height: 30px;
text-decoration: none;
text-indent: -9000px;
z-index: 20;
position: absolute;
padding: 0px;
}
.star-rating li a:hover{
background: url(star_rating.gif) left center;
z-index: 2;
left: 0px;
}
.star-rating a.one-star{
left: 0px;
}
.star-rating a.one-star:hover{
width:30px;
}
.star-rating a.two-stars{
left:30px;
}
.star-rating a.two-stars:hover{
width: 60px;
}
.star-rating a.three-stars{
left: 60px;
}
.star-rating a.three-stars:hover{
width: 90px;
}
.star-rating a.four-stars{
left: 90px;
}
.star-rating a.four-stars:hover{
width: 120px;
}
.star-rating a.five-stars{
left: 120px;
}
.star-rating a.five-stars:hover{
width: 150px;
}
.star-rating li.current-rating{
background: url(star_rating.gif) left bottom;
position: absolute;
height: 30px;
width:90px;
display: block;
text-indent: -9000px;
z-index: 1;
}
</style>


下载下面的星级效果图片保存下来,注意图片名称改成:star_rating.gif,不过需要注意一下CSS中的图片路径修改成自己的实际路径。


在需要添加评分投票功能的地方添加以下代码

<span id="showpf"><script type="text/javascript" src="[!--news.url--]e/public/ViewClick/?classid=[!--classid--]&id=[!--id--]&down=3"></script>
</span>分
<ul class="star-rating">
<li class="current-rating"></li>
<li><a href="JavaScript:makeRequest('[!--news.url--]e/enews/?enews=AddInfoPfen&classid=[!--classid--]&id=[!--id--]&doajax=1&ajaxarea=showpf&fen=1','EchoReturnedText','GET','');" class="one-star">1</a></li>
<li><a href="JavaScript:makeRequest('[!--news.url--]e/enews/?enews=AddInfoPfen&classid=[!--classid--]&id=[!--id--]&doajax=1&ajaxarea=showpf&fen=2','EchoReturnedText','GET','');" class="two-stars">2</a></li>
<li><a href="JavaScript:makeRequest('[!--news.url--]e/enews/?enews=AddInfoPfen&classid=[!--classid--]&id=[!--id--]&doajax=1&ajaxarea=showpf&fen=3','EchoReturnedText','GET','');" class="three-stars">3</a></li>
<li><a href="JavaScript:makeRequest('[!--news.url--]e/enews/?enews=AddInfoPfen&classid=[!--classid--]&id=[!--id--]&doajax=1&ajaxarea=showpf&fen=4','EchoReturnedText','GET','');" class="four-stars">4</a></li>
<li><a href="JavaScript:makeRequest('[!--news.url--]e/enews/?enews=AddInfoPfen&classid=[!--classid--]&id=[!--id--]&doajax=1&ajaxarea=showpf&fen=5','EchoReturnedText','GET','');" class="five-stars">5</a></li>
</ul>


此时你会发现在提交评分时总是提示:您来自的连接不存在!主要是因为要使用评分功能的模型,还需要往模型数据表增加“infopfen”(评分数)和“infopfennum”(评分人数)两个字段,详细操作步骤如下:

后台>系统>管理数据表>管理字段>增加字段:

评分数字段:字段名填“infopfen”、字段标识填“评分数”、字段类型选“大数值型(INT)”,其他默认,点提交;

评分人数字段:字段名填“infopfennum”、字段标识填“评分人数”、字段类型选“大数值型(INT)”,其他默认,点提交;

两个字段增加后模型即可使用评分功能了,效果如下:

帝国cms实现评分投票功能 方法二:

同样我们也可以使用表单的方式实现评分投票功能,首先还是要往模型数据表增加“infopfen”(评分数)和“infopfennum”(评分人数)两个字段,详细操作步骤同上!

增加评分字段以后,在那个评论的模板中有两个表单,一个是评分用的,另一个是提交评论用的。

在第一个表单(评分用的),表单提交地址,就用官方默认的:/e/enews/index.php,不能改为/e/pl/doaction.php

在第二个表单(提交评论用的),才需要把 /e/enews/index.php改为/e/pl/doaction.php

具体效果如下:

帝国cms列表页调用评分平均数,并设置小数点的方法:

首先找到帝国cms文件中的 e\public\ViewClick,打开index.php文件,在52行左右找到以下代 码:

$shownum=$r[infopfennum]?round($r[infopfen]/$r[infopfennum]):0;

或者直接搜索 down==3,完整的代码是:

//评分数
elseif($down==3)
{
$r=$empire->fetch1("select infopfen,infopfennum from {$dbtbpre}ecms_".$cr['tbname']." where id='$id' limit 1");
$shownum=$r[infopfennum]?round($r[infopfen]/$r[infopfennum]):0;}
)

将上面代码中的绿色部分修改为:

$shownum=$r[infopfennum]?round($r[infopfen]/$r[infopfennum],1):0;


其中的,1表示保留一个小数点,以此类推。

然后在列表页的调用代码为:(下面的代码为实时调用,不需要人工刷新。)

<script src=[!--news.url--]e/public/ViewClick?classid=[!--classid--]&id=[!--id--]&down=3></script>


[!--infotagslink--]

相关文章

  • JS实现仿百度文库评分功能

    本文给大家分享基于js实现仿百度文库评分功能,代码简单易懂,非常不错,具有参考借鉴价值,需要的的朋友参考下吧...2017-01-16
  • 基于jquery实现彩色投票进度条代码解析

    这篇文章主要介绍了基于jquery实现彩色投票进度条代码解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-08-27
  • vue实现带小数点的星星评分

    这篇文章主要为大家详细介绍了vue实现带小数点的星星评分,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-18
  • PHP再线投票connect.php

    <?php /* **数据库连接 */ $connect = new PDO ("mysql:host=localhost;dbname=online","root","960515"); ?> < PHP (Hypertext...2016-11-25
  • JS实现拖动滚动条评分的效果代码分享

    本文给大家基于js实现拖动滚动条评分效果,在项目开发中经常可以用到的,大家可以更加需要适当的添加修改,对js评分效果感兴趣的朋友一起看看吧...2016-10-02
  • JavaScript实现简单的星星评分效果

    这篇文章主要为大家详细介绍了JavaScript实现简单的星星评分效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2017-05-22
  • 利用TaskManager爬取2万条代理IP实现自动投票功能

    话说某天心血来潮想到一个问题,朋友圈里面经常有人发投票链接,让帮忙给XX投票,以前呢会很自觉打开链接帮忙投一票。可是这种事做多了就会考虑能不能使用工具来进行投票呢,身为一名程序猿决定研究解决这个问题。感兴趣的朋友一起学习吧...2020-06-25
  • 基于jQuery实现仿搜狐辩论投票动画代码(附源码下载)

    这篇文章主要介绍了基于jQuery实现仿搜狐辩论投票动画代码 的相关资料,需要的朋友可以参考下...2016-02-21
  • JavaScript实现星级评分

    本文主要分享了JavaScript实现星级评分的实例代码,具有一定的参考价值,下面跟着小编一起来看下吧...2017-01-16
  • 无需数据库在线投票调查php代码

    这篇文章主要为大家详细介绍了无需数据库在线投票调查php代码...2016-07-29
  • php $HTTP_COOKIE_VARS 实例投票资料限制

    if ($http_cookie_vars["vote"]) { echo "<script>alert('您已经投过票了,请不要重复投票');history.back();</script>"; exit; } $vcount=$_post["vcount"]; $l...2016-11-25
  • Vue动态实现评分效果

    这篇文章主要为大家详细介绍了Vue动态实现评分效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2017-05-27
  • 简单的PHP实现网络刷投票程序

    PHP投票程序在做活动时会用到了,我们今天就为各位朋友分享一个PHP投票程序,有需要了解的同学不防一起来看看吧. PHP刷投票,让你高居榜首!本文附上刷票方法和防御策略...2016-11-25
  • 基于C#编写经理评分系统

    最近接了这样一个项目,要求使用c#编写经理评分系统,需求,要显示员工信息,实现项目经理给员工评分功能,今天小编分步骤给大家介绍,需要的的朋友参考下...2020-06-25
  • js实现商城星星评分的效果

    这篇文章主要介绍了js实现商城星星评分的效果,很多网站都有如下图这样的星星打分效果,今天就看下用js怎么实现打分效果,需要的朋友可以参考下...2016-01-02
  • 免插件帝国cms内置的ajax评分实现评分投票功能

    信息投票评分已经很流行很通用了,几乎所有网站都有,但帝国CMS必未有好的解决办法。但实现上帝国CMS已经有了基础功能,只是没有体现出来而已,本教程就是利用帝国CMS本身的评分实...2016-01-27
  • php简单 在线投票系统 源码下载,

    php简单 在线投票系统 源码下载,上次要和你一家公合作他们说要我写一个简单的投票系统,但是每一个IP只能投一次,好了下面就是我写的一个最最简单的投票系统了,是用php...2016-11-25