热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

PHP及其微信开发(学习之路六)

经过一个星期的学习,时不时的抽点时间不断的完成微信公众号的开发,在这里,自己又添加了一个功能,即是用户的评论功能和做题的排位模式(不熟悉的朋友可以看看之前我的博客)。在接下来,我就对这两

       经过一个星期的学习,时不时的抽点时间不断的完成微信公众号的开发,在这里,自己又添加了一个功能,即是用户的评论功能和做题的排位模式(不熟悉的朋友可以看看之前我的博客)。在接下来,我就对这两个功能进行一下介绍,也为需要的朋友提供点帮助。

      首先,介绍下我的评论功能。。下面就是简单的界面显示:

              


      在上图(1)中,就是最开始用户的一个界面:

      很简单,当用户答完一个题目,进入到解析环节的时候,就可以对该题进行评论了,当评论完之后就会显示出来,这也就是从(1)到(2)的显示效果了。

      介绍一下这个的原理:

     (1)就是当用户点击评论查看/ 评论的按钮的时候,就会把下面的文本框显示出来,当再一次点击之后,下面的标签按钮就会隐藏起来。这其实就是运用了标签按钮的一个属性和简答的JS代码就可以完成了,下面就是代码,看了就会明白了,就不需要我多描述了。

   

      这就是显示的标签,然后下面控制显示的JS如下所示:

     

 function commentTextArea()  //在这里添加判断是否评论成功的代码
{
var userName = document.getElementById("addcomment").value;
  if (JTrim(userName) !=="")
  {
     document.commitcontent.submit();
alert("评论成功!");
  }
else{
alert("什么都没留下,咋评论呢?");
}
}
function clearText() { //取消当前编辑的评论
document.getElementById("addcomment").value = "";
alert("评论取消");
}
function showbutton(){ //显示隐藏的按钮
if(document.getElementById("oid").style.display)
{
document.getElementById("oid").style.display='';
}
else{
document.getElementById("oid").style.display='none';
}
}
function JTrim(s) //检测是否只输入了空格
{
return s.replace(/(^\s*)|(\s*$)/g, "");
}
      相信只有一点JS的基础就能够看懂的,,所以我就不啰嗦啦。。

     下面家讲解一下如何动态的生成所评论的条数,因为这界面的显示是根据用户的评论数来生成的,所以这是一个动态的过程,当然用Ajax是比较简单的能实现,但是下面介绍一下如何用PHP代码就实现。(其实这和我之前的那学生签到,显示开启签到的人数的方法是一样的)下面是代码:

    

                 function GenerateRadioGroup($name,$info)
{
$html="";
for($i=0;$i {
$username=$info[$i]['student_name'];
$cOntent=$info[$i]['user_comment'];

$html.='

';
$html.=$username.":".$content;
$html.='


';
}
return $html;
}
$html = GenerateRadioGroup("comment",$cominfo);
echo $html;
?>
简单讲解一下其中的参数的含义,其中的comment是用来标记给标签的一个统一的名字,因为都是关于评论的

,所以名字一样比较好处理。另外就是$cominfo,这就是从数据库中得到的一个用户评论的内容和条数等等信息的一个数组,通过这个就自然而然的可以拿到自己所想到的信息内容来提供显示了。下面是我的处理:

     

//得到评论的内容
$getcomment=new CommentData();
$cominfo=$getcomment::getAllComment($_SESSION['id']); //得到所有的评论行信息
         好了,关于评论我就做了简单的处理,其实还有很多好玩的,比如还可以添加对某个用户的评论再进行评论显示,其实这也很简单,就是拿到数据库里面的内容,在评论用户的右边进行显示就好了。如果你们想有很好的方式,都可以的。。

(二)介绍一下关于竞速排名的功能的步骤

    这个功能就是在用户做完一组题目(我这设置的是20个为一组,当然这个可以设置成用户自己想要的都可以,就只是变成了一个动态的而已,然后在处理排名的时候需要相对应的进行修改就可以了)后,然后按照胜率进行排序,当然如果胜率相同,就再按照时间的顺序进行排名,这也是很普通的排名的方法,如果你们有更好的排名方法都可以根据自己的需要来进行改变的。这都是小事,下面就是我的界面的显示:

   

   哈哈。界面丑了点,大家别介意,但是那自行车可是动态的哦。。还不错。。。。能看就好啦。。。。

   介绍一下原理:

   先把代码贴出来:

      

    session_start();
require_once '../Utils/MyDataBase.php';
require_once '../loaddata/RankListData.php';
$queryInfo=new RankListData();
$allStudentRankList=$queryInfo::quertAllRankInfo(); //得到所有的排名数据库中的信息
$number=0;
while(true){
if($allStudentRankList[$number]['student_openid']==$_SESSION['useropenid']){
$nowname=$allStudentRankList[$number]['student_name'];
$nowcurreny=$allStudentRankList[$number]['question_accuracy'];
$number++;
break;
}
else{
$number++;
}
}
?>
这就是得到所要显示的排名信息的内容了,这就是得到数据库中的内容而已,并没有什么技术在里面的,在while语句里面就是得到用户本身的信息,并且显示在第一排,这样就达到方便用户查看自己的排名了,做到人性化效果。

  另外就是一个动态的生成排名标签了,这和上面提到的评论的效果都差不多的,所以大家可以看看上面代码就好了。

  还是贴出来好了:

        function GenerateRadioGroup($name,$info)
{
$html="";
for($i=0;$i {
$username=$info[$i]['student_name'];
$rightrank=$info[$i]['question_accuracy'];
$cishu=$i+1;
$html.='

'."第".$cishu."名:";
$html.=$username.'          '."正确率".$rightrank."%";
$html.='
';
}
return $html;
}
$html = GenerateRadioGroup("ranklist",$allStudentRankList);
echo $html;
?>

好了,这样就差不多把大部分的效果实现了,还有个就是用户做题所花费的时间怎么算的,很简单的,就是当用户开始的时候,记录下系统的时间,得到一个时间戳,然后再答完最后一题的时间又记录转换成一个时间戳,这样相减就得到了用户的做题时间:(PHP里面有个time() 的函数,就可以实现)

 $_SESSION['finishtime']=time()-$_SESSION['starttime'];



这就是自己随便做的一些功能开发了,自己还会不断的想到一些功能就进行开发,然后记录下来,方便需要的朋友。。

很开心,这个星期没有白费,至少又学到了很多,继续努力,小伙伴们,一起加油吧!!!!!!!!!!!!!!!!!!



推荐阅读
  • 开机自启动的几种方式
    0x01快速自启动目录快速启动目录自启动方式源于Windows中的一个目录,这个目录一般叫启动或者Startup。位于该目录下的PE文件会在开机后进行自启动 ... [详细]
  • MySQL Decimal 类型的最大值解析及其在数据处理中的应用艺术
    在关系型数据库中,表的设计与SQL语句的编写对性能的影响至关重要,甚至可占到90%以上。本文将重点探讨MySQL中Decimal类型的最大值及其在数据处理中的应用技巧,通过实例分析和优化建议,帮助读者深入理解并掌握这一重要知识点。 ... [详细]
  • 在使用 Cacti 进行监控时,发现已运行的转码机未产生流量,导致 Cacti 监控界面显示该转码机处于宕机状态。进一步检查 Cacti 日志,发现数据库中存在 SQL 查询失败的问题,错误代码为 145。此问题可能是由于数据库表损坏或索引失效所致,建议对相关表进行修复操作以恢复监控功能。 ... [详细]
  • 本文介绍了如何利用Struts1框架构建一个简易的四则运算计算器。通过采用DispatchAction来处理不同类型的计算请求,并使用动态Form来优化开发流程,确保代码的简洁性和可维护性。同时,系统提供了用户友好的错误提示,以增强用户体验。 ... [详细]
  • 在 Ubuntu 中遇到 Samba 服务器故障时,尝试卸载并重新安装 Samba 发现配置文件未重新生成。本文介绍了解决该问题的方法。 ... [详细]
  • php更新数据库字段的函数是,php更新数据库字段的函数是 ... [详细]
  • 本文讨论了在进行 MySQL 数据迁移过程中遇到的所有 .frm 文件报错的问题,并提供了详细的解决方案和建议。 ... [详细]
  • 本文详细介绍了MySQL数据库的基础语法与核心操作,涵盖从基础概念到具体应用的多个方面。首先,文章从基础知识入手,逐步深入到创建和修改数据表的操作。接着,详细讲解了如何进行数据的插入、更新与删除。在查询部分,不仅介绍了DISTINCT和LIMIT的使用方法,还探讨了排序、过滤和通配符的应用。此外,文章还涵盖了计算字段以及多种函数的使用,包括文本处理、日期和时间处理及数值处理等。通过这些内容,读者可以全面掌握MySQL数据库的核心操作技巧。 ... [详细]
  • 本文详细介绍了 InfluxDB、collectd 和 Grafana 的安装与配置流程。首先,按照启动顺序依次安装并配置 InfluxDB、collectd 和 Grafana。InfluxDB 作为时序数据库,用于存储时间序列数据;collectd 负责数据的采集与传输;Grafana 则用于数据的可视化展示。文中提供了 collectd 的官方文档链接,便于用户参考和进一步了解其配置选项。通过本指南,读者可以轻松搭建一个高效的数据监控系统。 ... [详细]
  • 本文介绍了如何使用 Node.js 和 Express(4.x 及以上版本)构建高效的文件上传功能。通过引入 `multer` 中间件,可以轻松实现文件上传。首先,需要通过 `npm install multer` 安装该中间件。接着,在 Express 应用中配置 `multer`,以处理多部分表单数据。本文详细讲解了 `multer` 的基本用法和高级配置,帮助开发者快速搭建稳定可靠的文件上传服务。 ... [详细]
  • 在PHP中如何正确调用JavaScript变量及定义PHP变量的方法详解 ... [详细]
  • 2.2 组件间父子通信机制详解
    2.2 组件间父子通信机制详解 ... [详细]
  • 您的数据库配置是否安全?DBSAT工具助您一臂之力!
    本文探讨了Oracle提供的免费工具DBSAT,该工具能够有效协助用户检测和优化数据库配置的安全性。通过全面的分析和报告,DBSAT帮助用户识别潜在的安全漏洞,并提供针对性的改进建议,确保数据库系统的稳定性和安全性。 ... [详细]
  • 基于Net Core 3.0与Web API的前后端分离开发:Vue.js在前端的应用
    本文介绍了如何使用Net Core 3.0和Web API进行前后端分离开发,并重点探讨了Vue.js在前端的应用。后端采用MySQL数据库和EF Core框架进行数据操作,开发环境为Windows 10和Visual Studio 2019,MySQL服务器版本为8.0.16。文章详细描述了API项目的创建过程、启动步骤以及必要的插件安装,为开发者提供了一套完整的开发指南。 ... [详细]
  • 使用种子数据在Asp.NET Core 3.0 Web API迁移过程中写入数据库的详细步骤
    本文详细阐述了如何在Asp.NET Core 3.0 Web API的迁移过程中利用种子数据将信息写入数据库的具体步骤。对于开发人员而言,掌握这一技术能够显著提高数据初始化的效率和准确性。文章不仅提供了详细的代码示例,还深入解析了每个步骤背后的原理,帮助读者更好地理解和应用这一方法。 ... [详细]
author-avatar
狂风
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有