当前位置: 首页 > news >正文

从前端切图仔到鸿蒙开发02-布局样式

从前端切图仔到鸿蒙开发02-布局样式

本系列教程适合鸿蒙 HarmonyOS 初学者,为那些熟悉用 HTML 与 CSS 语法的 Web 前端开发者准备的。

本系列教程会将 HTML/CSS 代码片段替换为等价的 HarmonyOS/ArkUI 代码。

请添加图片描述

布局基础对比

在Web开发中,我们使用CSS来控制元素的布局和样式。而在HarmonyOS的ArkUI中,我们使用声明式UI和链式API来实现相同的效果。本文将对比两种框架在布局方面的异同。

盒子模型

在Web开发中,CSS盒子模型包含内容(content)、内边距(padding)、边框(border)和外边距(margin)。
在ArkUI中,这些概念依然存在,只是写法有所不同,容易上手。

HTML/CSS代码:

<div class="box">
  盒子模型
</div>

<style>
  .box {
    box-sizing: border-box;
    /* 内容 */
    width: 150px;
    height: 100px;
    /* 内边距 */
    padding: 10px;
    /* 边框 */
    border: 10px solid pink;
    /* 底部外边距 */
    margin-bottom: 10px;
  }
</style>

ArkUI代码:

Text('盒子模型')
  .width(150)
  .height(100)
  .padding(10)
  .border({ width: 10, style: BorderStyle.Solid, color: Color.Pink })
  .margin({ bottom: 10 })

背景色和文字颜色

在Web开发中,我们使用 background-colorcolor 属性来设置背景色和文字颜色。
在ArkUI中,我们使用 backgroundColorfontColor 方法。

HTML/CSS代码:

<div class="box">
  背景色、文字色
</div>

<style>
  .box {
    /* 背景色 */
    background-color: #36d;
    /* 文字色 */
    color: #fff;
  }
</style>

ArkUI代码:

Text('背景色、文字色')
  .backgroundColor('#36d')
  .fontColor('#fff')

内容居中

在Web开发中,我们使用 display: flex 配合 justify-contentalign-items 实现内容居中。
在ArkUI中,我们可以使用 ColumnRow 组件配合 justifyContentalignItems 属性。

HTML/CSS代码:

<div class="box">
  内容居中
</div>

<style>
  .box {
    display: flex;
    justify-content: center;
    align-items: center;
  }
</style>

ArkUI代码:

Column() {
  Text('内容居中')
}
.backgroundColor('#36D')
.justifyContent(FlexAlign.Center)
.alignItems(HorizontalAlign.Center)
.width(150)
.height(100)
.padding(10)

圆角

在Web开发中,我们使用border-radius属性来设置圆角。
在ArkUI中,我们使用borderRadius方法。

HTML/CSS代码:

<div class="box">
  圆角
</div>

<style>
  .box {
    border-radius: 10px;
  }
</style>

ArkUI代码:

Text('圆角')
  .width(150)
  .height(100)
  .backgroundColor('#36D')
  .borderRadius(10)

阴影效果

在Web开发中,我们使用box-shadow属性来设置阴影效果。
在ArkUI中,我们使用shadow方法。

HTML/CSS代码:

<div class="box">
  阴影
</div>

<style>
  .box {
    box-shadow: 0 6px 50px rgba(0, 0, 0, 0.5);
  }
</style>

ArkUI代码:

Text('阴影')
  .width(150)
  .height(100)
  .backgroundColor('#F5F5F5')
  .shadow({
    offsetX: 0,
    offsetY: 6,
    radius: 50,
    color: 'rgba(0, 0, 0, 0.5)',
  })

布局容器和轴向

基本容器

在Web开发中,我们使用<div>作为通用容器。
在ArkUI中,我们主要使用ColumnRow组件,注意 alignItems 需区分轴向。

HTML/CSS代码:

<div class="column">
  <!-- 垂直方向布局 -->
</div>

<div class="row">
  <!-- 水平方向布局 -->
</div>


<style>
  .column {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  
  .row {
    display: flex;
    flex-direction: row;
    align-items: center;
  }
</style>

ArkUI代码:

Column() {
  // 垂直方向布局,交叉轴水平居中
}
.alignItems(HorizontalAlign.Center)

Row() {
  // 水平方向布局,交叉轴垂直居中
}
.alignItems(VerticalAlign.Center)

关键区别总结

  1. 样式应用方式

    • HTML/CSS:使用选择器和属性声明样式
    • ArkUI:使用链式API直接在组件上设置样式
  2. 布局容器

    • HTML:使用 <div> 等标签,配合CSS实现布局
    • ArkUI:使用专门的布局组件如 ColumnRow 等组件,配合样式属性布局
  3. 单位使用

    • HTML/CSS:使用 px、em、rem、百分比等单位
    • ArkUI:使用 px、vp、lpx 、百分比等单位,使用数字单位 vp 可省略
  4. 样式继承

    • HTML/CSS:通过CSS选择器实现样式继承
    • ArkUI:没有样式继承

学习建议

  1. 理解链式API

    • 熟悉ArkUI的链式API调用方式
    • 掌握常用样式方法的命名规则
  2. 布局思维转变

    • 从CSS盒模型思维转向组件化思维
    • 理解ArkUI的布局容器特性
  3. 样式设置习惯

    • 养成使用链式API设置样式的习惯
    • 注意样式方法的参数格式
  4. 组件嵌套

    • 合理使用组件嵌套实现复杂布局
    • 注意组件的父子关系

总结

作为Web开发者,迁移到 HarmonyOS 开发需要适应新的布局和样式设置方式。概念其实非常相似,通过理解这些差异,并掌握ArkUI的组件化开发方式,Web开发者可以快速上手HarmonyOS开发。

希望这篇 HarmonyOS 教程对你有所帮助,期待您的 👍点赞、💬评论、🌟收藏 支持。

相关文章:

  • 基于javaweb的SpringBoot雪具商城系统设计与实现系统(源码+文档+部署讲解)
  • 数据结构之排序
  • 结合DrRacket学习《如何设计程序,第二版》
  • 数据库原理及应用mysql版陈业斌实验二
  • 小迪安全-php模型,mvc架构,动态调试未授权,脆弱及安全,为引用。逻辑错误
  • Qt中QApplication::processEvents()详细讲解
  • 定长内存池设计核心:如何用固定块内存实现零碎片管理
  • Python备赛笔记2
  • 5分钟学会interface(纯标题党)
  • 在GitHub中上传第一个文件
  • 如何优化SQL查询以提高数据库性能?
  • 科技快讯 | 谷歌正在推出Gemini实时人工智能视频功能;意大利出版全球首份“AI报纸”
  • 【C++】 —— 笔试刷题day_8
  • (十八)面向对象的三大特性:封装 、继承、多态
  • 速卖通API数据清洗实战:从原始JSON到结构化商品数据库
  • 收货地址区域
  • 基于python+django的商城网站-电子商城管理系统源码+运行
  • 详解vector容器
  • AI Agent开发与应用
  • MTK Android12-Android13 设置系统默认语言
  • 上海网站设计团队/产品推广软文200字
  • 卖网店哪个平台可靠/网站优化外包费用
  • 电影视频网站怎么做/网页推广怎么做
  • 做网站需要备案吗/汕头网站制作设计
  • 帮别人做设计图的网站/2021年新闻摘抄
  • 做网站有个名字叫小廖/我想学做互联网怎么入手