Vue.js组件开发-实现广告图片浮动随屏幕滚动

实现步骤

  1. 创建 Vue 项目:使用 Vue CLI 快速搭建一个新的 Vue 项目。
  2. 编写 HTML 结构:在 Vue 组件中定义广告图片的 HTML 结构。
  3. 添加 CSS 样式:设置广告图片的初始样式和浮动效果。
  4. 添加 JavaScript 逻辑:监听窗口滚动事件,根据滚动位置更新广告图片的位置。

详细代码及注释

1. 创建 Vue 项目

安装 Vue CLI,可以使用以下命令进行安装:

npm install -g @vue/cli

然后创建一个新的 Vue 项目:

vue create ad-floating-demo
cd ad-floating-demo
2. 编写组件代码

src/components 目录下创建一个名为 AdFloating.vue 的组件,代码如下:

<template><!-- 广告图片容器 --><div id="ad-floating" :style="{ top: adTop + 'px' }"><!-- 广告图片 --><img src="https://via.placeholder.com/200x300" alt="广告图片" /></div>
</template><script>
export default {data() {return {// 广告图片距离顶部的初始位置initialTop: 100,// 广告图片当前距离顶部的位置adTop: 100};},mounted() {// 当组件挂载完成后,监听窗口滚动事件window.addEventListener('scroll', this.handleScroll);},beforeDestroy() {// 在组件销毁前,移除窗口滚动事件监听器,避免内存泄漏window.removeEventListener('scroll', this.handleScroll);},methods: {handleScroll() {// 获取窗口滚动的垂直距离const scrollTop = window.pageYOffset || document.documentElement.scrollTop;// 更新广告图片的位置,使其跟随滚动this.adTop = this.initialTop + scrollTop;}}
};
</script><style scoped>
#ad-floating {/* 固定定位,使广告图片相对于浏览器窗口定位 */position: fixed;/* 距离右侧 20px */right: 20px;/* 初始距离顶部 100px */top: 100px;/* 设置广告图片容器的宽度 */width: 200px;/* 设置广告图片容器的高度 */height: 300px;/* 为广告图片容器添加边框 */border: 1px solid #ccc;/* 为广告图片容器添加内边距 */padding: 10px;/* 为广告图片容器添加背景颜色 */background-color: #fff;/* 为广告图片容器添加阴影效果 */box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}#ad-floating img {/* 使图片宽度适应容器 */width: 100%;/* 使图片高度适应容器 */height: 100%;/* 保持图片的宽高比,同时覆盖整个容器 */object-fit: cover;
}
</style>
3. 在 App.vue 中使用组件

打开 src/App.vue 文件,将 AdFloating 组件引入并使用,代码如下:

<template><div id="app"><!-- 引入 AdFloating 组件 --><AdFloating /><!-- 模拟页面内容 --><div style="height: 2000px; padding: 20px;"><h1>页面内容</h1><p>这是一个模拟的页面内容,用于测试广告图片的浮动效果。</p></div></div>
</template><script>
// 引入 AdFloating 组件
import AdFloating from './components/AdFloating.vue';export default {name: 'App',components: {// 注册 AdFloating 组件AdFloating}
};
</script><style>
#app {font-family: Avenir, Helvetica, Arial, sans-serif;-webkit-font-smoothing: antialiased;-moz-osx-font-smoothing: grayscale;text-align: center;color: #2c3e50;margin-top: 60px;
}
</style>

使用说明

  1. 运行项目:在项目根目录下,使用以下命令启动开发服务器:
npm run serve
  1. 访问页面:打开浏览器,访问 http://localhost:8080,你将看到一个带有广告图片的页面。
  2. 测试浮动效果:滚动页面,广告图片将跟随滚动,始终保持在页面的右侧。

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

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

相关文章

苹果再度砍掉AR眼镜项目?AR真的是伪风口吗?

曾经&#xff0c;AR游戏一度异常火热&#xff0c;宝可梦go让多少人不惜翻墙都要去玩&#xff0c;但是也没过去几年&#xff0c;苹果被曝出再度砍掉了AR眼镜项目&#xff0c;面对着市场的变化&#xff0c;让人不禁想问AR真的是伪风口吗&#xff1f; 一、苹果再度砍掉AR眼镜项目&…

关于deepseek的一些普遍误读

最近deepseek成为全球最热门的话题&#xff0c;甚至没有之一&#xff0c;无论是北美&#xff0c;欧洲&#xff0c;各大IT巨头&#xff0c;各个投资机构&#xff0c;政府官员&#xff0c;乃至脱口秀演员&#xff0c;都在不断提及这个话题&#xff0c;而国内&#xff0c;自媒体也…

Vue 3 30天精进之旅:Day 15 - 插件和指令

欢迎来到“Vue 3 30天精进之旅”的第15天&#xff01;今天我们将深入探讨Vue 3中的插件和自定义指令。这两个主题能够帮助我们扩展Vue的功能&#xff0c;使我们的应用更加灵活和强大。 一、插件概述 1. 什么是插件&#xff1f; 在Vue中&#xff0c;插件是一种功能扩展机制。…

PostgreSQL 数据库备份与还原

为了安全与数据共享等&#xff0c;创建好的数据库有时候需要备份操作和还原操作。数据库的备份与还原主要是三个命令&#xff1a;pg_dump、pg_dumpall 和 pg_restore 。 其中pg_dump用于备份单个数据库&#xff0c;它支持多种备份格式&#xff08;SQL、自定义等&#xff09;&a…

排序算法--计数排序

唯一种没有比较的排序(指没有前后比较,还是有交换的)。统计每个元素出现的次数&#xff0c;直接计算元素在有序序列中的位置&#xff0c;要求数据是整数且范围有限。适用于数据为小范围整数&#xff08;如年龄、成绩&#xff09;&#xff0c;数据重复率较高时效率更优。可用于小…

Ubuntu重启搜狗输入法

Ubuntu的搜狗输入法重启_ubuntu sogou reset-CSDN博客 # fictx自带的重启 fcitx -r

C#结合html2canvas生成切割图片并导出到PDF

目录 需求 开发运行环境 实现 生成HTML范例片断 HTML元素转BASE64 BASE64转图片 切割长图片 生成PDF文件 小结 需求 html2canvas 是一个 JavaScript 库&#xff0c;它可以把任意一个网页中的元素&#xff08;包括整个网页&#xff09;绘制到指定的 canvas 中&#xf…

java进阶专栏的学习指南

学习指南 java类和对象java内部类和常用类javaIO流 java类和对象 类和对象 java内部类和常用类 java内部类精讲Object类包装类的认识String类、BigDecimal类初探Date类、Calendar类、SimpleDateFormat类的认识java Random类、File类、System类初识 javaIO流 java IO流【…

static成员变量的本质?静态变量?静态类有什么意义?全局变量?类函数?

static成员变量的本质 面向对象编程语言喜欢将全局变量转移到类内部变成static变量&#xff0c;看起来不像全局变量。事实上&#xff0c;编译器会将static成员变量和全局变量看做的一样的&#xff0c;编程语言的写法减少程序员随意操作全局变量的可能&#xff0c;虽然事实上它们…

RK3566-移植5.10内核Ubuntu22.04

说明 记录了本人使用泰山派&#xff08;RK3566&#xff09;作为平台并且成功移植5.10.160版本kernel和ubuntu22.04&#xff0c;并且成功配置&连接网络的完整过程。 本文章所用ubuntu下载地址&#xff1a;ubuntu-cdimage-ubuntu-base-releases-22.04-release安装包下载_开源…

笔记day7

文章目录 1 分页功能实现2 分页器的展示需要哪些数据&#xff08;条件&#xff09;&#xff1f;3 自定义分页器4 分页器存在问题5 分页器动态展示6 开发某一个商品的详情页面 1 分页功能实现 为什么很多项目采用分页功能&#xff0c;比如电商平台同时展示的数据有很多&#xf…

【starrocks学习】之将starrocks表同步到hive

目录 方法 1&#xff1a;通过HDFS导出数据 1. 将StarRocks表数据导出到HDFS 2. 在Hive中创建外部表 3. 验证数据 方法 2&#xff1a;使用Apache Spark同步 1. 添加StarRocks和Hive的依赖 2. 使用Spark读取StarRocks数据并写入Hive 3. 验证数据 方法 3&#xff1a;通过…

stm32点灯 GPIO的输出模式

目录 1.选择RCC时钟 2.SYS 选择调试模式 SW 3.GPIO 配置 4.时钟树配置&#xff08; 默认不变&#xff09;HSI 高速内部时钟8Mhz 5.项目配置 6.代码 延时1s循环LED亮灭 1.选择RCC时钟 2.SYS 选择调试模式 SW 3.GPIO 配置 4.时钟树配置&#xff08; 默认不变&#xff09…

Docker基础以及单体实战

Docker 一、Docker1.1 Docker组成1.2 Dcoker运行图1.3 名称空间Namepace 1.4 docker、Docker compose、kubermetes 二、Docker安装2.1 在线Docker安装2.2 使用官方通用安装脚本2.3 二进制安装Docker三、Docker基础命令3.1 启动类3.2 镜像类3.3 容器类3.4 网络类3.5 Docker comp…

搭建Python环境:为量化交易做准备

搭建Python环境&#xff1a;为量化交易做准备 在量化交易的世界里&#xff0c;一个稳定且高效的Python环境是成功的关键。本文将指导您如何从零开始搭建适用于量化交易的本地Python环境&#xff0c;并介绍一些常用的代码编辑器和工具。 Python环境安装指南 官网安装&#xf…

Vue.js组件开发

Vue.js 是一个用于构建用户界面的渐进式 JavaScript 框架&#xff0c;组件化开发是 Vue.js 的核心特性之一&#xff0c;它允许你将页面拆分成多个小的、可复用的组件&#xff0c;从而提高代码的可维护性和可复用性。以下是关于 Vue.js 组件开发的详细介绍&#xff1a; 1. 组件…

备考蓝桥杯嵌入式7——ADC电压采集

目录 ADC电压采集 代码书写 ADC电压采集 ADC的含义就是将一个范围内的电压映射成为数字传入进来。举个例子&#xff0c;当我们想要做一个非常简单的电压测量计的时候&#xff0c;使用ADC就会将我们的模拟电压信号转化为数字电压信号。 我们的板子上有两个电压采集旋钮&#…

【大模型实战】0代码基于DeepSeek-R1搭建本地知识库,打造专属智能助手

【大模型实战】0代码基于DeepSeek-R1搭建本地知识库,打造专属智能助手 一、ollama下载与安装二、部署deepseek私有模型三、部署embedding模型四、可视化操作工具(1)下载与安装工具(2)部署安装的模型(3) 添加知识库(4)添加智能体助手(5) 助手问答一、ollama下载与安装…

Java进阶(vue基础)

目录 1.vue简单入门 ?1.1.创建一个vue程序 1.2.使用Component模板(组件&#xff09; 1.3.引入AXOIS ?1.4.vue的Methods&#xff08;方法&#xff09; 和?compoted&#xff08;计算&#xff09; 1.5.插槽slot 1.6.创建自定义事件? 2.Vue脚手架安装? 3.Element-UI的…

Java 面试真题

本题适合一到三年 Java 开发 &#xff0c;以下问题都是按照原面试官提问记录 文章目录 我要进大厂系列面试题二面 我要进大厂系列面试题 全部真题&#xff0c;欢迎投稿你的面试经验。 本篇涉及基础较多&#xff0c;但要耐性看完。 JVM内存模型垃圾回收器用的哪个gc各个算法…