模仿评论样式

news2025/8/6 16:08:37

在这里插入图片描述

  1. 主要用到了padding-left把左侧的空白给留出来,然后把头像定位到留出的空白位置。
  2. 行内对齐样式,使用了display:inline-flex;align-items:center;
  3. 图标本来要用字体比较方便,暂时用的从icon font下载的svg
  4. 样式写的一塌糊涂,一点也没考虑复用性
  5. 一直就想写出个评论样式,终于能写出来了,我太难了
  6. 后面再参考下:Vue2封装评论组件详细讲解
<template>
    <div class="comment-wrapper">

        <div class="one">
            <div class="main-comment">
                <div class="avatar">
                    <a href="#">
                        <img src="@/assets/avatar/avatar1.jpg" alt="">
                    </a>
                </div>
                <div class="main-commentor">
                    <span class="uname">初见Ta_U</span>
                    <img style="width:20px" src="@/assets/avatar/lv4.svg" alt="">
                </div>
                <div class="main-content">验证码老是错误是为什么呢</div>
                <div class="tipper">
                    <div class="left-tipper align-inline">
                        <span class="timing">2022-10-26 17:04</span>
                        <span class="like align-inline">
                            <img style="width:16px" src="@/assets/avatar/zan.svg" alt="">
                            <span>50</span>
                        </span>
                        <span class="dislike align-inline">
                            <img style="width:16px" src="@/assets/avatar/cai.svg" alt="">
                            <span>2</span>
                        </span>
                    </div>
                    <div class="right-tipper">
                        <img style="height:20px;" src="@/assets/avatar/dot.svg" alt="">
                    </div>
                </div>
            </div>

            <div class="sub-comment">
                <div class="avatar">
                    <a href="#">
                        <img src="@/assets/avatar/avatar2.jpg" alt="">
                    </a>
                </div>
                <div class="sub-commentor">
                    <span class="uname">伏月小九九</span>
                    <img style="width:20px" src="@/assets/avatar/lv4.svg" alt="">
                </div>
                <span class="sub-comment-content">我也是 我觉得不是打开方式不对我也是 我觉得不是打开方式不对我也是
                    我觉得不是打开方式不对我也是 我觉得不是打开方式不对我也是
                </span>
                <div class="tipper">
                    <div class="left-tipper align-inline">
                        <span class="timing">2022-10-27 18:46</span>
                        <span class="like align-inline">
                            <img style="width:16px" src="@/assets/avatar/zan.svg" alt="">
                            <span>8</span>
                        </span>
                        <span class="dislike align-inline">
                            <img style="width:16px" src="@/assets/avatar/cai.svg" alt="">
                            <span>1</span>
                        </span>
                    </div>
                    <div class="right-tipper">
                        <img style="height:20px;" src="@/assets/avatar/dot.svg" alt="">
                    </div>
                </div>
            </div>

            <div class="sub-comment">
                <div class="avatar">
                    <a href="#">
                        <img src="@/assets/avatar/avatar3.jpg" alt="">
                    </a>
                </div>
                <div class="sub-commentor">
                    <span class="uname">BYKang3</span>
                    <img style="width:20px" src="@/assets/avatar/lv3.svg" alt="">
                </div>
                <span class="sub-comment-content">
                    <span>回复</span> <a href="#">@伏月小九九 :</a>
                    解决了吗,我也是验证一值错误
                </span>
                <div class="tipper">
                    <div class="left-tipper align-inline">
                        <span class="timing">2022-10-26 17:04</span>
                        <span class="like align-inline">
                            <img style="width:16px" src="@/assets/avatar/zan.svg" alt="">
                            <span>2</span>
                        </span>
                        <span class="dislike align-inline">
                            <img style="width:16px" src="@/assets/avatar/cai.svg" alt="">
                            <span>3</span>
                        </span>
                    </div>
                    <div class="right-tipper">
                        <img style="height:20px;" src="@/assets/avatar/dot.svg" alt="">
                    </div>
                </div>
            </div>
        </div>

    </div>
</template>


<script lang="ts" setup>
import { ref, reactive, onMounted } from 'vue'

</script>

<style lang="scss">
.align-inline {
    display: inline-flex;
    align-items: center;
}

.comment-wrapper {
    width: 800px;
    height: 540px;
    margin: 20px auto;
    border: 1px dashed #ddd;
    border-radius: 5px;

    .main-comment {

        position: relative;

        padding-left: 80px;
        padding-top: 18px;
        margin-bottom: 20px;


        .avatar {

            width: 50px;
            height: 50px;
            border-radius: 50%;
            overflow: hidden;

            position: absolute;
            left: 10px;
            top: 10px;

            img {
                display: block;
                width: 100%;
                height: 100%;
            }
        }

    }

    .main-commentor {
        display: inline-flex;
        align-items: center;
        margin-bottom: 10px;

        .uname {
            color: #fb7299;
            font-size: 14px;
            font-family: 'Trebuchet MS', 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans', Arial, sans-serif;
            margin-right: 5px;
        }
    }

    .sub-comment {
        padding-left: 120px;
        padding-top: 5px;
        margin-bottom: 10px;
        position: relative;

        .avatar {
            width: 30px;
            height: 30px;
            border-radius: 50%;
            overflow: hidden;

            position: absolute;
            left: 80px;
            top: 0;

            img {
                width: 100%;
                height: 100%;
            }
        }

        .sub-commentor {
            color: #61666d;
            font-size: 14px;
            display: inline-flex;
            align-items: start;
            margin-right: 15px;

            .uname {
                margin-right: 5px;
            }
        }

        .sub-comment-content {
            color: #18191c;
        }
    }
}

.tipper {
    color: #9499a0;
    font-size: 14px;
    margin-top: 5px;
    display: flex;
    justify-content: space-between;

    .timing {
        margin-right: 10px;

    }

    .like {
        margin-right: 10px;

        img {
            margin-right: 5px;
        }
    }

    .like {
        margin-right: 10px;

        img {
            cursor: pointer;
            margin-right: 5px;
        }
    }

    .dislike {
        img {
            cursor: pointer;
            margin-right: 5px;
        }
    }

    .right-tipper {
        margin-right: 10px;

        img {
            cursor: pointer;
        }
    }
}

a {
    text-decoration: none;
    color: #008ac9;
}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/394103.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

说说转义字符 “\”

转义字符-escape character character 表示字符&#xff0c;包含两层含义&#xff0c; 1.字母 2.符号 转义&#xff1a; 改变含义 字符&#xff1a; 字母、符号 转义字符&#xff1a; 把 字母、符号 的含义改变了注意&#xff1a;这里有 2 个常常被忽视、忽略、轻视的转义规则&…

Java类加载器原理与实践

文章目录一、Java程序启动并运行的过程二、类加载器三、Java8内置的类加载器1. AppClassLoader2. ExtClassLoader3. BootStrap ClassLoader4. 3个类加载器之间的关系四、双亲委派模型五、关键类java.lang.ClassLoader1. loadClass(..)2. denfineClass(..)3. findClass(..)4. fi…

k8s client-go源码解析之informer 一

Informer(一) 注意&#xff1a;本文内容为学习笔记&#xff0c;内容为个人见解&#xff0c;不保证准确性&#xff0c;但欢迎大家讨论何指教。 本篇为先导篇&#xff0c; 介绍informer的入口工厂函数。 informer目录结构 (仅展示部分目录&#xff0c;省略的目录相似) clien…

项目实战典型案例27——对生产环境以及生产数据的敬畏之心

对生产环境以及生产数据的敬畏之心一&#xff1a;背景介绍总结升华一&#xff1a;背景介绍 本篇博客是对项目开发中出现的对生产环境以及生产数据的敬畏之心行的总结并进行的改进。目的是将经历转变为自己的经验。通过博客的方式分享给大家&#xff0c;大家一起共同进步和提高…

SpringCloud之 Gateway路由网关

文章目录Gateway 路由网关一、部署网关&#x1f34d;①添加依赖&#x1f34d;②设置配置文件&#x1f34d;③创建启动类&#x1f34d;④路由功能配置&#x1f34d;⑤路由访问服务二、路由过滤器2.1 单个过滤器: 配置文件2.2 全局过滤器: 自定义类提示&#xff1a;以下是本篇文章…

【数据结构初阶】详解链表OJ题

目录一.删除链表中等于给定值的节点二.合并有序链表并返回三.链表的回文结构1.反转单链表2.返回非空链表的中间节点四.输出链表倒数第K个节点五.基于给定值x分割单链表六.返回两个链表的第一个中间节点一.删除链表中等于给定值的节点 我们先来看第一题(题目链接): 因为我们需…

王道《操作系统》学习(二)—— 进程管理(一)

2.1 进程的概念、组成、特征、组织 2.1.1 进程的概念 这里像QQ这个程序执行了多次&#xff0c;虽然名字一样&#xff0c;但是它们的PID不同。 2.1.2 进程的组成 &#xff08;1&#xff09;PCB &#xff08;2&#xff09;程序段 和 数据段 小例子&#xff1a;程序是如何执行的&…

Nacos实现配置中心

文章目录配置中心提供的基础功能Nacos实现配置中心1、在配置文件增加配置&#xff08;application.yml&#xff09;2、使用Value来引用配置使用配置中心&#xff0c;怎样的配置方式呢一、安装nacos二、启动服务发现1、引入依赖2、配置文件3、开启服务注册发现功能4、启动服务三…

quarkus 生产环境与k8s集成总结

quarkus 生产环境与k8s集成总结 大纲 基础准备quarkus2.13.7脚手架工程配置GraalVM-java11 安装配置配置maven3.8.7linux环境下云原生二进制文件打包环境搭建编译运行quarkus二进制文件quarkus二进制文件制作为docker镜像并运行使用k8s部署quarkus二进制文件 基础准备 生产…

手把手交叉编译mysql

1.下载mysql&#xff08;注意下载boost版本&#xff0c;这样会少一步编译&#xff09; 下载mysql的时候一定要看好交叉编译工具链的版本。因为mysql 8.0需要的工具链版本较高&#xff0c;所以有可能不支持 查看链接如下&#xff1a; MySQL :: MySQL 8.0 Reference Manual :: …

InstructGPT方法简读

InstructGPT方法简读 引言 仅仅通过增大模型规模和数据规模来训练更大的模型并不能使得大模型更好地理解用户意图。由于数据的噪声极大&#xff0c;并且现在的大多数大型语言模型均为基于深度学习的“黑箱模型”&#xff0c;几乎不具有可解释性和可控性&#xff0c;因此&…

「SAP ABAP」OPEN SQL(四)【FROM语句】

&#x1f482;作者简介&#xff1a; THUNDER王&#xff0c;一名热爱财税和SAP ABAP编程以及热爱分享的博主。目前于江西师范大学会计学专业大二本科在读&#xff0c;同时任汉硕云&#xff08;广东&#xff09;科技有限公司ABAP开发顾问。在学习工作中&#xff0c;我通常使用偏后…

CIMCAI port ai shipping ai artificial intelligence smart port

上海人工智能独角兽中集集团高科技中集飞瞳&#xff0c;是全球应用落地最广&#xff0c;规模最大&#xff0c;最先进的的港航人工智能高科技企业&#xff0c;工业级成熟港航人工智能产品全球规模化落地应用&#xff0c;全球前三大船公司及港口码头应用落地。上海人工智能独角兽…

3.4 按键控制LED灯光敏传感器控制蜂鸣器

按键控制LED灯1.1 按键连接示意图1.2 代码设计1.21 设计思路我们要实现按键控制led&#xff0c;我们需要完成LED和按键驱动代码&#xff0c;但如果把这两部分代码都混在主函数里面&#xff0c;那么代码显得过于杂乱&#xff0c;不容易管理和移植&#xff0c;所以对于这种驱动代…

记一次反射型XSS

记一次反射型XSS1.反射型XSS1.1.前言1.2.测试过程1.3.实战演示1.3.1.输入框1.3.2.插入代码1.3.3.跳转链接2.总结1.反射型XSS 1.1.前言 关于这个反射型XSS&#xff0c;利用的方式除了钓鱼&#xff0c;可能更多的就是自娱自乐&#xff0c;那都说是自娱自乐了&#xff0c;并且对系…

Maxscale读写分离实施文档

Maxscale介绍 MaxScale是maridb开发的一个mysql数据中间件&#xff0c;其配置简单&#xff0c;能够实现读写分离&#xff0c;并且可以根据主从状态实现写库的自动切换。 使用Maxscale无需对业务代码进行修改&#xff0c;其自带的读写分离模块&#xff0c;能够解析SQL语句&…

DD-1/40 10-40mA型【接地继电器】

系列型号&#xff1a; DD-1/40接地继电器 DD-1/50接地继电器 DD-1/60接地继电器 一、 用途及工作原理 DD-1型接地继电器为瞬时动作的过电流继电器&#xff0c;用作小电流接地电力系统高电压三相交流发电机和电动机的接地零序过电流保护。继电器线圈接零序电流互感器(电缆式、母…

Vue动态粒子特效插件(背景线条吸附动画)

目录 效果图&#xff1a; 一、安装&#xff1a; 二、引入 main.js 文件&#xff1a; 三、使用&#xff1a; 四、属性说明&#xff1a; 效果图&#xff1a; 一、安装&#xff1a; npm install vue-particles --save 二、引入 main.js 文件&#xff1a; import VueParticles…

【C++】30h速成C++从入门到精通(多态)

多态的概念多态&#xff1a;通俗来说就是多种心态&#xff0c;具体点就是去完成某个行为&#xff0c;当不同的对象去完成时会产生出不同的状态。多态的定义及实现多态的构成条件多态是在不同继承关系的类对象&#xff0c;去调用同意函数&#xff0c;产生了不同的行为&#xff0…

C/C++每日一练(20230307)

目录 1. 国名排序 ★★ 2. 重复的DNA序列 ★★★ 3. 买卖股票的最佳时机 III ★★★ &#x1f31f; 每日一练刷题专栏 C/C 每日一练 ​专栏 Python 每日一练 ​专栏 1. 国名排序 小李在准备明天的广交会&#xff0c;明天有来自世界各国的客房跟他们谈生意&#xff0c…