zoukankan      html  css  js  c++  java
  • Vue---评论组件

    ## 评论子组件的封装和引用
    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 }}楼&nbsp;用户:{{ item.user_name }}&nbsp;发表时间:{{ 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>
  • 相关阅读:
    是什么阻止你达成人生的目标?
    安装cocoa pods
    Mac安装mysql
    Mac安装jee开发环境,webservice环境搭建
    Mac使用Github
    从一个app开始学iOS
    Macbook Pro开机黑屏了。
    U盘安装OSX
    数据分析有时候的结果并不令人满意
    vmvare fusion 8
  • 原文地址:https://www.cnblogs.com/fdxjava/p/11635123.html
Copyright © 2011-2022 走看看