一、前言

1、渲染评论列表

2、点击加载按钮,加载更多

   3、提交评论

二、主要内容

1、评论列表一般是注册到一个全局的公共组件中

2、请求后台数据,渲染评论列表

  (1)数据格式如下

地址

/api/getcomments/:artid?pageindex=1

作用描述

根据资讯id获取它的评论的分页信息

请求方式

Get

传入api的参数

artid: 资讯id,这个id是用来区分是哪一个页面中的评论数据

pageindex: 分页的页码,表示当前第几页

传入url写法: /api/getcomments/43?pageindex=1

返回数据格式

Json

返回数据格式样例

 

 

  (2)如何获取到父组件的id,  这里用到子父组件通信

  a:在父组件中用自定义一个cid属性

<Comment   :cid="$route.query.id"    />

//获取到路由上面的id参数

  b:在子组件Comment.vue中接收这个属性,然后作为Comment里面的查询参数

    props:['cid'], //接收到父组件定义的自定义属性

  c:根据上面接收到的自定义属性进行查询,查询到对应的评论信息

d:用户还可能输入url地址中的page来查询

data(){
return {
comments:[]
}
}, created(){
//用户在查看评论列表的时候还可能在上面输入
let page = this.$route.query.page || '1'; //从url地址中获取到当前的page,如果没有默认加载第一页
//查询的时候带着这个page查询
this.$axios.get(`getcomments/${this.cid}?pageindex=${page}`)
.then(res=>{
console.log(res.data.message);
this.comments=res.data.message;
})
.catch(err=>{
console.log('数据请求失败',err);
}) }

3、查看评论,点击加载按钮,加载更多(通常评论信息不会全部渲染到页面中的,)

  (1)给按钮注册一个loadMore()方法,点击的时候传进去url地址栏中的page

<Button @click='loadMore(page)'>加载更多</Button>

  (2)声明loadMore()

    (3)当用户每点击一次的时候,就让当前的page++

 export default{
name:'Comment',
props:['cid'],//接受父组件传过来的自定义属性
data(){
return {
comments:[],
page:1
}
}, methoods:{
loadMore(page){
this.$axios.get(`getcomments${this.cid}?pageindex=${this.page}`)
.then(res=>{
console.log(res.data.message);
this.comments=res.data.message; if(page){
//表示加载更多,将新一页的数据追加到原来的里面
this.comments = this.comments.concat(res.data.message);
}else{ //否则第一次加载
this.comments = res.data.message;
} this.page++; })
.catch(err=>{
console.log('数据请求失败',err);
}) }
},
created(){
//用户在查看评论列表的时候还可能在上面输入
let page = this.$route.query.page || '1'; //
this.loadMore(page); }

4、提交评论

  (1)数据如下

地址

/api/postcomment/:artid

作用描述

给某条资讯进行评论

请求方式

Post

传入api的参数

artid: 资讯id,

content: 评论的内容

传入url写法:/api/postcomment/43

请求报文体Body格式:

content=评论内容

  (2)点击提交按钮,执行提交按钮方法,并且要个文本域双向数据绑定

                <li class="txt-comment">
<textarea v-model='commentContent'></textarea>
</li>
<li>
<button @click='commentHandle'>提交</button>
</li>

  (3)在methods中定义

//处理提交评论请求,并且将评论信息,添加到postcomment/:${this.cid}中

 commentHandle(){
this.$axios.post(`postcomment/:${this.cid}`,'conetent='+this.commentContent)
.then(res=>{
console.log(res.data.message); })
.catch(err=>{
console.log('评论失败',err);
}) }

  (4)提交评论信息之后还需要清空当前这个评论框的文本内容,然后再加载第一页数据

 methoods:{
commentHandle(){
this.$axios.post(`postcomment/:${this.cid}`,'conetent='+this.commentContent)
.then(res=>{
console.log(res.data.message); this.commentContent=''; //清空评论框
this.page=1;//然后加载第一页数据
this.loadMore(); })
.catch(err=>{
console.log('评论失败',err);
}) },

三、总结

1、查看评论,用户可能要查看其它页的评论信息,所以在请求的时候带了一个page参数

2、加载更多,用户每次点击加载更多按钮,让当前的page++, 并且将新请求到的一页的数据用concat连接到上次请求到的数据中

3、提交评论,用post提交,提交了之后要清空当前的文本域,然后再加载第一页的数据

Vue(小案例_vue+axios仿手机app)_实现用户评论的更多相关文章

  1. Vue(小案例_vue+axios仿手机app)_购物车(二模拟淘宝购物车页面,点击加减做出相应变化)

    一.前言 在上篇购物车中,如果用户刷新了当前的页面,底部导航中的数据又会恢复为原来的: 1.解决刷新,购物车上数值不变                                         ...

  2. Vue(小案例_vue+axios仿手机app)_购物车

    一.前言 1.购物车 二.主要内容 1.效果演示如下,当我们选择商品数量改变的时候,也要让购物车里面的数据改变 2.具体实现 (1)小球从上面跳到下面的效果 (2)当点击上面的“加入购物车按钮”让小球 ...

  3. Vue(小案例_vue+axios仿手机app)_公共组件(路由组件传参)

    一.前言                    1.公共轮播图的实现                    2.组件传参,公共组件的实现 二.主要内容 1.公共轮播图的实现 (1)分析:当渲染不同的轮 ...

  4. Vue(小案例_vue+axios仿手机app)_上拉加载

    ---恢复内容开始--- 一.前言                                                                                    ...

  5. Vue(小案例_vue+axios仿手机app)_图片列表操作

    一.前言 1.让图片还没有被完全加载出来的时候给用户提示                                       2.图片查看器 二.主要内容 1.让图片还没有被完全加载出来的时候 ...

  6. Vue(小案例_vue+axios仿手机app)_首页(底部导航栏+轮播图+九宫格)

    ---恢复内容开始--- 一.前言                        1.底部导航(两种做法)                                         2.轮播图 ...

  7. Vue(小案例_vue+axios仿手机app)_图文列表实现

    一.前言 1.导航滑动实现   2.渲染列表信息时让一开始加载的时候就请求数据 3.根据路由的改变,加载图文的改变(实现用户访问网站时可能执行的三个操作) 二.主要内容 1.导航滑动实现: (1)演示 ...

  8. Vue(小案例_vue+axios仿手机app)_购物车(计算商品总金额)

    一.前言                 1.计算总金额                 2.点击删除按钮,删除对应的商品信息                 3.当还没结算的时候,当用户跳到其他页面 ...

  9. Vue(小案例_vue+axios仿手机app)_Vuex优化购物车功能

    一.前言         1.用vuex实现加入购物车操作 2.购物车详情页面          3.点击删除按钮,删除购物详情页面里的对应商品 二.主要内容 1.用vuex加入购物车 (1)在src ...

随机推荐

  1. SQLServer之创建表值函数

    表值函数创建注意事项 用户定义表值函数返回 table 数据类型. 对于内联表值函数,没有函数主体,表是单个 SELECT 语句的结果集. 表值函数主要用于数据计算出来返回结果集. 使用SSMS数据库 ...

  2. Python XML解析之DOM

    DOM说明: DOM:Document Object Model API DOM是一种跨语言的XML解析机制,DOM把整个XML文件或字符串在内存中解析为树型结构方便访问. https://docs. ...

  3. mysql安装和配置(windowns||centos)

    windows10版本安装 1.获取mysql压缩包 https://dev.mysql.com/downloads/mysql/ 2.解压并配置文件my.ini .解压的文件路径 D:\Progra ...

  4. SQL Server -- 回忆笔记(四):case函数,索引,子查询,分页查询,视图,存储过程

    SQL Server知识点回忆篇(四):case函数,索引,子查询,分页查询,视图,存储过程 1. CASE函数(相当于C#中的Switch) then '未成年人' else '成年人' end f ...

  5. 【idea】Springboot整合jpa

    第一步快速搭建springboot项目:在你建立的工程下创建 Module 选择Spring initializr创建. 第二步:修改包名.项目名.web项目打成war包.在Type处选择: Mave ...

  6. 4.13Python数据处理篇之Matplotlib系列(十三)---轴的设置

    目录 目录 前言 (一)设置轴的范围 1.同时对于x,y轴设置 2.分别对与x,y轴的设置 (二)设置刻度的大小 1.普通的刻度设置 2.添加文本的刻度设置 3.主副刻度的设置 (三)设置轴的数据 1 ...

  7. GitHub的初级使用

    最近准备学习一个GitHub的使用 一.账号创建 1.百度找到GitHub官方网站(https://github.com/ ) 2.点击Sign up注册GitHub账号 下图为注册页面 第一步:填写 ...

  8. 5.机器学习——DBSCAN聚类算法

    1.优缺点 优点: (1)聚类速度快且能够有效处理噪声点和发现任意形状的空间聚类: (2)与K-MEANS比较起来,不需要输入要划分的聚类个数: (3)聚类簇的形状没有偏倚: (4)可以在需要时输入过 ...

  9. 【Python 21】52周存钱挑战1.0

    1.案例描述 按照52周存钱法,存钱人必须在一年52周内,每周递存10元.例如,第一周存10元,第二周存20元,第三周存30元,直到第52周存520元. 记录52周后能存多少钱?即10+20+30+. ...

  10. 迷茫<第三篇:再到北京>

    这是2016年初春,三月的北京仍带着丝丝的冷意,我再次来到了这座熟悉又陌生的城市.我是早上6点钟到的北京西站,坐火车过来的,一夜未眠,眼睛很疲劳.这次过来和上次回长沙一样,下了火车先把行李寄存在朋友家 ...