AngularJS實(shí)現(xiàn)星星等級(jí)評(píng)分功能
星期六加班,教育后臺(tái)也要有星級(jí)評(píng)分等級(jí)的需求,醉了……基本知道些怎么做,網(wǎng)上也隨便找了找,沒(méi)什么合意的,畢竟需求不同,也不能完全一樣不是。學(xué)習(xí)之,改之╮(╯▽╰)╭
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
//星星等級(jí)評(píng)分 $scope.max = 6; $scope.ratingVal = 6; $scope.hoverVal = 6;//我這需求是默認(rèn)六個(gè)星全滿(淡騰,反正也招不出神龍.因?yàn)檫€差一個(gè).)一般的話,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}}
說(shuō)幾句, 星星那東西,可以直接輸入法敲出來(lái),也可以用unicode搞出來(lái),字體文件什么的都行,你要硬用圖片的話……把ngClass換成ngSrc也可以試試,代碼改改也行,精靈圖改改background-position也湊合過(guò),╮(╯▽╰)╭ 想了一下,比較累,祝你成功。
如果是那種商城網(wǎng)站只是要看評(píng)價(jià)等級(jí)的話,復(fù)用代碼也可以,加個(gè)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}}.
寫到這,突然意識(shí)到今后一定會(huì)改需求,加功能(已然習(xí)慣)。我還是默默地加上readonly吧……
指令這玩意,深了很繞,我也弄不熟,每次寫還得翻翻以前寫的代碼,畢竟渣渣。每次不要復(fù)用的代碼,我都懶得用指令,畢竟菜鳥。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JS實(shí)現(xiàn)星星評(píng)分功能實(shí)例代碼(兩種方法)
- jquery插件star-rating.js實(shí)現(xiàn)星級(jí)評(píng)分特效
- js點(diǎn)亮星星評(píng)分并獲取參數(shù)的js代碼
- js星星評(píng)分效果
- JS實(shí)現(xiàn)帶提示的星級(jí)評(píng)分效果完整實(shí)例
- javascript實(shí)現(xiàn)五星評(píng)分功能
- js實(shí)現(xiàn)的星星評(píng)分功能函數(shù)
- javascript 星級(jí)評(píng)分效果(手寫)
- JavaScript制作淘寶星級(jí)評(píng)分效果的思路
- css+html+js實(shí)現(xiàn)五角星評(píng)分
相關(guān)文章
用Angular實(shí)時(shí)獲取本地Localstorage數(shù)據(jù),實(shí)現(xiàn)一個(gè)模擬后臺(tái)數(shù)據(jù)登入的效果
這篇文章主要介紹了用ANGULAR實(shí)時(shí)獲取本地LOCALSTORAGE數(shù)據(jù),實(shí)現(xiàn)一個(gè)模擬后臺(tái)數(shù)據(jù)登入的效果的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-11-11angular.js實(shí)現(xiàn)購(gòu)物車功能
這篇文章主要為大家詳細(xì)介紹了angular.js購(gòu)物車功能的實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10自學(xué)實(shí)現(xiàn)angularjs依賴注入
這篇文章主要為大家詳細(xì)介紹了angularjs依賴注入的自己成果,如何實(shí)現(xiàn)angularjs依賴注入,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12Angular環(huán)境搭建及簡(jiǎn)單體驗(yàn)小結(jié)
Angular基于TypeScript和react、vue相比 Angular更適合中大型企業(yè)級(jí)項(xiàng)目,本文通過(guò)實(shí)例代碼給大家分享Angular環(huán)境搭建及簡(jiǎn)單體驗(yàn),感興趣的朋友跟隨小編一起學(xué)習(xí)吧2021-05-05AngularJS整合Springmvc、Spring、Mybatis搭建開發(fā)環(huán)境
這篇文章主要介紹了AngularJS整合Springmvc、Spring、Mybatis搭建開發(fā)環(huán)境的相關(guān)資料,為學(xué)習(xí)使用AngularJS做好基礎(chǔ)準(zhǔn)備,感興趣的小伙伴們可以參考一下2016-02-02Angular.JS利用ng-disabled屬性和ng-model實(shí)現(xiàn)禁用button效果
這篇文章主要介紹了Angular.JS利用ng-disabled屬性和ng-model實(shí)現(xiàn)禁用button效果的相關(guān)資料,文中給出了詳細(xì)的示例代碼,相信對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-04-04