網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
正文
swiftui 中的 padding 用于設(shè)置視圖的填充。
使用 padding() 可以指定 Text、Button 等視圖填充的數(shù)值,或者是對(duì)一個(gè)或多個(gè)邊設(shè)置填充。
下面讓我們來(lái)看看 padding 有哪些使用方式。
padding 的默認(rèn)值
使用 padding() 設(shè)置填充時(shí),沒(méi)有設(shè)置具體數(shù)值將會(huì)使用特定平臺(tái)給定的默認(rèn)值。而這個(gè)默認(rèn)值并沒(méi)有標(biāo)準(zhǔn)值,對(duì)于不同的設(shè)備,用戶(hù)的設(shè)置等情況,padding 的默認(rèn)值都會(huì)有所不同:
如果值為 nil,則將應(yīng)用特定平臺(tái)指定的或者由系統(tǒng)計(jì)算的值用于填充。
來(lái)看看具體示例:
import SwiftUI
struct Test: View {
var body: some View {
VStack{
Text("沒(méi)有默認(rèn)值的padding")
.padding()
.background(Color.red)
Text("填充值為16的padding")
.padding(16)
.background(Color.blue)
}
}
}
struct Test_Previews: PreviewProvider {
static var previews: some View {
Test()
}
}
iphone14 pro 顯示效果(下面示例默認(rèn)使用 iphone14 pro 顯示):
上圖的顯示效果中,默認(rèn)值和 16 的效果近似,但不代表默認(rèn)值就是 16。
對(duì)某個(gè)方向設(shè)置 padding
padding 可以對(duì)上下左右 4 個(gè)方向單獨(dú)設(shè)置填充。
- top:上
- bottom:下
- leading:左
- trailing:右
import SwiftUI
struct Test: View {
var body: some View {
VStack{
Text("上padding")
.padding(.top, 20) // 文字頂部設(shè)置 20 像素的填充
.border(Color.gray)
Text("下padding")
.padding(.bottom, 20)
.border(Color.gray)
Text("左padding")
.padding(.leading, 20)
.border(Color.gray)
Text("右padding")
.padding(.trailing, 20)
.border(Color.gray)
// 統(tǒng)一設(shè)置 16 像素的填充
Text("填充值為16的padding")
.padding(16)
.border(Color.gray)
}
}
}
struct Test_Previews: PreviewProvider {
static var previews: some View {
Test()
}
}
注意:如果在設(shè)置某個(gè)方向的 padding 時(shí)沒(méi)有給定具體數(shù)值,將會(huì)使用系統(tǒng)默認(rèn)值:padding(.top)。
同時(shí)對(duì)多個(gè)方向設(shè)置 padding
我們還可以同時(shí)對(duì)多個(gè)方向設(shè)置 pdding。
import SwiftUI
struct Test: View {
var body: some View {
VStack{
Text("上下padding")
.padding([.top, .bottom], 20)
.border(Color.gray)
Text("上下左padding")
.padding([.top, .bottom, .leading], 20)
.border(Color.gray)
Text("左右padding")
.padding([.leading, .trailing], 20)
.border(Color.gray)
Text("左右下padding")
.padding([.bottom, .leading, .trailing], 20)
.border(Color.gray)
Text("水平padding")
.padding(.horizontal, 20)
.border(Color.gray)
Text("垂直padding")
.padding(.vertical, 20)
.border(Color.gray)
Text("填充值為16的padding")
.padding(16)
.border(Color.gray)
}
}
}
struct Test_Previews: PreviewProvider {
static var previews: some View {
Test()
}
}
對(duì)上下左右4個(gè)方向的 padding 進(jìn)行精確設(shè)置
import SwiftUI
struct Test: View {
var body: some View {
VStack{
Text("精確控制4個(gè)方向的padding")
.padding(EdgeInsets(top: 10, leading: 20, bottom: 30, trailing: 40))
.border(Color.gray)
Text("填充值為16的padding")
.padding(16)
.border(Color.gray)
}
}
}
struct Test_Previews: PreviewProvider {
static var previews: some View {
Test()
}
}
總結(jié)
我們學(xué)會(huì)了 padding 的各個(gè)方向的設(shè)置,給你的布局加點(diǎn) padding,對(duì)用戶(hù)體驗(yàn)會(huì)更加友好哦。
原文鏈接:https://juejin.cn/post/7146035670606151710
相關(guān)推薦
- 2022-04-25 .net5?使用Hangfire的過(guò)程記錄_實(shí)用技巧
- 2022-07-22 防火墻.iptables-tcp-flags防止nmap端口掃描
- 2022-08-04 Go語(yǔ)言func匿名函數(shù)閉包示例詳解_Golang
- 2023-01-31 golang定時(shí)任務(wù)cron項(xiàng)目實(shí)操指南_Golang
- 2021-12-10 Oracle數(shù)據(jù)庫(kù)備份還原詳解_oracle
- 2022-10-11 ABAP 云平臺(tái)向控制臺(tái)輸出消息
- 2022-04-11 Python如何在終端彩色打印輸出_python
- 2022-10-10 AOSP源碼下載示例代碼_Android
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門(mén)
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支