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

SwiftUI的 特性 - ViewModify

SwiftUI的 特性 - ViewModify

记录一下SwiftUI的 特性 - ViewModify的使用方式
可以通过viewModify来管理视图的样式,结合extension来完成封装达到解偶效果


import SwiftUI///  我们可以通过viewModify来管理视图的样式,来达到解偶效果
struct DefaultButtonViewModifier: ViewModifier {@State var font: Font@State var bgColor: Colorfunc body(content: Content) -> some View {content.font(font).foregroundColor(.white).frame(height: 55).frame(maxWidth: .infinity).background(bgColor).cornerRadius(10.0, antialiased: /*@START_MENU_TOKEN@*/true/*@END_MENU_TOKEN@*/).shadow(radius: 10)}}extension View {/// MARK - 通过拓展来简化调用过程从而完成封装func withDefaultButtonFormatting(bgColor: Color = .blue, font: Font = .title) -> some View {modifier(DefaultButtonViewModifier(font: font, bgColor: bgColor))}
}struct ViewModifierBootCamp: View {var body: some View {VStack(spacing: 20, content: {Text("Hello, World!").withDefaultButtonFormatting(bgColor: .yellow)Text("Hello, everyOne!").withDefaultButtonFormatting(font: .title3)Text("Hello !!").withDefaultButtonFormatting(bgColor: .green, font: .headline)}).padding()}
}#Preview {ViewModifierBootCamp()
}

效果:
在这里插入图片描述

http://www.lryc.cn/news/319132.html

相关文章:

  • 中间件 | RPC - [Dubbo]
  • 【中等】保研/考研408机试-二叉树相关
  • 自动驾驶---Motion Planning之构建SLT Driving Corridor
  • 本地文件包含漏洞利用
  • 【docker】docker的常用命令
  • jmeter实战
  • 面试官常问问题
  • 外包就干了2个月,技术退步明显....
  • 面向对象 汇总(详细内容见Day12—16)
  • 结构体联合体枚举和位段
  • 人类程序员真要失业?首位“AI软件工程师”亮相引爆科技圈
  • redis的过期策略以及内存淘汰机制
  • 华为数通方向HCIP-DataCom H12-821题库(多选题:161-180)
  • 网络通信与网络协议
  • 【矩阵】240. 搜索二维矩阵 II【中等】
  • 详解uniapp的生命周期
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(基础手势:PluginComponent)
  • mysql笔记:15. 事务和锁
  • Learn OpenGL 15 面剔除
  • EndeavourOs(arch系)安装sunpinyin输入法(ibus) + 迅雷(xunlei-bin)
  • Spring Cache框架的介绍和使用
  • perl 用 XML::Parser 解析 XML文件,访问哈希
  • MATLAB中的矩阵和数组,它们之间有什么区别?
  • python爬虫实战——抖音
  • Day1-力扣刷题学习打卡
  • C语言的位操作与位字段
  • 应用实战|从头开始开发记账本1:如何获取BaaS服务
  • el-form v-for循环列表的表单如何校验
  • 笔记:《NCT全国青少年编程能力等级测试教程Python语言编程三级》
  • 地平线旭日x3派部署yolov5--全流程