前面2章我们介绍了WordPress主题激活后自动新建数据表以及插入和调用函数,这些只是把用户的点击投票记入到数据库中,并没有在前台显示出来。要想在前台的文章页面显示用户的投票数(如下图),我们还要为前台页面添加调用。就一起来看看吧。
第一,添加前台调用代码 。
在主题的single.php文件的loop循环中添加如下代码:
<span class="vote_up" id="<?php echo 'vote_up'.$post->ID;?>"> <a href="javascript:void(0);" rel="<?php echo 'up_',$post->ID;?>"> <span id="<?php echo 'vup'.$post->ID;?>"> <?php echo get_post_vote($post->ID,'up');?> </span> </a> 顶 </span> <span class="vote_down" id="<?php echo 'vote_down'.$post->ID;?>"> <a href="javascript:void(0);" rel="<?php echo 'down_'.$post->ID;?>"> <span id="<?php echo 'vdown'.$post->ID;?>"> <?php echo get_post_vote($post->ID,'down');?> </span> </a> 踩 </span>
这2段代码,一个是调用用户“顶”的数据,一个是调用用户的“踩”的数据。这里就用到了我们上一章添加的调用函数get_post_vote()。
[baidu2]
第二、添加JS代码。
在主题文件夹下的js文件夹里添加一个dingcai.js 的JS文件,在这个dingcai.js 文件中添加如下JS代码:
/** 获取Cookie , name cookie名称 */ function getCookie(name) { var start = document.cookie.indexOf( name + "=" ); var len = start + name.length + 1; if ( ( !start ) && ( name != document.cookie.substring( 0, name.length ) ) ) return null; if ( start == -1 ) return null; var end = document.cookie.indexOf( ';', len ); if ( end == -1 ) end = document.cookie.length; return unescape( document.cookie.substring( len, end ) ); } function ashu_isCookieEnable() { var today = new Date(); today.setTime( today.getTime() ); var expires_date = new Date( today.getTime() + (1000 * 60) ); document.cookie = 'ashu_cookie_test=test;expires=' + expires_date.toGMTString() + ';path=/'; var cookieEnable = (getCookie('ashu_cookie_test') == 'test') ? true : false; //document.cookie = 'ludou_cookie_test=;expires=Fri, 3 Aug 2001 20:47:11 UTC;path=/'; return cookieEnable; } jQuery(document).ready(function($) { var ashu_token = 1; $('.vote_up a').click(function(){ //检查浏览器是否启用cookie功能 if( !ashu_isCookieEnable() ) { alert("很抱歉,您不能给本文投票!"); return; } if( ashu_token != 1 ) { alert("您的鼠标点得也太快了吧?!"); return false; } ashu_token = 0; //获取投票a标签中的rel值 var full_info = $(this).attr( 'rel' ); var arr_param = full_info.split( '_' ); //以字符"_"分割 //发起ajax $.ajax({ url:ajax_url, //ajax地址 type:'POST', //请求的参数包括action rating postid三项 data:'action=vote_post&rating=' + arr_param[ 0 ] + '&postid=' + arr_param[ 1 ], //返回数据 success:function(results){ if(results=='n'){ alert('评价失败'); ashu_token = 1; } if (results=='y'){ //如果成功,给前台数据加1 var upd_vd = 'vup' + arr_param[ 1 ]; $('#'+upd_vd).text(parseInt($("#"+upd_vd).text())+1); ashu_token = 1; } if (results=='h'){ ashu_token = 1; alert('已经发表过评价了'); } if (results=='e'){ ashu_token = 1; alert('评价失败'); } } }); }); $('.vote_down a').click(function(){ if( !ashu_isCookieEnable() ) { alert("很抱歉,您不能给本文投票!"); return; } if(ashu_token != 1) { alert("您的鼠标点得也太快了吧?!"); return false; } ashu_token = 0; var full_info = $(this).attr( 'rel' ); var arr_param = full_info.split( '_' ); $.ajax({ url:ajax_url, type:'POST', data:'action=vote_post&rating=' + arr_param[ 0 ] + '&postid=' + arr_param[ 1 ], success:function(results){ if(results=='n'){ alert('评价失败'); ashu_token = 1; } if (results=='y'){ var upd_vd = 'vdown' + arr_param[ 1 ]; $("#"+upd_vd).text(parseInt($("#"+upd_vd).text())+1); ashu_token = 1; } if (results=='h'){ ashu_token = 1; alert('已经发表过评价了'); } if (results=='e'){ ashu_token = 1; alert('发生未知错误'); } } }); }); });
这段JS代码会获取用户点击的cookie。
第三、添加JS调用代码。
在主题的header.php文件的</head>标签前添加JS调用代码,如下:
<script src="<?php echo get_template_directory_uri();?>/js/jquery-1.4.4.js"></script> <script type="text/javascript">var ajax_url = '<?php echo admin_url(); ?>/admin-ajax.php';</script> <script src="<?php echo get_template_directory_uri();?>/js/dingcai.js"></script>
这里的jquery-1.4.4.js文件可以到网上下载一个,版本不限,可以是jquery的任意版本,如jquery.js、jquery.1.7.2.js 等。
第四、添加后台处理函数。
以前我们的ajax请求地址直接是网站页码地址,即调用另一个php文件来处理的。而此处我们的ajax请求地址是类似wanlimm.com/wp-admin/admin-ajax.php, 即调用wordpress自带的php文件,使用这个地址来处理ajax请求,需要在请求中有action参数,然后在functions.php文件中添加如下php代码,即可处理ajax的请求(注:执行完请求输出内容之后,添加die函数结束)。
add_action("wp_ajax_vote_post", "add_votes_options"); add_action("wp_ajax_nopriv_vote_post", "add_votes_options"); function add_votes_options() { if( isset($_POST['action']) && ($_POST['action'] == 'vote_post') ){ $postid = (int)$_POST['postid']; if( !$postid ){ echo 'e'; //输出error die(0); } //cookie中是否已经存在投票数据 $voted = $_COOKIE["smzdm_voted_".$postid]; if( $voted ){ echo 'h'; //输出have die(0); } $ip = $_SERVER['REMOTE_ADDR'];//ip $rating = $_POST['rating']; //投票内容 //判断用户是否登录 if( is_user_logged_in() ){ global $wpdb, $current_user; get_currentuserinfo(); $uid = $current_user->ID; }else{ $uid=''; } if($rating=='up'){ $rating='up'; }else{ $rating='down'; } //添加数据 $voted = add_vote($postid,$uid,$ip,$rating); if($voted=='y'){ //设置cookie setcookie("ashu_voted_" . $postid,$rating, time() + 3000000, '/'); echo 'y';//输出yes die(0); } if($voted=='h'){ //设置cookie setcookie("ashu_voted_" . $postid,$rating, time() + 3000000, '/'); echo 'h'; die(0); } if($voted=='e'){ echo 'n';//输出no die(0); } }else{ echo 'e';//输出eroor } die(0); }
通过上面这几步,我们就完成了WordPress主题添加顶踩投票功能,效果如上图。要想达到上图的效果,还要为顶踩添加CSS样式代码。
第五、CSS样式代码:
/* 文章顶踩 */ .vote_up{ float:right; background:no-repeat url("/wp-content/themes/wanlimm/images/ding.gif") 0 50%; } .vote_up:hover{ background:no-repeat url("/wp-content/themes/wanlimm/images/ding.gif"); } .vote_up a { padding-left:16px; color:#FF0000 !important; font-weight:600; } .vote_up a:hover { color:#3300CC !important; text-decoration:none; } .vote_down{ float:right; background:no-repeat url("/wp-content/themes/wanlimm/images/cai.gif") 0 50%;; margin:0 20px;} .vote_down:hover{ background:no-repeat url("/wp-content/themes/wanlimm/images/cai.gif"); } .vote_down a { padding-left:18px; color:#FF0000 !important; font-weight:600; } .vote_down a:hover { color:#3300CC !important; text-decoration:none; }
黄飞鸿热灸馆加盟项目,整店输出模式,专业热灸加盟技术培训,一个专业做中医养生的连锁品牌。源自黄飞鸿的嫡孙继承了黄飞鸿先生的遗志,多年来一直坚定不移地致力于大健康产业,并创立了黄飞鸿热灸馆;主要业务服务有黄飞鸿热炙理疗,黄飞鸿热炙理疗馆加盟,黄飞鸿理疗馆,黄飞鸿热灸,黄飞鸿养生馆加盟,黄飞鸿养生馆加盟,黄飞鸿热灸馆,黄飞鸿热灸体验馆,黄飞鸿热灸馆加盟,黄飞鸿热灸理疗馆,黄飞鸿热灸膏
TokenPocket钱包支持数字资产存储。每天走势掌握,功能强大,在线管理数字货币,超多币种推送,多种交易方式,私钥用户自持且轻便易用的以太坊轻钱包。tp支持多资产类型,如:TokenPocket、ETH、QTUM、AE、BTM等大多数主流币种,让tp钱包更好地融入你的生活。
浙江丰安齿轮股份有限公司成立于1999年1月,是一家集开发、设计、制造、销售服务为一体的齿轮专业制造商,占地面积93亩,总资产3亿余元,主要设备400余台。公司于2017年1月在“新三板”挂牌,股票代码870508。公司以精湛的技术、过硬的品质、优良的服务来赢得客户满意,努力打造业界一流齿轮制造企业。
我公司系高新技术企业,专业从事空气净化的产品生产、工程服务及洁净技术的应用与研究,提供从空调处理设备、空调自动控制系统到洁净室系统全面服务,为各类工业用空气处理提供一揽子解决方案及交钥匙工程。 产品遍及全国几十个省市,并出口至巴基斯坦、伊朗等国家。我公司在化纤工艺空调领域精耕细作20余年,2001年进入医药、电子等行业的净化空调设备。 本公司拥有雄厚的技术力量和良好的售后服务,承接系统设计、技术咨询、产品制造、技术改造等项目。设备采用工业计算机、可编程序(PLC)控制器、数字直接控制器(DDC)等智能控制器,可实现节能显著的运行系统(节能策略有:新回风的焓值控制、二次回风、送风机的变频调速;非露点控制方案在过渡季节节能50%。在化纤纺丝行业采用的节能措施,同样可在医药行业的净化空调上使用);采用与国际惯例接轨的CAD设计和质量保证体系。
双友科技为客户提供直缝埋弧焊管生产线、直缝高频焊管生产线、螺旋埋弧焊管生产线、钢管内外防腐生产线,石油套管生产线,热处理生产线以及其他系列产品。同时公司致力于为高端铝业服务,为客户提供更为高效,节能,环保,安全的铸铝生产线及其相关设备。公司积极推进国际化发展战略,逐步实现品牌、市场、团队、技术、管理与国际化标准接轨。此外,公司与众多国际知名管材和铝材生产商建立了紧密的合作关系,在中东设立了海外分支机构。双友科技旨在将中国的高端制造带给世界。
南京三超新材料股份有限公司成立于1999年1月,注册资本9360万元,2017年4月21日,在深圳创业板成功挂牌上市。占地面积130亩,建筑面积约86,000平方米。是一家专业从事金刚石、立方氮化硼工具的研发、生产与销售的高新技术企业,现拥有金刚石砂轮和金刚石线两大类相互协同的产品系列,应用于硅、蓝宝石、石英、铁氧体、钕铁硼、陶瓷、玻璃、硬质合金等硬脆材料的精密切割、磨削与抛光。 公司自成立以来,始终坚持"以人为本、技术优先"的发展理念,先后引入多名外籍专家,并在日本成立了超硬材料工具的专业研发机构。经过多年研发,公司成为国内最早通过自主研发掌握金刚线制造的相关技术,成功实现产业化的企业之一,并且打破了国外企业的技术垄断,与新研发成功的硅片背面减薄砂轮、硅片倒角砂轮、PAD修整器等产品,为半导体及太阳能光伏行业提供了优质的金刚石工具,并凭借良好的品质与高性价比,赢得了众多实力用户认可,在国内形成了较高的行业影响力。