Uni-App CSS 样式开发指南
目录
- 基础概念
- 布局与盒模型
- [Flexbox 布局](#Flexbox 布局)
- [Grid 布局](#Grid 布局)
- 常用样式属性
- 响应式设计
- [UI 样式示例](#UI 样式示例)
- 微信小程序样式适配
- 动画与过渡
- 常见问题与解决方案
- 性能优化
- 工具与资源
- 总结
- 高级技巧
- 实战案例
- 社区与学习资源
- 附录
基础概念
1.1 CSS 简介
CSS(Cascading Style Sheets)用于描述 HTML 或 XML 文档的呈现方式,包括布局、颜色、字体等样式。在 Uni-App 中,CSS 用于定义跨平台应用的界面样式。
1.2 Uni-App 中的 CSS
Uni-App 支持标准的 CSS 语法,但由于跨平台特性,部分样式在不同平台(如微信小程序、H5、App)上可能存在差异。因此,编写 CSS 时需注意平台兼容性。
1.3 样式单位
- px:像素单位,固定大小。
- rpx:微信小程序专用单位,1rpx = 屏幕宽度 / 750,适合响应式布局。
- em:相对于父元素的字体大小。
- rem:相对于根元素的字体大小。
- %:百分比单位,常用于宽度和高度。
布局与盒模型
2.1 盒模型
每个元素都被视为一个矩形盒子,包含以下部分:
- 内容区(Content):显示实际内容。
- 内边距(Padding):内容与边框之间的空间。
- 边框(Border):围绕内容和内边距的边框。
- 外边距(Margin):盒子与其他元素之间的空间。
css
.box {
width: 300px;
height: 200px;
padding: 20px;
border: 1px solid #ccc;
margin: 10px;
}
2.2 布局方式
- 块级元素 :独占一行,如
div
、p
。 - 行内元素 :不独占一行,如
span
、a
。 - 行内块元素 :兼具块级和行内特性,如
img
。
css
.block {
display: block;
}
.inline {
display: inline;
}
.inline-block {
display: inline-block;
}
Flexbox 布局
3.1 Flexbox 简介
Flexbox 是一种一维布局模型,适合在单行或单列中排列元素。
3.2 容器属性
- display: flex:启用 Flexbox 布局。
- flex-direction :定义主轴方向(
row
、column
、row-reverse
、column-reverse
)。 - justify-content :主轴对齐方式(
flex-start
、flex-end
、center
、space-between
、space-around
)。 - align-items :交叉轴对齐方式(
flex-start
、flex-end
、center
、stretch
、baseline
)。 - flex-wrap :是否换行(
nowrap
、wrap
、wrap-reverse
)。
css
.container {
display: flex;
flex-direction: row;
justify-content: space-between;
align-items: center;
flex-wrap: wrap;
}
3.3 项目属性
- flex-grow:定义项目的放大比例。
- flex-shrink:定义项目的缩小比例。
- flex-basis:定义项目的初始大小。
- align-self:单个项目的交叉轴对齐方式。
css
.item {
flex-grow: 1;
flex-shrink: 0;
flex-basis: 100px;
align-self: flex-end;
}
Grid 布局
4.1 Grid 简介
Grid 是一种二维布局模型,适合在行和列中排列元素。
4.2 容器属性
- display: grid:启用 Grid 布局。
- grid-template-columns:定义列宽。
- grid-template-rows:定义行高。
- gap:定义行和列之间的间距。
css
.container {
display: grid;
grid-template-columns: 1fr 2fr 1fr;
grid-template-rows: 100px 200px;
gap: 10px;
}
4.3 项目属性
- grid-column:定义项目占据的列。
- grid-row:定义项目占据的行。
- grid-area:定义项目在网格中的位置。
css
.item {
grid-column: 1 / 3;
grid-row: 1 / 2;
grid-area: 1 / 1 / 2 / 3;
}
常用样式属性
5.1 背景与颜色
- background-color:背景颜色。
- background-image:背景图片。
- background-size:背景图片大小。
- color:文本颜色。
css
.element {
background-color: #f0f0f0;
background-image: url('bg.png');
background-size: cover;
color: #333;
}
5.2 文本与字体
- font-size:字体大小。
- font-weight:字体粗细。
- text-align:文本对齐方式。
- line-height:行高。
css
.text {
font-size: 16px;
font-weight: bold;
text-align: center;
line-height: 1.5;
}
5.3 边框与圆角
- border:边框样式。
- border-radius:圆角半径。
- box-shadow:阴影效果。
css
.box {
border: 1px solid #ccc;
border-radius: 8px;
box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.1);
}
响应式设计
6.1 媒体查询
通过媒体查询实现不同屏幕尺寸下的样式适配。
css
@media screen and (max-width: 768px) {
.container {
flex-direction: column;
}
}
6.2 响应式单位
使用 rpx
或 %
实现响应式布局。
css
.element {
width: 100%;
height: 50rpx;
}
UI 样式示例
7.1 按钮样式
css
.button {
display: inline-block;
padding: 10px 20px;
background-color: #007bff;
color: #fff;
border-radius: 4px;
text-align: center;
cursor: pointer;
}
7.2 卡片样式
css
.card {
background-color: #fff;
border-radius: 8px;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
padding: 16px;
margin: 10px;
}
7.3 导航栏样式
css
.navbar {
display: flex;
justify-content: space-between;
align-items: center;
background-color: #333;
color: #fff;
padding: 10px 20px;
}
微信小程序样式适配
8.1 单位适配
微信小程序推荐使用 rpx
单位,确保在不同设备上显示一致。
css
.element {
width: 750rpx; /* 满屏宽度 */
height: 100rpx;
}
8.2 样式隔离
微信小程序默认启用样式隔离,避免样式污染。可通过 options
配置关闭隔离。
json
{
"styleIsolation": "apply-shared"
}
动画与过渡
9.1 CSS 动画
通过 @keyframes
定义动画,使用 animation
属性应用动画。
css
@keyframes fadeIn {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
.element {
animation: fadeIn 1s ease-in-out;
}
9.2 CSS 过渡
通过 transition
属性实现平滑的样式变化。
css
.button {
background-color: #007bff;
transition: background-color 0.3s ease;
}
.button:hover {
background-color: #0056b3;
}
9.3 动画性能优化
- 使用
transform
和opacity
实现动画,避免使用top
、left
等属性。 - 启用硬件加速:
transform: translateZ(0)
。
css
.element {
transform: translateZ(0);
transition: transform 0.3s ease;
}
.element:hover {
transform: scale(1.1);
}
常见问题与解决方案
10.1 样式不生效
- 问题:样式未正确应用。
- 解决方案 :
- 检查选择器是否正确。
- 确保样式优先级(使用
!important
或提高选择器权重)。 - 检查是否被其他样式覆盖。
css
/* 提高优先级 */
.element {
color: red !important;
}
10.2 平台差异
- 问题:样式在微信小程序和 H5 上表现不一致。
- 解决方案 :
- 使用条件编译区分平台样式。
- 使用
rpx
单位适配微信小程序。
css
/* 条件编译 */
/* #ifdef MP-WEIXIN */
.element {
width: 750rpx;
}
/* #endif */
10.3 布局错乱
- 问题:布局在不同设备上错乱。
- 解决方案 :
- 使用 Flexbox 或 Grid 布局。
- 避免固定宽度,使用百分比或
rpx
。
css
.container {
display: flex;
justify-content: space-between;
}
性能优化
11.1 减少样式嵌套
- 避免过深的嵌套选择器,减少渲染性能开销。
css
/* 不推荐 */
.container .box .item {
color: red;
}
/* 推荐 */
.item {
color: red;
}
11.2 避免频繁重绘
- 减少使用
box-shadow
、border-radius
等消耗性能的属性。 - 使用
will-change
提示浏览器优化。
css
.element {
will-change: transform;
}
11.3 压缩与合并样式
- 使用工具(如 Webpack)压缩和合并 CSS 文件,减少请求数量。
工具与资源
12.1 CSS 预处理器
- Sass:增强 CSS 功能,支持变量、嵌套、混合等。
- Less:类似 Sass,语法更接近原生 CSS。
scss
// Sass 示例
$primary-color: #007bff;
.button {
background-color: $primary-color;
}
12.2 CSS 框架
- Uni-UI:Uni-App 官方 UI 组件库。
- Vant Weapp:微信小程序 UI 组件库。
12.3 在线工具
- CSS Generator:快速生成 CSS 代码。
- Autoprefixer:自动添加浏览器前缀。
总结
本指南涵盖了 Uni-App 中 CSS 样式开发的核心知识点,包括布局、Flexbox、Grid、响应式设计、动画、常见问题与解决方案等。通过掌握这些内容,您可以高效地开发跨平台应用,并确保样式在不同设备上的一致性。
在实际开发中,建议结合具体需求灵活运用这些技术,同时关注性能优化和平台差异,以提升用户体验。
高级技巧
14.1 自定义属性(CSS 变量)
CSS 变量(Custom Properties)允许定义可重用的值,适合主题切换或动态样式。
css
:root {
--primary-color: #007bff;
--secondary-color: #6c757d;
}
.button {
background-color: var(--primary-color);
color: var(--secondary-color);
}
14.2 伪元素与伪类
- 伪元素 :如
::before
、::after
,用于添加装饰性内容。 - 伪类 :如
:hover
、:active
,用于定义元素的状态样式。
css
.button::before {
content: "★";
margin-right: 5px;
}
.button:hover {
background-color: #0056b3;
}
14.3 多列布局
使用 column-count
和 column-gap
实现多列文本布局。
css
.article {
column-count: 2;
column-gap: 20px;
}
14.4 混合模式
通过 mix-blend-mode
实现元素与背景的混合效果。
css
.overlay {
background-color: rgba(255, 0, 0, 0.5);
mix-blend-mode: multiply;
}
实战案例
15.1 响应式导航栏
实现一个在移动端和桌面端表现不同的导航栏。
html
<template>
<view class="navbar">
<view class="logo">Logo</view>
<view class="menu">
<view class="menu-item">Home</view>
<view class="menu-item">About</view>
<view class="menu-item">Contact</view>
</view>
</view>
</template>
<style>
.navbar {
display: flex;
justify-content: space-between;
align-items: center;
padding: 10px 20px;
background-color: #333;
color: #fff;
}
.menu {
display: flex;
}
.menu-item {
margin-left: 20px;
}
@media screen and (max-width: 768px) {
.menu {
display: none;
}
}
</style>
15.2 卡片列表
实现一个带有阴影和圆角的卡片列表。
html
<template>
<view class="card-list">
<view class="card" v-for="item in 5" :key="item">
<view class="card-title">Card {{ item }}</view>
<view class="card-content">This is card content.</view>
</view>
</view>
</template>
<style>
.card-list {
display: flex;
flex-wrap: wrap;
gap: 20px;
padding: 20px;
}
.card {
background-color: #fff;
border-radius: 8px;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
padding: 16px;
width: calc(33.33% - 20px);
}
.card-title {
font-size: 18px;
font-weight: bold;
margin-bottom: 10px;
}
.card-content {
font-size: 14px;
color: #666;
}
</style>
社区与学习资源
16.1 官方文档
16.2 学习平台
- 慕课网:提供 Uni-App 和微信小程序相关课程。
- 掘金:开发者社区,分享技术文章和实战经验。
16.3 开源项目
- Uni-App 示例项目:GitHub 上搜索 Uni-App 相关项目。
- Vant Weapp:微信小程序 UI 组件库。
附录
17.1 CSS 属性速查表
属性 | 描述 |
---|---|
display |
定义元素的显示类型 |
flex-direction |
定义 Flexbox 主轴方向 |
justify-content |
定义主轴对齐方式 |
align-items |
定义交叉轴对齐方式 |
grid-template |
定义 Grid 布局的行和列 |
transition |
定义样式过渡效果 |
animation |
定义动画效果 |
17.2 常见单位速查表
单位 | 描述 |
---|---|
px |
像素单位 |
rpx |
微信小程序响应式单位 |
em |
相对于父元素字体大小 |
rem |
相对于根元素字体大小 |
% |
百分比单位 |
本指南到此结束,希望这些内容能帮助您更好地掌握 Uni-App 中的 CSS 样式开发。如果有任何问题或需要进一步探讨,请随时联系!