开门见山,直入主题。
data:image/s3,"s3://crabby-images/a31a6/a31a695bd016d09311ead92db32f416f67f54df9" alt=""
至于Angluar程序架构和搭建环境,这里不多说
要实现星级评分需要解决6个问题
data:image/s3,"s3://crabby-images/1b15f/1b15f6cb48d27a10daf7b814dba695fc54bf33ae" alt=""
就是效果图的这部分区域
data:image/s3,"s3://crabby-images/da9be/da9be34ea599286df178d78565c35d0d0606f5db" alt=""
1、如何在页面实现一个星,在stars.components.html里面用bootstrap的样式<span class="glyphicon glyphicon-star"></span>,前提你的angular项目必须要安装bootstrap,要经过3步
2、如何实现一个空的星<span class="glyphicon glyphicon-star-empty"></span>
3、如何显示5颗星星。在stars.components.ts里面定义一个数组。
private starts:boolean[ ];
ngOnInit() { //一个钩子函数
this.stars= [true,true,false,false,true];
},然后在span里面用*ngFor=“let star of stars ”(这点跟vue好像,其实有很多地方都很相像)
4、如何实现有的是实星,有的是空星。先介绍几种绑定值的方式
a.{{}} 学过vue的人对这种绑定值的方式应该不陌生b.属性绑定,比如
data:image/s3,"s3://crabby-images/9a3b7/9a3b7aafd7d979f17b42bf9b6c716c29ff21fb55" alt=""
data:image/s3,"s3://crabby-images/69206/69206ae87aa2fb990b6e93d8de815d37633e0d83" alt=""
这就是属性绑定(不也跟vue很像吗)
c.样式绑定(就是用样式绑定来实现5颗星有的是空星有的是实星)<span*ngFor="let star of stars" class="glyphicon glyphicon-star"[class.glyphicon-star-empty]="star">这句话的意思就是如果star是true显示实星,如果是false就显示空星
data:image/s3,"s3://crabby-images/745b3/745b33af3fe6f4a4ce0648d13d6c59807286415a" alt=""
5、如何将商品的评级传给星级评价(父组件传值给子组件)
1)首先在星级评价star.component.ts的组件里面声明一个rating属性(private rating:number=0),用来接受父组件传给子组件的值,即productc->star
data:image/s3,"s3://crabby-images/1ebbf/1ebbff2056480f760ec3a2cb4f5fd1b4310db6ed" alt=""
2)怎么在star.component.html上面显示{{rating}}星
data:image/s3,"s3://crabby-images/7dd69/7dd69c5ab59d2c4d1658de81e3ae6b70325ee69a" alt=""
现在肯定是0,因为product组件还没有传值,现在只是star组件做了接受和显示的操作
3)在star.component.ts里面定义一个@Input的装饰器
data:image/s3,"s3://crabby-images/1dfd1/1dfd15ba4546b4aa8f7eeb1f53f981e8f5143898" alt=""
4)在父组件里面传值
data:image/s3,"s3://crabby-images/22512/225128fd4d96b9ab0d3683a07ca263fec8ca92f6" alt=""
6、如何将商品的星级来决定是实心还是空心的,之前是this.stars数组是写死的
1)先将stars.component.ts的this.stars置空
2)动态传值
data:image/s3,"s3://crabby-images/69d47/69d47642482ae6de7b0c663c6d88863fd4c338f6" alt=""
星级评分到此结束!
网友评论