登录  /   注册
  • 首页

  • PHP培训

  • 视频教程

    视频课程 直播课程 精品课
  • 学习路径

    入门教程 独孤九贱 玉女心经 天龙八部 趣味闯关
  • 资源下载

    源码市场 工具下载 在线工具 手册下载 电子课件 js特效 网站源码 网站素材 类库下载
  • 技术文章

    前端开发 后端开发 数据库 php框架 每日编程
  • 社区

    问答 博客 文章 专题
  • 微信公众号

    扫码关注官方订阅号

  • 编程词典 APP下载 源码市场
首页 > web前端 > js教程 > 正文

js实现五星评价功能的实例

高洛峰
发布: 2017-03-12 14:33:24
原创
3409人浏览过

本文主要介绍了 js实现五星评价功能和印象评价功能的实例,具有很好的参考价值。下面跟着小编一起来看下吧

效果图:

201738154306911.png

代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>五星评价</title>
  <style>
    @font-face {
      font-family: &#39;iconfont&#39;; /* project id 247957 */
      src: url(&#39;//at.alicdn.com/t/font_wkv6intmx8cnxw29.eot&#39;);
      src: url(&#39;//at.alicdn.com/t/font_wkv6intmx8cnxw29.eot?#iefix&#39;) format(&#39;embedded-opentype&#39;),
      url(&#39;//at.alicdn.com/t/font_wkv6intmx8cnxw29.woff&#39;) format(&#39;woff&#39;),
      url(&#39;//at.alicdn.com/t/font_wkv6intmx8cnxw29.ttf&#39;) format(&#39;truetype&#39;),
      url(&#39;//at.alicdn.com/t/font_wkv6intmx8cnxw29.svg#iconfont&#39;) format(&#39;svg&#39;);
    }
    .iconfont {
      font-family:"iconfont" !important;
      font-size:16px;
      font-style:normal;
      -webkit-font-smoothing: antialiased;
      -webkit-text-stroke-width: 0.2px;
      -moz-osx-font-smoothing: grayscale;
    }
    body{
      font-family: "microsoft yahei";
    }
    ul,li{
      list-style: none;
      padding:0;
      margin:0;
    }
    a{
      text-decoration: none;
    }
    .clearfix:after {
      content: ".";
      display: block;
      height: 0;
      clear: both;
      visibility: hidden;
    }
    .order-evaluation {
      width: 827px;
      border: 2px solid #E84E40;
      background: #fff;
      z-index: 200;
      margin:50px auto;
    }
    .order-evaluation{
      padding:22px;
    }
    .order-evaluation h4{
      font-size:18px;
      color:#333333;
      padding-bottom:20px;
      border-bottom:1px dashed #dbdbdb;
    }
    .order-evaluation p{
      font-size:14px;
      color:#999;
      line-height:45px;
      margin-bottom:0;
    }
    .order-evaluation .order-evaluation-text{
      font-size:16px;
      color:#333;
      line-height:40px;
      width:809px;
      padding-left:15px;
      background:#f3f3f3;
      margin-bottom:25px;
      margin-top:20px;
    }
    .order-evaluation-checkbox ul li{
      width:142px;
      height:43px;
      border:1px solid #e8e8e8;
      text-align: center;
      background: #fff;
      font-size:14px;
      color:#333333;
      line-height:43px;
      margin-right:25px;
      margin-bottom:25px;
      float:left;
      cursor: pointer;
      overflow: hidden;
      position:relative;
    }
    .order-evaluation-checkbox ul li.checked i{
      display: block;
    }
    .order-evaluation-checkbox ul li.checked{
      border:1px solid #e84c3d;
    }
    .order-evaluation .order-evaluation-textarea{
      position:relative;
      width: 784px;
      height: 210px;
    }
    .order-evaluation .order-evaluation-textarea textarea{
      width:793px;
      height:178px;
      border:1px solid #e8e8e8;
      position:absolute;
      top:0;
      left:0;
      line-height:22px;
      padding:15px;
      color:#666;
    }
    .order-evaluation .order-evaluation-textarea span{
      position:absolute;
      bottom:10px;
      font-size:12px;
      color:#999;
      right:10px;
    }
    .order-evaluation .order-evaluation-textarea span em{
      color:#e84c3d;
    }
    .order-evaluation>a{
      width:154px;
      height:48px;
      border-radius: 6px;
      display: block;
      text-align: center;
      line-height:48px;
      background:#f36a5a;
      float:right;
      margin-top:20px;
      color:#fff;
      font-size:14px;
    }
    .order-evaluation-checkbox ul li i {
      display: none;
      color: #e84c3d;
      position: absolute;
      right: -4px;
      bottom: -14px;
      font-size: 20px;
    }
    .order-evaluation>a:hover{
      background: #e84c3d;
    }
    .block li label,.con span{ font-size: 18px; margin-right: 20px; line-height: 23px;}
    .block li span{display: inline-block; vertical-align: middle; cursor: pointer;}
    .block li span img{margin-right: -5px; }
    .level{color:#e84c3d;font-size:16px;margin-left:15px;position: relative;top: 3px;}
    .dmlei_tishi_info{
      height:70px;border-radius: 10px;background: rgba(0,0,0,0.5);font-size:18px;color:#fff;text-align: center;line-height: 70px;position:fixed;
      left: 48%;
      display: none;
      margin-left: -128px;
      top: 40%;
      margin-top: -35px;
      padding: 0 15px;
      z-index: 1000;
    }
  </style>
</head>
<body>
<p class="order-evaluation clearfix">
  <h4>给“新闻订单”的评价</h4>
  <p>请严肃认真对待此次评价哦!您的评价对我们真的真的非常重要!</p>
  <p class="block">
    <ul>
      <li data-default-index="0">
            <span>
              <img  src="http://7xnlea.com2.z0.glb.qiniucdn.com/x1.png" alt="js实现五星评价功能的实例" >
              <img  src="http://7xnlea.com2.z0.glb.qiniucdn.com/x1.png" alt="js实现五星评价功能的实例" >
              <img  src="http://7xnlea.com2.z0.glb.qiniucdn.com/x1.png" alt="js实现五星评价功能的实例" >
              <img  src="http://7xnlea.com2.z0.glb.qiniucdn.com/x1.png" alt="js实现五星评价功能的实例" >
              <img  src="http://7xnlea.com2.z0.glb.qiniucdn.com/x1.png" alt="js实现五星评价功能的实例" >
            </span>
        <em class="level"></em>
      </li>
    </ul>
  </p>
  <p class="order-evaluation-text">
    本次交易,乖,摸摸头 给您留下了什么印象呢?
  </p>
  <p class="order-evaluation-checkbox">
    <ul class="clearfix">
      <li class="order-evaluation-check" data-impression="1">专业水平高<i class="iconfont icon-checked"></i></li>
      <li class="order-evaluation-check" data-impression="2">交付准时<i class="iconfont icon-checked"></i></li>
      <li class="order-evaluation-check" data-impression="3">效果明显<i class="iconfont icon-checked"></i></li>
      <li class="order-evaluation-check" data-impression="4">数据分析准确<i class="iconfont icon-checked"></i></li>
      <li class="order-evaluation-check" data-impression="5">能力待提高<i class="iconfont icon-checked"></i></li>
      <li class="order-evaluation-check" data-impression="6">工期延误<i class="iconfont icon-checked"></i></li>
    </ul>
  </p>
  <p class="order-evaluation-textarea">
    <textarea name="content" id="TextArea1" onkeyup="words_deal();" ></textarea>
    <span>还可以输入<em id="textCount">140</em>个字</span>
  </p>
  <a href="javascript:;" rel="external nofollow" id="order_evaluation">评价完成</a>
</p>
<p id="order_evaluate_modal" class="dmlei_tishi_info"></p>
</body>
<script src="//cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script>
<script>
  /*
   * 根据index获取 str
   * **/
  function byIndexLeve(index){
    var str ="";
    switch (index)
    {
      case 0:
        str="差评";
        break;
      case 1:
        str="较差";
        break;
      case 2:
        str="中等";
        break;
      case 3:
        str="一般";
        break;
      case 4:
        str="好评";
        break;
    }
    return str;
  }
  // 星星数量
  var stars = [
[&#39;x2.png&#39;, &#39;x1.png&#39;, &#39;x1.png&#39;, &#39;x1.png&#39;, &#39;x1.png&#39;],
    [&#39;x2.png&#39;, &#39;x2.png&#39;, &#39;x1.png&#39;, &#39;x1.png&#39;, &#39;x1.png&#39;],
    [&#39;x2.png&#39;, &#39;x2.png&#39;, &#39;x2.png&#39;, &#39;x1.png&#39;, &#39;x1.png&#39;],
    [&#39;x2.png&#39;, &#39;x2.png&#39;, &#39;x2.png&#39;, &#39;x2.png&#39;, &#39;x1.png&#39;],
    [&#39;x2.png&#39;, &#39;x2.png&#39;, &#39;x2.png&#39;, &#39;x2.png&#39;, &#39;x2.png&#39;],
  ];
  $(".block li").find("img").hover(function(e) {
    var obj = $(this);
    var index = obj.index();
    if(index < (parseInt($(".block li").attr("data-default-index")) -1)){
      return ;
    }
    var li = obj.closest("li");
    var star_area_index = li.index();
    for (var i = 0; i < 5; i++) {
      li.find("img").eq(i).attr("src", "http://7xnlea.com2.z0.glb.qiniucdn.com/" + stars[index][i]);//切换每个星星
    }
    $(".level").html(byIndexLeve(index));
  }, function() {
  })
  $(".block li").hover(function(e) {
  }, function() {
    var index = $(this).attr("data-default-index");//点击后的索引
    index = parseInt(index);
    console.log("index",index);
    $(".level").html(byIndexLeve(index-1));
    console.log(byIndexLeve(index-1));
    $(".order-evaluation ul li:eq(0)").find("img").attr("src","http://7xnlea.com2.z0.glb.qiniucdn.com/x1.png");
    for (var i=0;i<index;i++){
      $(".order-evaluation ul li:eq(0)").find("img").eq(i).attr("src","http://7xnlea.com2.z0.glb.qiniucdn.com/x2.png");
    }
  })
  $(".block li").find("img").click(function() {
    var obj = $(this);
    var li = obj.closest("li");
    var star_area_index = li.index();
    var index1 = obj.index();
    li.attr("data-default-index", (parseInt(index1)+1));
    var index = $(".block li").attr("data-default-index");//点击后的索引
    index = parseInt(index);
    console.log("index",index);
    $(".level").html(byIndexLeve(index-1));
    console.log(byIndexLeve(index-1));
    $(".order-evaluation ul li:eq(0)").find("img").attr("src","http://7xnlea.com2.z0.glb.qiniucdn.com/x1.png");
    for (var i=0;i<index;i++){
      $(".order-evaluation ul li:eq(0)").find("img").eq(i).attr("src","http://7xnlea.com2.z0.glb.qiniucdn.com/x2.png");
    }
  });
  //印象
  $(".order-evaluation-check").click(function(){
    if($(this).hasClass(&#39;checked&#39;)){
      //当前为选中状态,需要取消
      $(this).removeClass(&#39;checked&#39;);
    }else{
      //当前未选中,需要增加选中
      $(this).addClass(&#39;checked&#39;);
    }
  });
  //评价字数限制
  function words_deal()
  {
    var curLength=$("#TextArea1").val().length;
    if(curLength>140)
    {
      var num=$("#TextArea1").val().substr(0,140);
      $("#TextArea1").val(num);
      alert("超过字数限制,多出的字将被截断!" );
    }
    else
    {
      $("#textCount").text(140-$("#TextArea1").val().length);
    }
  }
  $("#order_evaluation").click(function(){
    $("#order_evaluate_modal").html("感谢您的评价!么么哒(*  ̄3)(ε ̄ *)").show().delay(3000).hide(500);
  })
</script>
</html>
登录后复制

以上就是js实现五星评价功能的实例的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
我要提问
来源:php中文网
收藏 点赞
上一篇:强大Vue.js组件详细说明 下一篇:js实现Mac触摸板双指事件总结
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
  • php+mysql中13位的时间戳详细介绍
    2023-03-06 20:34:02
  • php模块的添加方法介绍
    2023-03-06 20:32:02
  • PHP中的cookie与session使用详细介绍
    2023-03-06 20:30:02
  • PHP获取真实客户端的真实IP的方法介绍
    2023-03-06 20:28:01
  • 关于php创建图像具体步骤详解
    2023-03-06 18:56:01
  • 实现ajax三级联动下拉菜单的实例代码
    2023-03-06 18:54:01
  • 利用php生成无限栏目树方法介绍
    2023-03-06 18:52:01
  • PHP开发中Redis安装CentOS6.5的实例
    2023-03-06 18:50:01
  • 使用ajax实现分页和分页查询方法
    2023-03-06 18:48:02
  • 详解PHP安全之webshell和后门检测示例
    2023-03-06 18:46:02
最新问题
function_exists()无法判定自定义函数 function test()    {        return true;    } ...
凡人来自于2024-04-29 11:01:01
0 2 1098
google 浏览器 手机版显示的怎么实现 老师您好,google 浏览器怎么变成手机版样式的?
艾尼宛尔.亚森来自于2024-04-23 00:22:19
0 6 1130
子窗口操作父窗口,输出没反应 前两句可执行,最后一句没法应
P粉722478067来自于2024-04-19 15:37:47
0 1 1185
父窗口没有输出 document.onclick = function(){ window.opener.document.write('我是子窗口的输出');  &nb...
P粉722478067来自于2024-04-18 23:52:34
0 0 989
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
0 0 1095
PX自动转换为REM错误  <style>html {   font-size: calc(100vw / 3.75);      }...
凡人来自于2024-04-16 09:34:16
0 0 5163
PHP数组从URL参数中获取的行为不如预期 我有一个包含类别ID的URL参数,我想将其视为一个数组,如下所示:http://example.com?cat[]=3,9,13在PHP中,我使用它从URL参数获取数组:$catI...
P粉785905797来自于2024-04-06 22:09:02
0 1 1401
通过添加 Width 属性将内容向左移动 我已经为主体提供了边距。主要{左边缘:200px;右边距:200px;文本对齐:居中}由于我想以两行而不是一行显示文本,因此我在样式中添加了width属性。.p{字体大小:12px...
P粉738046172来自于2024-04-06 22:01:35
0 3 541
我应该在 apache 中哪里放置 CustomLog 指令 我正在使用php:7.2-apachedocker。我需要禁用运行状况检查url登录访问日志。基于此链接,他们提到了有关修改Customlog指令的信息。我不是关于需要更改Cust...
P粉573809727来自于2024-04-06 22:03:59
0 1 622
返回值中变量的格式是什么? 我是php的新学习者。我发现有一段代码:if($x<time()){return[false,'error'];}逻辑或变量并不重要,但我不明白[false,'error']...
P粉757556355来自于2024-04-06 21:55:20
0 1 409
相关专题
更多>
  • 服务器域名转接慢怎么解决
  • python考级的级别介绍
  • 您需要admin提供的权限才能对此文件进行更改
  • HTML嵌入CSS样式的方法
  • 怎样发位置给别人
  • token怎么获取
  • mesh组网是什么意思
  • win732位和64位的区别
热门推荐
  • js中什么是原型对象
  • js中什么是变量类型什么是数据类型
  • js中什么是变量提升
  • js中什么是构造函数
  • js中什么是闭包函数
  • js中什么函数可以打乱排序
  • js中什么是函数作用域
  • js中的内置对象有哪些
  • js中this的工作原理
  • js中return用法
热门教程
更多>
相关推荐
热门推荐
最新课程
  • phpStudy极速入门视频教程
    phpStudy极速入门视频教程
    514064次学习
    收藏
  • 独孤九贱(1)_HTML5视频教程
    独孤九贱(1)_HTML5视频教程
    596302次学习
    收藏
  • 独孤九贱(5)_ThinkPHP5视频教程
    独孤九贱(5)_ThinkPHP5视频教程
    1191881次学习
    收藏
最新下载
更多>
  • 家居装潢清洁维修服务公司网站模板
网站特效
网站源码
网站素材
前端模板
  • [表单按钮] jQuery企业留言表单联系代码
  • [播放器特效] HTML5 MP3音乐盒播放特效
  • [菜单导航] HTML5炫酷粒子动画导航菜单特效
  • [表单按钮] jQuery可视化表单拖拽编辑代码
  • [播放器特效] VUE.JS仿酷狗音乐播放器代码
  • [html5特效] 经典html5推箱子小游戏
  • [图片特效] jQuery滚动添加或减少图片特效
  • [相册特效] CSS3个人相册封面悬停放大特效
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
app下载
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号

  • 精品班

  • 技术支持

  • 技术咨询

  • 学习群

  • 会员优惠

  • 返回顶部

  • 天下网标王昌都企业网站设计公司昭通网页制作公司南联百度网站优化排名报价咸宁网站关键词优化哪家好深圳百度网站优化报价阿里百度网站优化排名公司鞍山百度seo哪家好喀什设计网站推荐邢台百姓网标王推广报价怀化建设网站价格孝感营销型网站建设哪家好南平百度竞价包年推广价格泰州SEO按天扣费公司阳泉网站优化推广价格资阳seo优化公司长葛网站制作设计推荐开封网站优化推荐西宁网络广告推广报价抚顺seo网站推广公司飞来峡推广网站丹东网站优化软件推荐醴陵关键词按天扣费报价常州seo排名推荐龙华网页设计公司吕梁百姓网标王推广价格平湖阿里店铺运营哪家好爱联企业网站制作多少钱金昌网站制作设计哪家好遵义SEO按效果付费吉祥百度网站优化排名香港通过《维护国家安全条例》两大学生合买彩票中奖一人不认账让美丽中国“从细节出发”19岁小伙救下5人后溺亡 多方发声卫健委通报少年有偿捐血浆16次猝死汪小菲曝离婚始末何赛飞追着代拍打雅江山火三名扑火人员牺牲系谣言男子被猫抓伤后确诊“猫抓病”周杰伦一审败诉网易中国拥有亿元资产的家庭达13.3万户315晚会后胖东来又人满为患了高校汽车撞人致3死16伤 司机系学生张家界的山上“长”满了韩国人?张立群任西安交通大学校长手机成瘾是影响睡眠质量重要因素网友洛杉矶偶遇贾玲“重生之我在北大当嫡校长”单亲妈妈陷入热恋 14岁儿子报警倪萍分享减重40斤方法杨倩无缘巴黎奥运考生莫言也上北大硕士复试名单了许家印被限制高消费奥巴马现身唐宁街 黑色着装引猜测专访95后高颜值猪保姆男孩8年未见母亲被告知被遗忘七年后宇文玥被薅头发捞上岸郑州一火锅店爆改成麻辣烫店西双版纳热带植物园回应蜉蝣大爆发沉迷短剧的人就像掉进了杀猪盘当地回应沈阳致3死车祸车主疑毒驾开除党籍5年后 原水城县长再被查凯特王妃现身!外出购物视频曝光初中生遭15人围殴自卫刺伤3人判无罪事业单位女子向同事水杯投不明物质男子被流浪猫绊倒 投喂者赔24万外国人感慨凌晨的中国很安全路边卖淀粉肠阿姨主动出示声明书胖东来员工每周单休无小长假王树国卸任西安交大校长 师生送别小米汽车超级工厂正式揭幕黑马情侣提车了妈妈回应孩子在校撞护栏坠楼校方回应护栏损坏小学生课间坠楼房客欠租失踪 房东直发愁专家建议不必谈骨泥色变老人退休金被冒领16年 金额超20万西藏招商引资投资者子女可当地高考特朗普无法缴纳4.54亿美元罚金浙江一高校内汽车冲撞行人 多人受伤

    天下网标王 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化