《微信小程序开发入门精要》——第2章,第2.1节水平排列

简介:

本节书摘来自异步社区《微信小程序开发入门精要》一书中的第2章,第2.1节水平排列,作者 李宁,更多章节内容可以访问云栖社区“异步社区”公众号查看

第2章 布局
微信小程序开发入门精要
布局是任何支持UI的技术都会涉及到的。小程序的布局采用了和React Native相同的flex(弹性布局)方式,使用方法也类似(只是属性名不同而已)。因此,如果读者已经对React Native的布局比较了解,那么将非常容易掌握小程序布局。即使对React Native的布局不了解,通过对本章的学习,也可以掌握小程序布局的核心技术。

本章要点
水平排列布局
水平折行排列布局
垂直排列布局
垂直折列排列布局
水平排列对齐布局
垂直排列对齐布局
水平等间隔排列布局
带边距的水平等间隔排列布局

2.1 水平排列
小程序的布局和React Native的布局类似,采用了弹性布局的方法,即分为水平和垂直布局。默认是从左向右水平依次放置组件,或从上到下依次放置组件。

wxml文件用于放置参与布局的组件,为了更好地描述小程序是如何布局的,本章使用了带背景色的view组件来演示。view是小程序中所有可视组件的根。

任何可视组件都需要使用样式来设置自身的属性,并完成相应的布局。在小程序中,可以使用两种方式设置样式,一种是class属性,另一种是style属性。前者需要指定在wxss文件中定义的样式,后者允许直接在组件中定义样式属性。例如,如果要水平放置3个view组件,可以在wxml文件中使用下面的代码。

<view class="flex-wrp" style="flex-direction:row">
    <view class="flex-item bc_green"></view>
    <view class="flex-item bc_red"></view>
    <view class="flex-item bc_blue"></view>
 </view>

显示的效果如图2-1所示。


7fc4fe44a0efe584b038061112d04b80e2ca6c2c

▲图2-1 水平布局

在上面的代码中,同时使用了class和style属性。分别指定了样式flex-wrp和样式属性flex-direction:row,其中,后者表示view中的子组件要按水平排列。flex-wrp的定义如下:

.flex-wrp{
    height: 100px;
    display:flex;
    background-color: #FFFFFF;
 }

其中,display:flex表示弹性布局,flex是Flexible的缩写。

如果class属性需要指定多个样式,样式直接用空格分隔,代码如下:

<view class="flex-item bc_green"></view>
其中flex-item的代码如下:

.flex-item{
   width: 100px;
   height: 100px;
}

前面所有的样式都是在当前页面的index.wxss文件中定义的,而bc_green以及其他几个设置颜色的样式是在app.wxss文件中定义的,所有的页面都可以使用。

.bc_green{
    background-color: #09BB07;
 }
 .bc_red{
    background-color: #F76260;
 }
 .bc_blue{
    background-color: #10AEFF;
 }
 .bc_yellow{
    background-color: #FFBE00;
 }
 .bc_gray{
    background-color: #C9C9C9;
 }

如果不想使用style属性,可以将flex-direction:row放在样式中。例如,可以在index.wxss文件中添加如下的样式。

  .flex-row{
     flex-direction:row;
 }
然后修改index.wxml文件中的代码如下:

<view class="flex-wrp flex-row" >
    <view class="flex-item bc_green"></view>
    <view class="flex-item bc_red"></view>
    <view class="flex-item bc_blue"></view>
 </view>

可能很多读者会发现一个问题,本节的例子中只有3个view,如果放置了多个view会怎么样呢?从flex-item样式可知,每个view的尺寸是100*100,单位是像素(px),如果放置过多,可能会发生如下两种情况:

折行。
压缩每一个view的宽度。
那么到底会发生哪种情况呢?我们不妨做一个实验,代码如下:

<view class="flex-wrp flex-row" >
    <view class="flex-item bc_green"></view>
    <view class="flex-item bc_red"></view>
    <view class="flex-item bc_blue"></view>
    <view class="flex-item bc_green"></view>
    <view class="flex-item bc_red"></view>
    <view class="flex-item bc_blue"></view>
    <view class="flex-item bc_green"></view>
    <view class="flex-item bc_red"></view>
    <view class="flex-item bc_blue"></view>
  </view>

在上述代码中,view中包含了9个子view,保存index.wxml文件后,会显示如图2-2所示的效果。


c4036ec6902352445488171768d291877c7a9589

▲图2-2 压缩了每一个view的宽度

很明显,每一个view的宽度都被压缩了(因为每一个view的默认尺寸是一个正方形),以适应设备的宽度。不过这种处理方式可能并不符合我们的要求,如果我们的要求是让每一个view的尺寸保持不变,但是一行放不下,怎么能够折到下一行呢?答案就在下一节!

相关文章
|
11月前
|
人工智能 自然语言处理 小程序
技术小白如何利用DeepSeek半小时开发微信小程序?
通过通义灵码的“AI程序员”功能,即使没有编程基础也能轻松创建小程序或网页。借助DeepSeek V3和R1满血版模型,用户只需用自然语言描述需求,就能自动生成代码并优化程序。例如,一个文科生仅通过描述需求就成功开发了一款记录日常活动的微信小程序。此外,通义灵码还提供智能问答模式,帮助用户解决开发中的各种问题,极大简化了开发流程,让普通人的开发体验更加顺畅。
3303 11
技术小白如何利用DeepSeek半小时开发微信小程序?
|
10月前
|
小程序 Java 关系型数据库
weixin163基于微信小程序的校园二手交易平台系统设计与开发ssm(文档+源码)_kaic
本文介绍了一款基于微信小程序的校园二手物品交易平台的开发与实现。该平台采用Java语言开发服务端,使用MySQL数据库进行数据存储,前端以微信小程序为载体,支持管理员和学生两种角色操作。管理员可管理用户、商品分类及信息、交易记录等,而学生则能注册登录、发布购买商品、参与交流论坛等。系统设计注重交互性和安全性,通过SSM框架优化开发流程,确保高效稳定运行,满足用户便捷交易的需求,推动校园资源共享与循环利用。
|
10月前
|
小程序 关系型数据库 Java
weixin168“返家乡”高校暑期社会实践微信小程序设计与开发ssm(文档+源码)_kaic
本文探讨高校暑期社会实践微信小程序的开发与应用,旨在通过信息化手段提升活动管理效率。借助微信小程序技术、SSM框架及MySQL数据库,实现信息共享、流程规范和操作便捷。系统涵盖需求分析、可行性研究、设计实现等环节,确保技术可行、操作简便且经济合理。最终,该小程序可优化活动发布、学生信息管理和心得交流等功能,降低管理成本并提高工作效率。
|
11月前
|
小程序 JavaScript 前端开发
微信小程序开发全流程:从注册到上线的完整指南
这篇文章详细记录了微信小程序的完整开发到最终上线的每一个步骤。适合对小程序开发感兴趣的个人开发者或希望了解完整流程的学习者,涵盖了云开发、事件绑定、生命周期管理、组件使用等关键内容。
10695 12
|
12月前
|
JSON 缓存 小程序
微信小程序组件封装与复用:提升开发效率
本文深入探讨了微信小程序的组件封装与复用,涵盖组件的意义、创建步骤、属性与事件处理,并通过自定义弹窗组件的案例详细说明。组件封装能提高代码复用性、开发效率和可维护性,确保UI一致性。掌握这些技能有助于构建更高质量的小程序。
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
3606 7
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
3734 1
|
小程序 前端开发 测试技术
微信小程序的开发完整流程是什么?
微信小程序的开发完整流程是什么?
2367 7
ly~
|
存储 供应链 小程序
除了微信小程序,PHP 还可以用于开发哪些类型的小程序?
除了微信小程序,PHP 还可用于开发多种类型的小程序,包括支付宝小程序、百度智能小程序、抖音小程序、企业内部小程序及行业特定小程序。在电商、生活服务、资讯、工具、娱乐、营销等领域,PHP 能有效管理商品信息、订单处理、支付接口、内容抓取、复杂计算、游戏数据、活动规则等多种业务。同时,在企业内部,PHP 可提升工作效率,实现审批流程、文件共享、生产计划等功能;在医疗和教育等行业,PHP 能管理患者信息、在线问诊、课程资源、成绩查询等重要数据。
ly~
397 6
|
小程序 前端开发 数据安全/隐私保护
微信小程序全栈开发中的身份认证与授权机制
【10月更文挑战第3天】随着移动互联网的发展,微信小程序凭借便捷的用户体验和强大的社交传播能力,成为企业拓展业务的新渠道。本文探讨了小程序全栈开发中的身份认证与授权机制,包括手机号码验证、微信登录、第三方登录及角色权限控制等方法,并强调了安全性、用户体验和合规性的重要性,帮助开发者更好地理解和应用这一关键技术。
470 5