• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >AngularJS > AngularJS实现星星等级评分功能

AngularJS实现星星等级评分功能

作者:大禹不治水 字体:[增加 减小] 来源:互联网 时间:2017-05-30

本文主要包含angularjs 搜索功能,angularjs,angularjs菜鸟教程,angularjs官网,angularjs教程等相关知识,大禹不治水 希望在学习及工作中可以帮助到您

星期六加班,教育后台也要有星级评分等级的需求,醉了……基本知道些怎么做,网上也随便找了找,没什么合意的,毕竟需求不同,也不能完全一样不是。学习之,改之╮(╯▽╰)╭

Directive 

angular.module('XXX').directive('stars', stars);

  function stars() {
    var directive = {
      restrict: 'AE',
      template: '<ul class="rating" ng-mouseleave="leave()">' +
        '<li ng-repeat="star in stars" ng-class="star" ng-click="click($index + 1)" ng-mouseover="over($index + 1)">' +
        '<i class="glyphicon glyphicon-star stars"></i>' +
        '</li>' +
        '</ul>',
      scope: {
        ratingValue: '=',
        hoverValue: '=',
        max: '=',
        onHover: '=',
        onLeave: '='
      },
      controller: startsController,

      link: function(scope, elem, attrs) {
        elem.css("display", "block");
        elem.css("text-align", "center");
        var updateStars = function() {
          scope.stars = [];
          for (var i = 0; i < scope.max; i++) {
            scope.stars.push({
              filled: i < scope.ratingValue
            });
          }
        };
        updateStars();

        var updateStarsHover = function() {
          scope.stars = [];
          for (var i = 0; i < scope.max; i++) {
            scope.stars.push({
              filled: i < scope.hoverValue
            });
          }
        };
        updateStarsHover();

        scope.$watch('ratingValue', function(oldVal, newVal) {
          if (newVal) {
            updateStars();
          }
        });
        scope.$watch('hoverValue', function(oldVal, newVal) {
          if (newVal) {
            updateStarsHover();
          }
        });
      }


    };

    return directive;

    /** @ngInject */
    function startsController($scope) {
      // var vm = this;
      $scope.click = function(val) {
        $scope.ratingValue = val;
      };
      $scope.over = function(val) {
        $scope.hoverValue = val;
      };
      $scope.leave = function() {
        $scope.onLeave();
      }

    }
  }

</div>

CSS 

.rating {

  color: #a9a9a9;
  margin: 0;
  padding: 0; 
  text-align: center;

}
ul.rating {
  display: inline-block;

}
.rating li {
  list-style-type: none;
  display: inline-block;
  padding: 1px;
  text-align: center;
  font-weight: bold;
  cursor: pointer;
}

 

.rating .filled {
  color: #f00;
}
.rating .stars{

  font-size: 20px;

  margin-right: 5px;

}

</div>

Controller 

    //星星等级评分
    $scope.max = 6;
    $scope.ratingVal = 6;
    $scope.hoverVal = 6;//我这需求是默认六个星全满(淡腾,反正也招不出神龙.因为还差一个.)一般的话,ratingVal和hoverVal都写0就可以了。
    $scope.onHover = function(val) {
      $scope.hoverVal = val;
    };
    $scope.onLeave = function() {
      $scope.hoverVal = $scope.ratingVal;
    }
    $scope.onChange = function(val) {
      $scope.ratingVal = val;
    }

</div>

HTML

<stars rating-value="ratingVal" hover-value="hoverVal" max="max" on-hover="onHover" on-leave="onLeave"></stars>
ratingVal:{{ratingVal}};<br/>
hoverVal:{{hoverVal}}
</div>

说几句, 星星那东西,可以直接输入法敲出来,也可以用unicode搞出来,字体文件什么的都行,你要硬用图片的话……把ngClass换成ngSrc也可以试试,代码改改也行,精灵图改改background-position也凑合过,╮(╯▽╰)╭ 想了一下,比较累,祝你成功。

如果是那种商城网站只是要看评价等级的话,复用代码也可以,加个readonly属性。 

directive:
  scope: {
    readonly: '@'
  }
   function startsController($scope) {
      // var vm = this;
      $scope.click = function(val) {
       if ($scope.readonly) {
         return;
        }
        $scope.ratingValue = val;
      };
      $scope.over = function(val) {
       if ($scope.readonly) {
         return;
        }
        $scope.hoverValue = val;
      };

   }

controller:
  $scope.readonly = false;

html:
  readonly={{readonly}}.
</div>

写到这,突然意识到今后一定会改需求,加功能(已然习惯)。我还是默默地加上readonly吧……

指令这玩意,深了很绕,我也弄不熟,每次写还得翻翻以前写的代码,毕竟渣渣。每次不要复用的代码,我都懒得用指令,毕竟菜鸟。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

</div>

您可能想查找下面的文章:

  • angularjs实现多张图片上传并预览功能
  • AngularJS实现表单验证功能
  • AngularJS实现星星等级评分功能
  • Angularjs 实现分页功能及示例代码
  • 利用Angularjs和bootstrap实现购物车功能
  • AngularJS轻松实现双击排序的功能

相关文章

  • 2017-05-30使用Raygun来自动追踪AngularJS中的异常
  • 2017-05-30详解AngularJS中自定义指令的使用
  • 2017-05-30基于Angularjs实现分页功能
  • 2017-05-30angularjs 实现带查找筛选功能的select下拉框实例
  • 2017-05-30浅析AngularJS Filter用法
  • 2017-05-30实例解析angularjs的filter过滤器
  • 2017-05-30详解JavaScript的AngularJS框架中的作用域与数据绑定
  • 2017-05-30Angular-Ui-Router+ocLazyLoad动态加载脚本示例
  • 2017-05-30深入浅析AngularJS和DataModel
  • 2017-05-30AngularJS实现网站换肤实例

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • Ubuntu系统下Angularjs开发环境安装
    • AngularJS中一般函数参数传递用法分析
    • AngularJS表单基本操作
    • Angular4 幕课网demo
    • Angular1.x自定义指令实例详解
    • 浅谈angularJS中的事件
    • 深入理解Angularjs向指令传递数据双向绑定机制
    • AngularJS表格详解及示例代码
    • AngularJS基础学习笔记之控制器
    • Angular.js指令学习中一些重要属性的用法教程

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有