作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在 Xcode 11.6 的 iOS 13 上的 SwiftUI 中创建一个应用程序
我想在 SwiftUI 的 View 上创建一个扩展,当用户长按 View 时显示一条警报消息。
例如,假设我有这样的观点:
import SwiftUI
struct TestView: View {
var body: some View {
TabView {
Text("1").addLongPressAlert("Test 1")
Text("2").addLongPressAlert("Test 2")
Text("3").addLongPressAlert("Test 3")
}
}
}
View 上的扩展看起来像这样:
extension View {
public func addLongPressAlert(message _ : String) -> some View {
return self.onLongPressGesture {
// I know this is not how you show an alert, but im unsure how to display it
Alert(title: Text("Alert"), message: Text(m), dismissButton: .default(Text("OK!")))
}
}
}
我正在努力弄清楚如何正确设置它。
最佳答案
您可以创建自定义 ViewModifier
:
struct LongPressAlertModifier: ViewModifier {
@State var showAlert = false
let message: String
func body(content: Content) -> some View {
content
.onLongPressGesture {
self.showAlert = true
}
.alert(isPresented: $showAlert) {
Alert(title: Text("Alert"), message: Text(message), dismissButton: .default(Text("OK!")))
}
}
}
并像这样使用它:
Text("1").modifier(LongPressAlertModifier(message: "Test1"))
View
延期:
extension View {
func addLongPressAlert(_ message: String) -> some View {
self.modifier(LongPressAlertModifier(message: message))
}
}
并以更方便的方式使用您的修饰符:
Text("1").addLongPressAlert("Test 1")
关于ios - 如何在 View 上创建扩展以在长按手势上显示警报 - SwiftUI,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63181915/
我是一名优秀的程序员,十分优秀!