项目vue2.0仿外卖APP(七)
ratings评价列表页实现

在ratings.vue组件里开发
首先先引入seller数据:

书写模板结构:

由于评价页又有之前写过的star.vue组件,所以又要在ratings.vue组件引入:
import star from 'components/star/star';
并且注册:
components: {
      star
    }

这部分的模板:
<template>
<div class="ratings">
<div class="ratings-content">
<div class="overview">
<div class="overview-left">
<h1 class="score">{{seller.score}}</h1>
<div class="title">综合评分</div>
<div class="rank">高于周边商家{{seller.rankRate}}%</div>
</div>
<div class="overview-right">
<div class="score-wrapper">
<span class="title">服务态度</span>
<star :size="" :score="seller.serviceScore"></star>
<span class="score">{{seller.serviceScore}}</span>
</div>
<div class="score-wrapper">
<span class="title">商品评分</span>
<star :size="" :score="seller.foodScore"></star>
<span class="score">{{seller.foodScore}}</span>
</div>
<div class="delivery-wrapper">
<span class="title">送达时间</span>
<span class="delivery">{{seller.deliveryTime}}分钟</span>
</div>
</div>
</div>
<split></split>
</div>
</div>
</template>
书写样式:
整个ratings区块绝对定位的:
.ratings
position: absolute
top: 174px
bottom:
left:
width: %
overflow: hidden
这里的overview-left区块是固定宽度,overview-right区块是自适应宽度。所以还是用了flex布局。
而且这里overview-left还是响应式的:
.overview-left
flex: 137px
padding: 6px
width: 137px
border-right: 1px solid rgba(, , , 0.1)
text-align: center
@media only screen and (max-width: 320px)
flex: 120px
width: 120px
在这个区块下方还有个灰色间隔,因为在其他页面也有,所以这里也可以用组件化开发一个split.vue:

然后在ratings.vue引入并注册。
这样就可以用在模板里面了:

这里再通过vue.resource去获取之前处理过的data.json里面的ratings数据:

可以看到,数据已经出来了:

ratings.vue:

ratingsselect.vue:

接下来:

这三个按钮都是可以点击的,点击哪一个就会显示对应的评价,而且点击后也会出现高亮。下面还有一个可选择的文字。
当然,我们还是用组件化的思想来开发。
ratingselect.vue组件:

接着就可以在ratings.vue里引入和注册了

接下添加内容:


再写样式
结果就是这样:

接着继续完成页面的评价内容:

并且添加样式
这样页面的基本结构就出来了:

接下来在ratings.vue组件中给页面添加滚动:
加ref属性:


这样就可以滚动页面了。
接下来要实现的功能就是根据我们点击不同的按钮,显示按钮所要求的评论内容。
这里还需要将ratings.vue组件的ratings数据传给ratingselect.vue组件:

在ratingselect.vue组件计算属性:得出满意的和不满意的评论数,用filter()来过滤:

然后把数据传给DOM:

在ratingselect.vue组件添加按钮的点击状态:ALL为2:const ALL = 2;

并且添加.active的样式。
接下来要用到组件间的通信了,来传递子组件所点击的是那个按钮:



项目vue2.0仿外卖APP(七)的更多相关文章
- 项目vue2.0仿外卖APP(一)
		
最近用vue.js做一个仿饿了么外卖APP的项目,现在也把流程啊什么的暂时先整理一下在这个博客上面. 当然,这个过程会有点长,不过确实能学到很多东西. 话不多说,马上开始吧. 1.项目介绍 选用当前最 ...
 - 项目vue2.0仿外卖APP(六)
		
goods 商品列表页开发 布局编写 除了商品之外还有购物车,还有个详情页,挺复杂的. 两栏布局:左侧固定宽度,右侧自适应,还是用flex. 因为内容可能会超过手机高度,超过就隐藏.左右两侧的内容是可 ...
 - 项目vue2.0仿外卖APP(五)
		
header组件 vue-resourse应用 https://github.com/pagekit/vue-resource vue-resource是Vue.js的一款插件,它可以通过XMLHtt ...
 - 项目vue2.0仿外卖APP(四)
		
组件拆分 先把项目搭建时生成的代码给清了吧 现在static目录下引入reset.css 接着在index.html引入,并且设置<meta> 有时候呢,为了让代码符合我们平时的编码习惯, ...
 - 项目vue2.0仿外卖APP(二)
		
vue-cli开启vue.js项目 github地址:https://github.com/vuejs/vue-cli Vue.js开发利器vue-cli,是vue的脚手架工具. 在工地上,脚手架是工 ...
 - 项目vue2.0仿外卖APP(三)
		
项目的结构如下: 项目资源准备 准备项目的各种图片资源等等 注意:在webpack可以不用css sprite,直接用单张图片,因为它会帮忙打包. 还有SVG图片, ...
 - Vue2.0仿饿了么webapp单页面应用
		
Vue2.0仿饿了么webapp单页面应用 声明: 代码源于 黄轶老师在慕课网上的教学视频,我自己用vue2.0重写了该项目,喜欢的同学可以去支持老师的课程:http://coding.imooc.c ...
 - vue2.0仿今日头条开源项目
		
vue-toutiao 这是用 vue.js 2.0 高仿 今日头条 的移动端项目,结合了原生app的部分功能以及网页版. 前言 本人是 今日头条 的重度用户,在学习vue.js过程中,在GitHub ...
 - vue2.0:(一)、vue的安装和项目搭建(以外卖app项目举例)
		
vue系列踩坑大作战由此就要开始了,准备好了吗,和我一起踩坑,学会vue吧.同时,也欢迎大家把自己遇到的坑发出来,让更多的人学会vue,因为我深知前端学习新框架不容易,尤其是我这种半路出家的女前端.不 ...
 
随机推荐
- go语言赋值
			
使用赋值语句可以更新一个变量的值,最简单的赋值语句是将要被赋值的变量放在=的左边,新值的表达式放在=的右边. x = // 命名变量的赋值 *p = true // 通过指针间接赋值 person.n ...
 - Intellij Idea 15 下新建 Hibernate 项目以及如何添加配置
			
1.说明:Idea 下,项目对应于 Eclipse 下的 workspace,Module 对应于 Eclipse 下的项目.Idea 下,新添加的项目既可以单独作为一个 Project,也可以作为一 ...
 - 使用backbone的history管理SPA应用的url
			
本文介绍如何使用backbone的history模块实现SPA应用里面的URL管理.SPA应用的核心在于使用无刷新的方式更改url,从而引发页面内容的改变.从实现上来看,url的管理和页面内容的管理是 ...
 - 设计模式(十三)代理模式(Proxy Pattern)
			
一.引言 在软件开发过程中,有些对象有时候会由于网络或其他的障碍,以至于不能够或者不能直接访问到这些对象,如果直接访问对象给系统带来不必要的复杂性,这时候可以在客户端和目标对象之间增加一层中间层,让代 ...
 - 【无私分享:ASP.NET CORE 项目实战(第六章)】读取配置文件(一) appsettings.json
			
目录索引 [无私分享:ASP.NET CORE 项目实战]目录索引 简介 在我们之前的Asp.net mvc 开发中,一提到配置文件,我们不由的想到 web.config 和 app.config,在 ...
 - python爬虫的一些心得
			
爬虫用于从网上得到目标数据,根据需要对其予以利用,加以分析,得到想要的实验成果.现在讲一讲我这两天学到的东西. 第一,爬虫的算法结构,包括以下几个方面: (1)读取网络数据 (2)将获取的数据解析为目 ...
 - spring aop对service层日志和异常的处理
			
1.aop是什么 AOP是Aspect Oriented Programming的缩写,意思是面向切面编程,与OOP(Object Oriented Programming)面向对象编程对等,都是一种 ...
 - Cobar + MySQL 技术验证(li)
			
一.简介 Cobar是一个对数据进行拆分后进行分布式存储的产品,可以支持使用后台的 MySQL或者Oracle数据库,通过配置,将数据按照一定规则存储入不同的数据库中.即用分布式数据库代替了集中式数据 ...
 - 20款 JavaScript 开发框架推荐给前端开发者
			
下面,我们给大家提供了一个用于 HTML5 开发的各种用途的 JavaScript 库列表.这些框架能够给前端开发人员提供更好的功能实现的解决方案.如果你有收藏优秀的框架,也可以在后面的评论中分享给我 ...
 - Android 使用pull,sax解析xml
			
pull解析xml文件 1.获得XmlpullParser类的引用 这里有两种方法 //解析器工厂 XmlPullParserFactory factory=XmlPullParserFactory. ...