Angular 星级评分组件
一、需求演变及描述:
1. 有一个“客户对公司的总体评价”的字段(evalutation)。字段为枚举类型,0-5,对应关系为:0-暂无评价,1-很差,2-差,3-一般,4-好,5-很好
2. 后来需要根据评分使用星星来表现,一共5颗星,分为实星和空星,例如,当3分时,三颗星星被点亮,即3颗实星2颗空星。
二、开发前准备:
1. 用于描述星星的图标,也可以是图片,我这里使用 iconfont
2. 新建一个星级评分组件,便于复用
通过命令 ng g component rating 我新建了一个星级评分组件
三、从父组件中获取“客户对公司的总体评价”的字段的值
通常控制星星显示的 evalutation 值都是一个从父组件传递出去的Number类型值。
1、首先我们需要在调用星级组件的父组件模板中将值传递出去:
<li class="companyevalutation">客户对公司的总体评价:
<app-rating [starsRating]="repairs.evalutation"></app-rating>
</li>
说明:app-rating 是新建的星级评分组件,使用 starsRating 属性绑定 evalutation 的值
2、星级组件为了获得这个值,需要使用输入属性 @Input()
在星星组件的控制器(rating.component.ts)中写这样一段代码
@Input()
private starsRating: number = 0;
说明:@input 用来定义模块的输入,用于从父组件向子组件传递数据
在这里可以将 starsRating 的值传递出去。
三、显示实星和空星
1. 显示5颗实星
要显示5颗实星可以这样做:
<span class="iconfont icon-start_c"></span>
<span class="iconfont icon-start_c"></span>
<span class="iconfont icon-start_c"></span>
<span class="iconfont icon-start_c"></span>
<span class="iconfont icon-start_c"></span>
但是这样的做法未免太过暴力,假如要显示100颗星,岂不是要写100行同样的代码。
显示5颗实星,可以使用 angular 的循环
<span *ngFor="let star of stars;" class="iconfont icon-start_c"></span>
同时在控制器里面,定义 stars 的值:
stars: boolean[]; constructor() { } ngOnInit() {
this.stars = [true, true, true, true, true];
}
这样就得到了5颗实心的星星。
star 的值为 true 时,添加 icon-start_n 类,显示空星。
<span *ngFor="let star of stars;" class="rating iconfont icon-start_c" [class.icon-start_n]="star"></span>
获取实际的星星个数:
get starsRating(): number {
return this._starsRating;
} @Input() set starsRating(value: number){
this._starsRating = value;
this.rating();
}
stars 为布尔型的数组,值为 false 将会显示实星,值为 true 将会显示空星。
public rating(): void {
this.stars = [];
for (let i = 1; i <= 5; i++){
this.stars.push(i > this.starsRating);
}
}
如果 starRating 的值为 3,stars = [false, false, false, true, true]; 视图显示三颗实星,两颗空星
四、源码:
rating.component.html:
<span *ngFor="let star of stars;" class="rating iconfont icon-start_c" [class.icon-start_n]="star"></span>
rating.component.ts:
import {Component, Input, OnInit} from '@angular/core'; @Component({
selector: 'app-rating',
templateUrl: './rating.component.html'
})
export class RatingComponent implements OnInit { public _starsRating: number = 0;
public stars: boolean[]; get starsRating(): number {
return this._starsRating;
} @Input() set starsRating(value: number){
this._starsRating = value;
this.rating();
} constructor() { } ngOnInit() {
this.rating();
} public rating(): void {
this.stars = [];
for (let i = 1; i <= 5; i++){
this.stars.push(i > this.starsRating);
}
} }
Angular 星级评分组件的更多相关文章
- 干货之运用CALayer创建星级评分组件(五角星)
本篇记录星级评分组件的创建过程以及CALayer的运用. 为了实现一个星级评分的组件,使用了CALayer,涉及到mask.CGPathRef.UIBezierPath.动画和一个计算多角星关键节点的 ...
- vue星级评分组件
<template> <div class="Rating-gray"> <i v-for="(item,index) in itemCla ...
- js实现星级评分效果(非常规5个li代码)
1. 前言 此方案受到JS单行写一个评级组件启发,自己写了一个简单Demo. 功能有正常滑动,动态显示实心星星个数:当点击确认,则保持当前的实心星星个数:再移动时未点击,则离开后还是保持之前的状态. ...
- ExtJS 4.2 评分组件
上一文章是扩展ExtJS自带的Date组件.在这里将创建一个评分组件. 目录 1. 介绍 2. 示例 3. 资源下载 1. 介绍 代码参考的是 Sencha Touch 2上的一个RatingStar ...
- 原生JS实现-星级评分系统
今天我又写了个很酷的实例:星级评分系统(可自定义星星个数.显示信息) sufuStar.star();使用默认值5个星星,默认信息 var msg = [........]; sufuStar.sta ...
- javascript星级评分(多个)
JS打多个类型星级评分: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http: ...
- js星级评分点击星级评论打分效果
html代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www ...
- js星级评分点击星级评论打分效果--收藏--转载
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- JavaScript星级评分
事件onmouseover <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http ...
随机推荐
- sql中把时间转换成xx年xx月xx日
DECLARE @dt datetime SET @dt=GETDATE()--1.短日期格式:yyyy-m-d SELECT STUFF(STUFF(CONVERT(char(8),@dt,112) ...
- 修改MVC视图默认搜索规则(IViewEngine)
前几天我自己在写一个系统,写到后台管理系统的时候,我突然有个想法就是:想在区域视图下新建文件,单独处理后台一些业务:Area/AdminManager/View/Content/Index.cshtm ...
- SpringBoot+Mybatis整合入门(一)
SpringBoot+Mybatis 四步整合 第一步 添加依赖 springBoot+Mybatis相关依赖 <!--springBoot相关--> <parent> < ...
- 【原】Docker入门之Centos7.0+安装
服务器配置:1核2G 40G 硬盘,Centos 7.4. 以下全程是在 root 用户下操作: 1.卸载旧版本 yum remove docker \ docker-client \ docker- ...
- 【转】详解spring 每个jar的作用
spring.jar 是包含有完整发布模块的单个jar 包.但是不包括mock.jar, aspects.jar, spring-portlet.jar, and spring-hibernate2. ...
- zookeeper 选举
选举概述: 1.启动时期的选举 所有的服务器状态为 LOOKING. 1.1.每个Server 会投出一票(投票规则为:SID.ZXID ,即 服务器ID 和 最大事务ID). 1.2.处理选票 (A ...
- [js常用]百度将文字转化为语音实例
嗷嗷方便的文字转语音,不过用的时候记得到百度语音上申请key,免费的.之前在网络上看到有人写了一部分,自己丰富下,以后用也方便 <!DOCTYPE html PUBLIC "-//W3 ...
- 阿里云 CentOS7安装redis4.0.9并开启远程访问
1 安装redis编译的c环境 yum install gcc-c++ redis是c语言开发的,安装redis需要先将官网下载的源码进行编译,编译依赖gcc环境. 如果没有gcc环境,需要安装gcc ...
- 转:导出csv文件数字会自动变科学计数法的解决方法
导出csv文件数字会自动变科学计数法的解决方法 其实这个问题跟用什么语言导出csv文件没有关系.Excel显示数字时,如果数字大于12位,它会自动转化为科学计数法:如果数字大于15位,它不仅用于科 ...
- 用CSS的方法如何让一个元素不可见?(面试题目)
面试中看到这个问题,自己想的不全面,下面整理下,一起学习: 一.CSS元素隐藏 在CSS中,让元素隐藏(指屏幕范围内肉眼不可见)的方法很多,有的占据空间,有的不占据空间:有的可以响应点击,有的不能响应 ...