AngularJS实现星星等级评分功能

前端之家收集整理的这篇文章主要介绍了AngularJS实现星星等级评分功能前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

Directive

<div class="jb51code">
<pre class="brush:js;">
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">' +
'' +
'',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',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();
  }

}

}

CSS

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

HTML

ratingVal:{{ratingVal}};
hoverVal:{{hoverVal}}

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

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

}

controller:
$scope.readonly = false;

html:
readonly={{readonly}}.

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

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

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

原文链接:https://www.f2er.com/js/45604.html

猜你在找的JavaScript相关文章