博客友链效果

news2025/1/11 10:11:57

在这里插入图片描述

学习风`宇blog

  • flex布局使用百分比作2栏网格布局,内部也是使用flex布局做左图右文
  • 使用IntersectionObserver这个浏览器提供的Api,配合vue指令,当元素出现在可视区时,添加上移的动画效果。注意:元素的初始状态,是visibility:hidden隐藏状态的,然后达到可视区时,通过添加类名的方式,来指定动画和让visibility:visible可见。
  • 图片也是通过el.getBoundingClientRect()这个api,配合vue指令,在bind初始化时候,就把src给换成data-src,src使用默认图片,然后,在inserted时,作第一次图片加载(有可能图片在未滚动时就已经在可视区了),并且监听滚动事件,当图片出现在可视区时,再把data-src的值给src
  • 向下加载更多效果
<style lang="scss">
/* 封面图下移效果 */
@keyframes slidedown {
    0% {
        opacity: 0.3;
        transform: translateY(-60px);
    }

    100% {
        opacity: 1;
        transform: translateY(0px);
    }
}

.slidedown {
    animation: slidedown 1s;
}

/* 内容上移效果 */
@keyframes slideup {
    0% {
        opacity: 0.3;
        transform: translateY(60px);
    }

    100% {
        opacity: 1;
        transform: translateY(0px);
    }
}

.slideup {
    animation: slideup 1s;
}

/* 旋转加载效果 */
@keyframes spinLoading {
    0% {
        transform: rotate(0);
    }

    100% {
        transform: rotate(360deg);
    }
}

.spinLoading {
    animation: spinLoading 1s infinite;
}

.banner {
    height: 400px;
    background-image: url(@/assets/bg4.jpg);
    background-size: cover;
    background-position: center;
    position: relative;
    color: #eee;

    .banner-content {
        position: absolute;
        bottom: 25%;
        width: 100%;
        text-align: center;
        text-shadow: 0.05rem 0.05rem 0.1rem rgb(0 0 0 / 30%);

        height: 108px;
        font-size: 30px;
        letter-spacing: 0.3em;

    }
}

* {
    box-sizing: border-box;
}

a {
    text-decoration: none;
    color: inherit;
}

p {
    margin: 0;
}

@keyframes slideUpBigIn {
    0% {
        transform: translateY(40px);
        opacity: 0;
    }

    100% {
        transform: translateY(0);
        opacity: 1;
    }
}

.aniSlideUpBigIn {
    animation: slideUpBigIn 1s;
    visibility: visible !important;
}


.friend-link-wrapper {
    display: flex;
    // border: 1px solid red;
    max-width: 1200px;
    margin: 40px auto;

    padding: 40px 30px;
    border-radius: 10px;

    .description {
        flex-grow: 1;
        line-height: 2em;

        h1 {
            margin: 0 20px;
            margin-left: 40px;
            font-weight: bold;
            font-size: 20px;
            position: relative;

            &::before {
                content: '\e888';
                font-family: "iconfont";
                font-weight: normal;
                color: #49b1f5;
                position: absolute;
                left: -1.5em;
            }
        }

        .welcome {
            margin: 0 60px;
            position: relative;

            &::before {
                content: '';
                position: absolute;
                width: 5px;
                height: 5px;
                background-color: red;
                top: 1em;
                left: -0.7em;
                border-radius: 50%;
            }
        }

        blockquote {
            background-color: #daefff;
            border-left: 4px solid #3cc1ff;
            border-radius: 5px;
            padding: 5px 10px;
        }
    }

    .friends {
        display: flex;
        flex-wrap: wrap;
        padding: 20px 40px;

        .friend {
            width: calc(50% - 20px);
            display: flex;
            margin: 10px;
            border-radius: 10px;
            box-shadow: 0 2px 8px 0px rgba(0, 0, 0, 0.08);

            visibility: hidden;

            .fl-avatar {
                width: 100px;
                height: 100px;
                border-radius: 5px;
                overflow: hidden;
                margin-right: 10px;
                padding: 10px;

                img {
                    height: 100%;
                    width: 100%;
                    object-fit: cover;
                    border-radius: 5px;
                    transition: all 0.3s;

                    &:hover {
                        transform: scale(1.2);
                    }
                }
            }

            .fl-info {
                flex: 1;
                padding-top: 8px;
                padding-right: 10px;

                // overflow: hidden;
                a {
                    display: block;
                    color: #5abdff;
                    font-weight: bold;
                    margin-bottom: 6px;
                }

                p {
                    font-size: 14px;
                    color: #3e3e3e;
                    line-height: 1.3;
                    display: -webkit-box;
                    -webkit-box-orient: vertical;
                    -webkit-line-clamp: 2;
                    overflow: hidden;
                    word-break: break-all;
                }
            }
        }
    }

    .load-more {
        text-align: center;
        color: #3e3e3e;

        .more-again {
            .loading-text {
                cursor: pointer;
                color: #5abdff;

                i {
                    font-size: 12px;
                }
            }

            .loading-ani {
                display: flex;
                color: #3e3e3e;
                align-items: center;
                justify-content: center;

                .loading-icon {
                    i {
                        display: block;
                        width: 2em;
                        height: 2em;
                        font-size: 1.6em;
                        // border: 1px solid red;
                        display: flex;
                        align-items: center;
                        justify-content: center;
                    }
                }
            }
        }

        .no-more {
            color: #ccc;
            user-select: none;
        }
    }
}
</style>

<template>
    <div>
        <navbar />
        <div class="banner slidedown">
            <div style="position: absolute;top: 0;left: 0;width: 100%;height: 100%;backdrop-filter: blur(5px);"></div>
            <div class="banner-content">
                <div>友情链接</div>
            </div>
        </div>

        <div class="friend-link-wrapper shadow slideup">

            <div class="description">

                <h1>本站信息</h1>
                <blockquote>
                    <p>名称: Halo world</p>
                    <p>简介: 热爱技术一点点的学习</p>
                    <p>头像: http://xxxx</p>
                </blockquote>
                <h1>申请方法</h1>
                <p class="welcome">需要交换友链的可在本页留言</p>
                <blockquote>
                    处于信息需要,大佬你的信息格式要包含:网站名称、网站链接、头像链接、网站介绍、名称颜色
                </blockquote>
                <h1>小伙伴们</h1>

                <div>
                    <div class="friends">
                        <div class="friend" v-slideUp>
                            <a href="#" class="fl-avatar">
                                <img v-lazy1 style="" src="@/assets/fl/fl1.png" alt="">
                            </a>
                            <div class="fl-info">
                                <a href="#" class="fl-link">冰箱主人のBlog</a>
                                <p>冰箱里什么都没有呢</p>
                            </div>
                        </div>
                        <div class="friend" v-slideUp>
                            <a href="#" class="fl-avatar">
                                <img v-lazy1 style="" src="@/assets/fl/fl2.png" alt="">
                            </a>
                            <div class="fl-info">
                                <a href="#" class="fl-link">優萌初華</a>
                                <p>琉璃的医学 & 编程笔记</p>
                            </div>
                        </div>
                        <div class="friend" v-slideUp>
                            <a href="#" class="fl-avatar">
                                <img v-lazy1 style="" src="@/assets/fl/fl3.png" alt="">
                            </a>
                            <div class="fl-info">
                                <a href="#" class="fl-link">Sady'Blog</a>
                                <p>永远年轻,永远热泪盈眶.</p>
                            </div>
                        </div>
                        <div class="friend" v-slideUp>
                            <a href="#" class="fl-avatar">
                                <img v-lazy1 style="" src="@/assets/fl/fl4.png" alt="">
                            </a>
                            <div class="fl-info">
                                <a href="#" class="fl-link">漫漫</a>
                                <p>漫漫即慢慢啊~</p>
                            </div>
                        </div>
                        <div class="friend" v-slideUp>
                            <a href="#" class="fl-avatar">
                                <img v-lazy1 style="" src="@/assets/fl/fl5.png" alt="">
                            </a>
                            <div class="fl-info">
                                <a href="#" class="fl-link">2T的固态</a>
                                <p>DaVan的个人博客</p>
                            </div>
                        </div>
                        <div class="friend" v-slideUp>
                            <a href="#" class="fl-avatar">
                                <img v-lazy1 style="" src="@/assets/fl/fl6.png" alt="">
                            </a>
                            <div class="fl-info">
                                <a href="#" class="fl-link">八尺妖剑</a>
                                <p>惟有热爱,可抵岁月漫长!</p>
                            </div>
                        </div>
                        <div class="friend" v-slideUp>
                            <a href="#" class="fl-avatar">
                                <img v-lazy1 style="" src="@/assets/fl/fl7.png" alt="">
                            </a>
                            <div class="fl-info">
                                <a href="#" class="fl-link">花未眠的个人博客</a>
                                <p>一个疯狂的coder</p>
                            </div>
                        </div>
                        <div class="friend" v-slideUp>
                            <a href="#" class="fl-avatar">
                                <img v-lazy1 style="" src="@/assets/fl/fl8.png" alt="">
                            </a>
                            <div class="fl-info">
                                <a href="#" class="fl-link">Big_fw</a>
                                <p>Try the best</p>
                            </div>
                        </div>
                        <div class="friend" v-slideUp>
                            <a href="#" class="fl-avatar">
                                <img v-lazy1 style="" src="@/assets/fl/fl9.png" alt="">
                            </a>
                            <div class="fl-info">
                                <a href="#" class="fl-link">皮皮龙</a>
                                <p>一位无所事事的大学码农</p>
                            </div>
                        </div>
                        <div class="friend" v-slideUp>
                            <a href="#" class="fl-avatar">
                                <img v-lazy1 style="" src="@/assets/fl/fl10.png" alt="">
                            </a>
                            <div class="fl-info">
                                <a href="#" class="fl-link">忻辰</a>
                                <p>忻辰</p>
                            </div>
                        </div>
                        <div class="friend" v-for="friend, idx in friendList" :key="idx" v-slideUp>
                            <a href="#" class="fl-avatar">
                                <img v-lazy1 style="" :src="friend.avatar" alt="">
                            </a>
                            <div class="fl-info">
                                <a href="#" class="fl-link">{{ friend.name }}</a>
                                <p>{{ friend.bio }}</p>
                            </div>
                        </div>
                    </div>
                    <div class="load-more">
                        <div v-show="hasMore" class="more-again">
                            <div v-show="!isLoading" class="loading-text" @click="loadMore">
                                加载更多 <i class="iconfont icon-gengduo"></i>
                            </div>
                            <div v-show="isLoading" class="loading-ani">
                                <span class="loading-icon spinLoading">
                                    <i class="iconfont icon-jiazai"></i>
                                </span>
                            </div>
                        </div>
                        <div v-show="!hasMore" class="no-more">
                            已经到底了~
                        </div>
                    </div>
                </div>


            </div>

        </div>

        <Footer></Footer>

    </div>
</template>

<script>
import Navbar from '@/views/Navbar'
import Footer from '@/views/Footer'

let img1 = require('@/assets/fl/fl1.png')


export default {
    name: 'FriendLink',
    methods: {
        showInfo(e) {
            alert('同学你好!')
            // console.log(e.target)
        }, showMsg(msg) {
            console.log(msg)
        },
    },
    data() {
        return {
            hasMore: true,
            isLoading: false,
            loadingCount: 0,
            friendList: []
        }
    },
    methods: {
        loadMore() {
            this.isLoading = true
            if (this.loadingCount <= 2) {
                this.loadingCount++
                setTimeout(() => {
                    this.isLoading = false
                    this.friendList.push(
                        {
                            name: 'pscool',
                            bio: '热爱技术,一点点的学习1',
                            avatar: img1
                        },
                        {
                            name: 'pscool2',
                            bio: '热爱技术,一点点的学习2',
                            avatar: img1
                        },
                        {
                            name: 'pscool3',
                            bio: '热爱技术,一点点的学习3',
                            avatar: img1
                        },
                        {
                            name: 'pscool4',
                            bio: '热爱技术,一点点的学习4',
                            avatar: img1
                        }
                    )
                    if(this.loadingCount == 2) {
                        this.hasMore = false
                    }
                }, 1500)
                
            }
        }
    },
    directives: {
        slideUp: {
            inserted(el, binding) {
                let observer = new IntersectionObserver((entries) => {
                    for (let entry of entries) {
                        if (entry.isIntersecting) {
                            console.log('出现。。。');
                            el.classList.add('aniSlideUpBigIn');
                            observer.unobserve(el)
                        }
                    }
                }, { threshold: 0.5 })
                observer.observe(el)
            }
        }
    },
    components: {
        Navbar, Footer
    }
}
</script>

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

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

相关文章

Clion 创建的Qt程序界面是老式风格

环境&#xff1a; Clion版本&#xff1a;CLion 2023.1.1Qt 5.15.2 问题 当使用Clion创建Qt程序&#xff0c;不管是选择MinGW编译器还是MSVC编译器&#xff0c;显示出来的界面都很old style 即老式的界面风格&#xff0c;如图所示&#xff1a; 原因 产生这个问题的原因是…

现在培训IT技术出来还能就业吗?

受疫情影响&#xff0c;近三年各行业都是在裁员节流&#xff0c;直接倒闭的也是常态。互联网企业也不能幸免于难&#xff0c;被裁掉了一大波基础或中级技术岗位&#xff0c;还有一部分中高层领导降薪。然后就到处疯传IT行业不行了&#xff0c;大家都失业了&#xff0c;但你知道…

算法训练第五十六天 | 583. 两个字符串的删除操作、72. 编辑距离、编辑距离总结篇

这里写自定义目录标题583. 两个字符串的删除操作题目描述思路动态规划一动态规划二72. 编辑距离&#xff08;困难&#xff09;题目描述思路编辑距离总结篇583. 两个字符串的删除操作 题目链接&#xff1a;583. 两个字符串的删除操作 参考&#xff1a;https://programmercarl.c…

clickhouse跳表索引最佳实践--minmax索引+Set索引

背景 我们知道对于clickhouse这种列式存储数据库来说&#xff0c;它虽然也提供了与mysql的btree的二级索引类似的跳表索引的功能&#xff0c;但是其实跳表索引和btree的二级索引有根本上的不同&#xff0c;比如mysql的二级索引一般来说应用于高基数的列的效果是最佳的&#xf…

SpringMVC入门以及工作流程详解

什么是MVC MVC是一种分层方法&#xff0c;其三层分别是模型&#xff08;Model&#xff09;&#xff0c;视图&#xff08;View&#xff09;和控制器&#xff08;Controller&#xff09;。是一种软件设计规范。MVC可以将软件的逻辑、数据和业务相分离&#xff0c;其主要作用是消除…

SpringCloud-Alibaba学习笔记03——nacos管理界面详细介绍和注册中心配置详解

一、nacos管理界面详细介绍 nacos服务管理界面如图所示&#xff1a; 1、创建服务和隐藏空服务 我们可以看到在界面上有个隐藏空服务的按钮&#xff0c;我们打开该按钮之后&#xff0c;服务列表并没有发生变化&#xff0c;这个按钮有啥用呢&#xff1f; 该按钮的作用就是隐藏…

St link V2驱动安装方法

前言 st-link v2又便宜又好用&#xff0c;是ARM单片机开发的必备神器。本文面向初学者介绍如何给windows安装stlink 驱动&#xff0c;并在keil v5进行配置。 操作系统&#xff1a;windows11&#xff0c; Keil版本&#xff1a;keil v5 mdk5.37. st-link驱动云盘共享地址&#x…

OSS下载中文名编码错误

最近工作中有个需求&#xff0c;是将客户支付的银行回执单上按照客户姓名上传到oss&#xff0c;然后将oss地址反显到pc后台&#xff0c;供客户自己查看下载。 开始的时候感觉很简单&#xff0c;设计思路是根据客户支付单单号&#xff0c;查询数据库中是否存在该支付单的回执单&…

Java生成二维码之Graphics2D自定义码眼形状

Java 2D API 提供了几个类来定义常见的几何对象&#xff0c;例如点、直线、曲线和矩形。这些几何类是 java.awt.geom包的一部分。通过熟练使用Graphics2D类&#xff0c;可以绘制出任意类型的图形。 官网教程地址&#xff1a;https://docs.oracle.com/javase/tutorial/2d/geome…

【虹科案例】固态量子发射器——虹科数字化仪用于控制钻石色心中的脉冲序列

前言 钻石的色心是晶格中的缺陷&#xff0c;其中碳原子被不同种类的原子取代&#xff0c;相邻的晶格位置是空的。由于其明亮的单光子发射和光学可访问的自旋&#xff0c;色心可以成为未来量子信息处理和量子网络的有前途的固态量子发射器。 实现自旋量子比特和相干光子纠缠的两…

基于RK3568的Linux驱动开发—— GPIO知识点(二)

authordaisy.skye的博客_CSDN博客-嵌入式,Qt,Linux领域博主系列基于RK3568的Linux驱动开发——GPIO知识点&#xff08;一&#xff09;_daisy.skye的博客-CSDN博客 查看goio使用情况 cat /sys/kernel/debug/gpio 1|rk3568_r:# cat /sys/kernel/debug/gpio gpiochip0: GPIOs 0-3…

English Learning - L2-14 英音地道语音语调 重音技巧 2023.04.10 周一

English Learning - L2-14 英音地道语音语调 重音技巧 2023.04.10 周一课前热身重音日常表达节奏单词全部重读的句子间隔时间非重读单词代词和缩约词助动词声临其境语调预习课前热身 学习目标 重音 重弱突出&#xff0c;重音突出核心表达的意思 重音是落在重读单词上&#x…

Vue3简介

1.Vue3简介 2020年9月18日&#xff0c;Vue.js发布3.0版本&#xff0c;代号&#xff1a;One Piece&#xff08;海贼王&#xff09;耗时2年多、[2600次提交](https://github.com/vuejs/vue-next/graphs/commit-activity)、[30个RFC](https://github.com/vuejs/rfcs/tree/master/…

机器学习 | 实验四:正则化

⭐对应笔记&#xff1a;正则化 &#x1f4da;描述 在这个练习中&#xff0c;你将实现正则化的线性回归和正则化的逻辑回归。 &#x1f4da;数据 这个数据包包含两组数据&#xff0c;一组用于线性回归&#xff0c;另一个用于逻辑回归。还包含一个名为"map_feature"…

Win11快速打开便签和使用技巧分享

Win11快速打开便签和使用技巧分享。Win11系统中为用户提供了一个非常实用的系统组件&#xff0c;就是便签功能&#xff0c;使用这个功能可以帮助我们便捷的进行一些重要内容的记录。那么如何去开启开启这个程序来使用呢&#xff1f;来看看以下的详情分享吧。 详细分享&#xff…

docker介绍与安装

目录 Docker docker概述 容器化优点 虚拟化架构 docker与虚拟机区别 docker三大核心概念 docker运行的原理 Docker安装 查看 docker 版本信息 docker 信息查看 Docker docker概述 Docker是一个开源的应用容器引擎&#xff0c;基于go语言开发并遵循了apache2.0协议开…

Perceiver Perceiver IO: 人工智能的多功能工具

如今人工智能系统使用的大多数架构都是专业的。2D 残差网络可能是处理图像的一个很好的选择&#xff0c;但它最多只能用于其他类型的数据&#xff0c;比如自动驾驶汽车中使用的激光雷达信号或机器人中使用的 torques。此外&#xff0c;标准架构在设计时通常只考虑一项任务&…

Seal AppManager发布:基于平台工程理念的全新应用部署管理体验

4月12日&#xff0c;数澈软件Seal&#xff08;以下简称“Seal”&#xff09;宣布推出新一代应用统一部署管理平台 Seal AppManager&#xff0c;采用平台工程的理念&#xff0c;降低基础设施操作的复杂度为研发和运维团队提供易用、一致的应用管理和部署体验&#xff0c;进而提升…

SpringMVC使用介绍-快速入门

文章目录SpringMVCSpringMVC快速入门bean加载控制SpringMVC SpringMVC快速入门 SpringMVC是一种基于Java实现MVC模型的轻量级Web框架 优点 使用简单&#xff0c;开发便捷&#xff08;相比于Servlet&#xff09; 灵活性强 使用SpringMVC技术开发web程序流程: 1.创建web工程&a…

[牛客复盘] 牛客小白月赛70 20230407

[牛客复盘] 牛客小白月赛70 20230407 一、本周周赛总结A、 小d和答案修改2. 思路分析3. 代码实现B、小d和图片压缩1. 题目描述2. 思路分析3. 代码实现C、小d和超级泡泡堂1. 题目描述2. 思路分析3. 代码实现D、小d和孤独的区间1. 题目描述2. 思路分析3. 代码实现E、小d的博弈1. …