## 评论子组件的封装和引用 1. 在 项目的 创建`src -> sub-components` 目录; 2. 创建一个标准的vue组件,命名为 `Comment.vue`, 作为我们的评论子组件 3. 哪个页面需要引用这个评论组件了,就在页面的 script 节点中,通过 import 的形式,导入此组件 4. 在 页面的 script 中,通过 `components`属性注册导入的评论组件 5. 把注册的组件名称,以标签形式,引入到页面上,就能够看到这个评论子组件了; --------------------------------- // 1.导入 Comment.vue 子组件 import comment from "../sub-components/Comment.vue"; //2注册 components: { // 为当前的 NewsInfo.vue 组件注册私有的子组件 comment } //3. <!-- 这里评论组件的位置 --> <!-- 父组件向子组件传值,通过 属性绑定的形式 --> <comment :newsid="id"></comment>
评论组件--comment.vue
props: ["newsid"] // 接收父组件传递过来的新闻Id
//请求数据-----这里的id直接可以引用--不用在data里声明了
data() {
return {
page: 1, // 默认展示第一页的评论
cmtlist: [], // 评论数组
msg: "" // 即将发表的评论内容
};
},
methods:{
getComments() {
this.$http.get(
"/api/getcomments/" + this.newsid + "?pageindex=" + this.page
)
.then(res => {
获取数据
})
}
}
<!-- 评论列表区域 --> <div class="cmt-list"> <div class="cmt-item" v-for="(item, i) in cmtlist" :key="i"> <div class="cmt-item-title">第{{ i+1 }}楼 用户:{{ item.user_name }} 发表时间:{{ item.add_time | dateFormat }}</div> <div class="cmt-item-body">{{ item.content }}</div> <!-- {{item.content === 'undefined' ? '此用户很懒,啥也没说' : item.content}} --> </div> </div>
<style lang="scss" scoped>
textarea {
font-size: 14px;
margin: 0;
}
.cmt-list {
margin-top: 4px;
.cmt-item {
line-height: 30px;
.cmt-item-title {
font-size: 14px;
background-color: #ddd;
}
.cmt-item-body {
font-size: 13px;
text-indent: 2em;
}
}
}
</style>
完整代码
<template> <div> <h4>发表评论 --- {{ newsid }}</h4> <hr> <textarea placeholder="请输入要BB的内容(最多吐槽120字)" maxlength="120" v-model="msg"></textarea> <mt-button type="primary" size="large" @click="postMsg">发表评论</mt-button> <!-- 评论列表区域 --> <div class="cmt-list"> <div class="cmt-item" v-for="(item, i) in cmtlist" :key="i"> <div class="cmt-item-title">第{{ i+1 }}楼 用户:{{ item.user_name }} 发表时间:{{ item.add_time | dateFormat }}</div> <div class="cmt-item-body">{{ item.content }}</div> </div> </div> <mt-button type="danger" size="large" plain @click="loadMore">加载更多</mt-button> </div> </template> <script> // 按需从 MintUI 中,导出需要的 弹框组件 import { Toast } from "mint-ui"; export default { data() { return { page: 1, // 默认展示第一页的评论 cmtlist: [], // 评论数组 msg: "" // 即将发表的评论内容 }; }, created() { this.getCommentByPage(); }, methods: { async getCommentByPage() { // 根据页数来获取评论的数据 const { data } = await this.$http.get( "/api/getcomments/" + this.newsid + "?pageindex=" + this.page ); if (data.status === 0) return (this.cmtlist = this.cmtlist.concat(data.message)); }, loadMore() { // 点击按钮,加载更多的评论 // 当触发这个加载更多方法的时候,应该让 page 页码 + 1 之后,再调用 getCommentByPage 方法 this.page++; this.getCommentByPage(); }, async postMsg() { // 点击发表评论: // 如果用户没有填写评论内容,则阻止其发表评论 if (this.msg.trim().length <= 0) return Toast("请填写评论内容!"); // 发表评论的逻辑: const { data } = await this.$http.post( "/api/postcomment/" + this.newsid, { content: this.msg.trim() } ); if (data.status === 0) { // 刷新评论列表 // 1. 再次调用 getCommentByPage() // console.log("ok"); // // 获取评论之前,先把之前所有的评论清空 // this.cmtlist = []; // this.getCommentByPage(); // 为了防止重新调用 getCommentByPage 方式时候,会把 之前的所有评论清空的问题: // 我们 在客户端,手动拼接出一个 评论的对象,并把 这个评论对象, unshift 到 cmtlist 中 this.cmtlist.unshift({ user_name: "匿名用户", add_time: new Date(), content: this.msg.trim() }); this.msg = ""; } } }, props: ["newsid"] // 接收父组件传递过来的新闻Id }; </script> <style lang="scss" scoped> textarea { font-size: 14px; margin: 0; } .cmt-list { margin-top: 4px; .cmt-item { line-height: 30px; .cmt-item-title { font-size: 14px; background-color: #ddd; } .cmt-item-body { font-size: 13px; text-indent: 2em; } } } </style>