uni-app项目实战笔记1--创建项目和实现首页轮播图功能

ps:本笔记来自B站咸虾米壁纸项目

一.创建项目,完成项目初始化搭建

1.在HBuilder X创建wallper项目,使用默认模块,选择vue;

2.在项目根目录下创建common目录,用于存放静态资源,创建项目时自动生成static目录,之所以不把静态资源放到static目录下,是因为放在static目录下,不管文件是否引用都会打包进去,而放到common目录只会将引用到的文件打包到项目包里,我们应该尽量控制包的大小;

3.在common目录下新建images目录用于存放图片资源,新建style目录存放样式文件;

4.在style目录下新建common-style.scss文件,写入下面折代码:

view{box-sizing: border-box;
}

box-sizing: border-box:为所有元素设置盒模型。为border-box声明表示元素的宽度(width)和高度(height)将包含:

  • 内容区(content)
  • 内边距(padding)
  • 边框(border)

这种设置的好处:

  • 更直观的尺寸控制
  • 简化布局计算
  • 响应式设计中更易处理百分比宽度

5.在程序主入口文件App.vue引入上面的scss文件,作为全局样式:

<style lang="scss">@import "common/style/common-style.scss";/*每个页面公共css */
</style>

 二. 首页banner效果的实现

在首页index.vue引入轮播图组件:

<template><view class="homeLayout"><view class="banner"><swiper indicator-dots indicator-color="rgba(255, 255, 255, 0.5)" indicator-active-color="#fff" autoplay circular><swiper-item ><image src="/common/images/banner1.jpg" mode="aspectFill"></image></swiper-item><swiper-item ><image src="/common/images/banner2.jpg" mode="aspectFill"></image></swiper-item><swiper-item ><image src="/common/images/banner3.jpg" mode="aspectFill"></image></swiper-item></swiper></view></view>
</template>

上面的代码实现的效果:

1. 轮播图功能
自动轮播 (autoplay):图片会自动切换,无需用户手动操作。

循环播放 (circular):滑动到最后一张后,会无缝衔接回到第一张,形成无限循环。

指示器 (indicator-dots):显示底部的小圆点,标识当前轮播的位置。

indicator-color="rgba(255, 255, 255, 0.5)":未选中的指示点颜色(半透明白色)。

indicator-active-color="#fff":当前选中的指示点颜色(纯白色)。

2. 图片展示
图片填充模式 (mode="aspectFill"):图片会按比例缩放,填满整个容器,可能会被裁剪,但不会变形。

3. 布局结构
最外层是 homeLayout 容器,用于整体页面布局。

banner 类包裹 swiper,用于控制轮播图的样式(如宽度、高度、边距等)。

SCSS部分的代码:

<style lang="scss" scoped>.homeLayout{.banner{width: 750rpx;padding: 30rpx 0;swiper{width: 750rpx;height: 340rpx;swiper-item{width: 100%;height: 100%;padding: 0 30rpx;image{width: 100%;height: 100%;border-radius: 10rpx;}}}}}
</style>

代码解释:

1. 外层容器布局 (homeLayout 和 banner)
宽度固定 750rpx(表示满屏宽度)。

上下内边距 30rpx,使轮播图与上下内容保持间距。

2. 轮播图 (swiper) 样式
宽度 750rpx(占满容器宽度)。

高度 340rpx(固定高度)。

轮播项 (swiper-item):

占满父容器 (width: 100%; height: 100%),继承自父类。

左右内边距 30rpx,使图片不紧贴屏幕边缘,留出呼吸空间。

3. 图片 (image) 样式
宽度和高度 100%(填满 swiper-item 的可用空间),继承自父类。

圆角 10rpx,使图片四角变圆润,提升视觉效果。

最终效果
轮播图宽度占满屏幕(750rpx)。

高度固定(340rpx),图片比例不变(aspectFill 模式)。

图片两侧有间距(padding: 0 30rpx),避免图片紧贴屏幕边缘。

图片带圆角(border-radius: 10rpx),视觉更柔和。

整体上下有留白(padding: 30rpx 0),避免与其他内容挤在一起。

重要事项说明:
rpx 单位:是小程序/Uniapp 的响应式单位,会根据屏幕宽度自适应缩放(750rpx ≈ 100% 屏幕宽度)。

scoped 作用域:样式仅作用于当前组件,避免影响其他页面。

aspectFill 模式(在 image 组件中定义):确保图片按比例缩放并填满容器,可能部分内容被裁剪,但不会变形。

最终实现的效果:

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

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

相关文章

机械制造系统中 PROFINET 与 PROFIBUS-DP 的融合应用及捷米科技解决方案

在机械制造领域&#xff0c;工业通信网络的兼容性与灵活性直接影响产线的自动化水平与生产效率。当前&#xff0c;多数机械制造系统采用PROFINET 控制器构建核心网络架构&#xff0c;并通过微波无线连接实现设备互联。随着工业网络的发展&#xff0c;系统中常需同时集成PROFINE…

MCP 协议系列序言篇:开启 AI 应用融合新时代的钥匙

文章目录 序言&#xff1a;AI 应用层进入 MCP 时代为什么 MCP 开启 AI 应用融合新时代的钥匙为什么是 MCP&#xff1f;它与 Function Calling、Agent 有什么区别&#xff1f;Function CallingAI AgentMCP&#xff08;Model Context Protocol&#xff09; MCP 如何工作MCP Serve…

【threejs】每天一个小案例讲解:光照

代码仓 GitHub - TiffanyHoo/three_practices: Learning three.js together! 可自行clone&#xff0c;无需安装依赖&#xff0c;直接liver-server运行/直接打开chapter01中的html文件 运行效果图 知识要点 常见光照类型及其特点如下&#xff1a; 1. 环境光&#xff08;Ambi…

大模型在输尿管下段积水预测及临床应用的研究

目录 一、引言 1.1 研究背景与意义 1.2 研究目的 1.3 研究范围与限制 1.4 文献综述 1.5 研究方法和框架 二、相关理论与概念 2.1 大模型技术原理 2.2 输尿管下段积水病理机制 2.3 大模型在医学预测领域的应用 三、大模型预测输尿管下段积水的方法 3.1 数据收集 3.…

gitlab相关操作

2025.06.11今天我学习了如何在终端使用git相关操作&#xff1a; 一、需要修改新的仓库git地址的时候&#xff1a; &#xff08;1&#xff09;检查当前远程仓库 git remote -v 输出示例&#xff1a; origin https://github.com/old-repo.git (fetch) origin https://github.c…

51c自动驾驶~合集58

我自己的原文哦~ https://blog.51cto.com/whaosoft/13967107 #CCA-Attention 全局池化局部保留&#xff0c;CCA-Attention为LLM长文本建模带来突破性进展 琶洲实验室、华南理工大学联合推出关键上下文感知注意力机制&#xff08;CCA-Attention&#xff09;&#xff0c;…

通过共享内存在多程序之间实现数据通信

注&#xff1a;以下内容为与 GPT-4O 共同创作完成 以共享内存的方式实现多程序之间的数据通信&#xff0c;尤其适合在一台机器上的多程序之间进行高频数据交换。 以下示例展示了 sender.py 向 receiver.py 发送数据并接收经 receiver.py 处理后的数据&#xff0c;以及如何通过…

[论文阅读] 人工智能+软件工程 | 理解GitGoodBench:评估AI代理在Git中表现的新基准

理解GitGoodBench&#xff1a;评估AI代理在Git中表现的新基准 论文信息 GitGoodBench: A Novel Benchmark For Evaluating Agentic Performance On Git Tobias Lindenbauer, Egor Bogomolov, Yaroslav Zharov Cite as: arXiv:2505.22583 [cs.SE] 研究背景&#xff1a;当AI走进…

开源 java android app 开发(十二)封库.aar

文章的目的为了记录使用java 进行android app 开发学习的经历。本职为嵌入式软件开发&#xff0c;公司安排开发app&#xff0c;临时学习&#xff0c;完成app的开发。开发流程和要点有些记忆模糊&#xff0c;赶紧记录&#xff0c;防止忘记。 相关链接&#xff1a; 开源 java an…

ubuntu + nginx 1.26 + php7.4 + mysql8.0 调优

服务器配置 8核 16G 查看内存 free -h nginx配置 worker_processes auto; # 自动检测CPU核心数 worker_rlimit_nofile 65535; # 提高文件描述符限制 ​ events {worker_connections 8192; # 每个worker的最大连接数multi_accept on; # 一次性接受…

[未验证]abaqus2022 更改内置python

如何在 Abaqus 2022 中更改内置 Python 在 Abaqus 中&#xff0c;Python 是常用的脚本语言&#xff0c;它使得用户能够自动化模型的创建、分析和后处理。可能有时候你需要更改默认的 Python 版本&#xff0c;比如使用特定库或者功能。本文将为您详细说明如何在 Abaqus 2022 中更…

RAG文档解析难点2:excel数据“大海捞针”,超大Excel解析与精准行列查询指南

写在前面 在构建检索增强生成(RAG)应用时,Excel文件是不可或缺的数据源。它们通常包含了企业运营、市场分析、科学研究等各个领域的宝贵数据。然而,当这些Excel文件变得“超大”——可能包含数十万甚至数百万行数据时,传统的解析方法和RAG数据处理流程将面临严峻的内存、…

深度掌控,智启未来 —— 基于 STM32F103RBT6 的控制板

在科技浪潮奔涌向前的时代&#xff0c;电子领域的创新发展从未停歇。对于电子工程师、科研工作者以及电子技术爱好者&#xff0c;在校电子专业学生而言&#xff0c;一款性能卓越、功能全面且稳定可靠的开发板&#xff0c;是探索电子世界奥秘、实现创意构想的关键基石。今天&…

什么样的登录方式才是最安全的?

目录 一、基础协议&#xff1a;HTTP与HTTPS HTTP协议 HTTPS协议 二、常见Web攻击与防御 2.1 XSS 常见攻击手段 针对XSS 攻击窃取 Cookie 2.2 CSRF CSRF攻击的核心特点 与XSS的区别 常见防御措施 三、疑问解答 四、登录方式演变 4.1 方案一&#x1f436;狗都不用 …

android studio底部导航栏

实现底部导航栏切换 将java文件return的xml文件赋值给页面FrameLayout控件 java文件BottomNavigationView&#xff0c;监听器setOnNavigationItemSelectedListener MainActivity.java代码 package com.example.myapplication;import android.os.Bundle;import androidx.appc…

vue-router相关理解

一、前言 随着 Vue.js 在前端开发中的广泛应用&#xff0c;Vue Router 成为了 Vue 官方推荐的路由管理器。它不仅支持单页面应用&#xff08;SPA&#xff09;中常见的路由跳转、嵌套路由、懒加载等功能&#xff0c;还提供了导航守卫、动态路由等高级特性。 本文将带你深入了解…

uni-app 自定义路由封装模块详解(附源码逐行解读)

&#x1f680;uni-app 自定义路由封装模块详解&#xff08;附源码逐行解读&#xff09; &#x1f4cc; 请收藏 点赞 关注&#xff0c;获取更多 uni-app 项目实用技巧&#xff01; 在实际 uni-app 项目中&#xff0c;我们常常需要对 uni.navigateTo、uni.switchTab 等 API 做…

QML显示图片问题解决办法

以前用qtwediget的时候&#xff0c;好像是放在qlabel或者什么组件上面&#xff0c;把图片的路径放上去就可以直接加载&#xff0c;但我用QML创建界面的时候就遇到了问题&#xff0c;哦对&#xff0c;qtwedget用qpixmap组件显示图片&#xff0c;也有image。话说回来&#xff0c;…

Vue中使用jsx

1. jsx的babel配置 1.1 在项目中使用jsx&#xff0c;需要添加对jsx的支持&#xff1a; jsx通常会通过Babel来进行转换(React编写的jsx就是通过babel转换的)Vue中&#xff0c;只需要在Babel中配置对应的插件即可以下列举需要支持转换的案例&#xff1a; template -> vue-l…

Spring Cache+Redis缓存方案 vs 传统redis缓存直接使用RedisTemplate 方案对比

结合 Spring Cache 和 Redis 的缓存方案&#xff08;即 Spring Cache Redis&#xff09;相较于普通的 Redis 缓存使用&#xff08;如直接通过 RedisTemplate 操作&#xff09;&#xff0c;具有以下显著优势&#xff1a; 具体实现方案请参考&#xff1a;Spring CacheRedis缓存…