angularJs实现星星等级评分

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

  Directive

 1 angular.module(‘XXX‘).directive(‘stars‘, stars);
 2
 3     function stars() {
 4         var directive = {
 5             restrict: ‘AE‘,
 6             template: ‘<ul class="rating" ng-mouseleave="leave()">‘ +
 7                 ‘<li ng-repeat="star in stars" ng-class="star" ng-click="click($index + 1)" ng-mouseover="over($index + 1)">‘ +
 8                 ‘<i class="glyphicon glyphicon-star stars"></i>‘ +
 9                 ‘</li>‘ +
10                 ‘</ul>‘,
11             scope: {
12                 ratingValue: ‘=‘,
13                 hoverValue: ‘=‘,
14                 max: ‘=‘,
15                 onHover: ‘=‘,
16                 onLeave: ‘=‘
17             },
18             controller: startsController,
19
20             link: function(scope, elem, attrs) {
21                 elem.css("display", "block");
22                 elem.css("text-align", "center");
23                 var updateStars = function() {
24                     scope.stars = [];
25                     for (var i = 0; i < scope.max; i++) {
26                         scope.stars.push({
27                             filled: i < scope.ratingValue
28                         });
29                     }
30                 };
31                 updateStars();
32
33                 var updateStarsHover = function() {
34                     scope.stars = [];
35                     for (var i = 0; i < scope.max; i++) {
36                         scope.stars.push({
37                             filled: i < scope.hoverValue
38                         });
39                     }
40                 };
41                 updateStarsHover();
42
43                 scope.$watch(‘ratingValue‘, function(oldVal, newVal) {
44                     if (newVal) {
45                         updateStars();
46                     }
47                 });
48                 scope.$watch(‘hoverValue‘, function(oldVal, newVal) {
49                     if (newVal) {
50                         updateStarsHover();
51                     }
52                 });
53             }
54
55
56         };
57
58         return directive;
59
60         /** @ngInject */
61         function startsController($scope) {
62             // var vm = this;
63             $scope.click = function(val) {
64                 $scope.ratingValue = val;
65             };
66             $scope.over = function(val) {
67                 $scope.hoverValue = val;
68             };
69             $scope.leave = function() {
70                 $scope.onLeave();
71             }
72
73         }
74     }

  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;
}

  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;
        }

  HTML

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

  说几句,

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

  

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

 1 directive:
 2     scope: {
 3         readonly: ‘@‘
 4     }
 5      function startsController($scope) {
 6             // var vm = this;
 7             $scope.click = function(val) {
 8               if ($scope.readonly) {
 9                   return;
10                 }
11                 $scope.ratingValue = val;
12             };
13             $scope.over = function(val) {
14               if ($scope.readonly) {
15                   return;
16                 }
17                 $scope.hoverValue = val;
18             };
19
20       }
21
22 controller:
23     $scope.readonly = false;
24
25 html:
26     readonly={{readonly}}.

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

  

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

  还是多学习!

  

时间: 2024-10-17 11:26:13

angularJs实现星星等级评分的相关文章

css两种动态显示星星等级的比较(一星、两星、三星、四星、五星)

以下是显示后的图片,相信在很多网站上都能看到这种效果,目前我知道两种实现方式 1.background-position加上一张图片 图片:http://www.brookstone.com/webassets/pwr/engine/images/stars.gif 1 <!DOCTYPE html> 2 <html> 3 4 <head> 5 <link rel="stylesheet" href="style.css"&

星星评分

一.方法1 1.用到图片 2.结构和样式 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <style> ul { padding-left: 0; overflow: hidden; } ul li { float: left; list-style: no

树形数组——摘星星伪题解

树形数组. 题目:摘星星 描述:宇航员经常检测星图,在星图上,星星由点表示而且每颗星星都有笛卡尔坐标.星星的等级表示左下方星星的数量.宇航员想知道星星等级的分布. 例如,如上面图形所示,第5号星等级是3 (它由三个标记为1,2和4的星组成).标记着2和4的星星的等级是1,在此地图上,0等级的星星只有一个,1等级的有两个,2等级的有一个,3等级的有一个. 你设计一个程序,在给定地图上计算出每个等级星星的数量. 输入: 输入文件“INPUT.TXT”的第一行包含N个星星(1<=N<=60000),

【SE】Week3 : 四则运算式生成评分工具Extension&amp;Release Version(结对项目)

Foreword 此次的结对项目终于告一段落,除了本身对软件开发的整体流程有了更深刻的了解外,更深刻的认识应该是结对编程对这一过程的促进作用. 在此想形式性但真心地啰嗦几句,十分感谢能端同学能够不厌其烦地接受我每次对软件的修改提议,并在代码实现过程中为团队贡献了许多人性化的tips: 另外,他积极好学的心态也很让我佩服.从初入面向对象,数据结构的使用,实际工程的开发,他快速地掌握了其中的技巧: 并在过程中不嫌辛苦地和我一起熬夜,才能在短短48h内高效利用时间,开发出这款颇多功能的软件.感谢!=)

树状数组的进阶运用(Stars 数星星)

英文原题 Problem Description Astronomers often examine star maps where stars are represented by points on a plane and each star has Cartesian coordinates. Let the level of a star be an amount of the stars that are not higher and not to the right of the g

微信小程序用户评分实例

微信小程序用户评分实例!成都小程序开发实例为大家分享了微信小程序实现展示评分结果的具体代码,供大家参考,具体内容如下 根据评分展示整颗行星或者半颗星星 根据评分按照小数点展示整颗行星或者部分星星 wxml 本文实例为大家分享了微信小程序实现展示评分结果的具体代码,供大家参考,具体内容如下 根据评分展示整颗行星或者半颗星星 根据评分按照小数点展示整颗行星或者部分星星 wxml <view class="conmmentbox"> <view class="st

php正则匹配用户名必须包含字母和数字且大于6位

php正则匹配用户名必须包含字母和数字且大于6位 UEditor 1.4.3版本中去掉本地自动保存功能 右键菜单没有新建文本文档txt 常见HTTP错误代码大全 http常见状态码 eclipse内存溢出错误 为什么井盖是圆的?--揭开面试题的神秘面目! Linux Centos 6.6搭建SFTP服务器 密码强度检测 JS判断检测用户输入密码强度代码 对程序员来说,提高薪水最好的建议是什么? CSS3仿淘宝右侧固定导航悬浮层 jQuery仿淘宝网登录拖动滑块验证码代码 jQuery单击div更

【字源大挪移—读书笔记】 第二部分:字根

[2] 字根:[2.1]表示[否定]的字根.[2.2]表示[方位]的字根.[2.3]表示[程度]的字根.[2.4]表示[状态]的字根.[2.5]表示[现象]的字根.[2.6]表示[身体]的字根.[2.7]表示[姿势]的字根.[2.8]表示[心,心里活动]的字根.[2.9]表示[行为动作]的字根.[2.10]表示[感官动作]的字根.[2.11]表示[感觉]的字根.[2.12]表示[生命]的字根.[2.13]表示[死亡]的字根.[2.14]表示[社会]的字根 [2.1]表示[否定]的字根 -neg-

未经整理的工作中遇到的小问题

console.log("success",e.data);页面的错误提醒nested exception is org.apache.ibatis.type.TypeException: Could not set parameters for mapping: ParameterMapping{property='name', mode=IN, javaType=class java.lang.Object, jdbcType=null, numericScale=null, re