时间:2021-05-28
星期六加班,教育后台也要有星级评分等级的需求,醉了……基本知道些怎么做,网上也随便找了找,没什么合意的,毕竟需求不同,也不能完全一样不是。学习之,改之╮(╯▽╰)╭
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(); } } }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属性。
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}}.写到这,突然意识到今后一定会改需求,加功能(已然习惯)。我还是默默地加上readonly吧……
指令这玩意,深了很绕,我也弄不熟,每次写还得翻翻以前写的代码,毕竟渣渣。每次不要复用的代码,我都懒得用指令,毕竟菜鸟。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了js实现的星星评分功能函数。分享给大家供大家参考,具体如下:星星评分functionrate(obj,oEvent){//图片地址设置varimg
本文实例为大家分享了js星星等级评价的具体代码,供大家参考,具体内容如下效果图:Document.container{float:left;}.score{fl
本文实例为大家分享了微信小程序实现展示评分结果的具体代码,供大家参考,具体内容如下星星评分展示1根据评分展示整颗行星或者半颗星星星星评分展示2根据评分按照小数点
关于星星评分效果大家一定都不会陌生,当鼠标滑过的时候会使相应的星星变得高亮,下面就介绍一下如何利用css实现此功能,当然并不是完整的评分功能,仅仅是如何使滑过的
京东根据店铺评分进行等级划分。现在,根据店铺的星星来划分等级的方法,根据业者们的风向标等级来划分,可以直接反应风向标的等级,京东店铺的等级在哪里看呢京东店铺等级