我有在Objective-C中创建和NSAlert的代码,但我现在想在Swift中创建它。
警告是确认用户想要删除文档。
我希望“删除”按钮然后运行删除功能,“取消”按钮只是为了解除警报。
我怎样才能在Swift中写这个?
NSAlert *alert = [[[NSAlert alloc] init] autorelease];
[alert addButtonWithTitle:@"Delete"];
[alert addButtonWithTitle:@"Cancel"];
[alert setMessageText:@"Delete the document?"];
[alert setInformativeText:@"Are you sure you would like to delete the document?"];
[alert setAlertStyle:NSWarningAlertStyle];
[alert beginSheetModalForWindow:[self window] modalDelegate:self didEndSelector:@selector(alertDidEnd:returnCode:contextInfo:) contextInfo:nil];
答案 0 :(得分:118)
beginSheetModalForWindow:modalDelegate
。
Swift 2
func dialogOKCancel(question: String, text: String) -> Bool {
let alert: NSAlert = NSAlert()
alert.messageText = question
alert.informativeText = text
alert.alertStyle = NSAlertStyle.WarningAlertStyle
alert.addButtonWithTitle("OK")
alert.addButtonWithTitle("Cancel")
let res = alert.runModal()
if res == NSAlertFirstButtonReturn {
return true
}
return false
}
let answer = dialogOKCancel("Ok?", text: "Choose your answer.")
根据用户的选择返回true
或false
。
NSAlertFirstButtonReturn
表示添加到对话框的第一个按钮,此处为" OK"之一。
Swift 3
func dialogOKCancel(question: String, text: String) -> Bool {
let alert = NSAlert()
alert.messageText = question
alert.informativeText = text
alert.alertStyle = NSAlertStyle.warning
alert.addButton(withTitle: "OK")
alert.addButton(withTitle: "Cancel")
return alert.runModal() == NSAlertFirstButtonReturn
}
let answer = dialogOKCancel(question: "Ok?", text: "Choose your answer.")
Swift 4
我们现在使用枚举作为警报的样式和按钮选择。
func dialogOKCancel(question: String, text: String) -> Bool {
let alert = NSAlert()
alert.messageText = question
alert.informativeText = text
alert.alertStyle = .warning
alert.addButton(withTitle: "OK")
alert.addButton(withTitle: "Cancel")
return alert.runModal() == .alertFirstButtonReturn
}
let answer = dialogOKCancel(question: "Ok?", text: "Choose your answer.")
答案 1 :(得分:20)
我认为这对你有用......
let a = NSAlert()
a.messageText = "Delete the document?"
a.informativeText = "Are you sure you would like to delete the document?"
a.addButtonWithTitle("Delete")
a.addButtonWithTitle("Cancel")
a.alertStyle = NSAlertStyle.WarningAlertStyle
a.beginSheetModalForWindow(self.view.window!, completionHandler: { (modalResponse) -> Void in
if modalResponse == NSAlertFirstButtonReturn {
print("Document deleted")
}
})
答案 2 :(得分:4)
更新了Jose Hidalgo对Swift 4的回答:
let a: NSAlert = NSAlert()
a.messageText = "Delete the document?"
a.informativeText = "Are you sure you would like to delete the document?"
a.addButton(withTitle: "Delete")
a.addButton(withTitle: "Cancel")
a.alertStyle = NSAlert.Style.warning
a.beginSheetModal(for: self.window!, completionHandler: { (modalResponse: NSApplication.ModalResponse) -> Void in
if(modalResponse == NSApplication.ModalResponse.alertFirstButtonReturn){
print("Document deleted")
}
})
答案 3 :(得分:3)
选择@Jose Hidalgo对 Swift 5
的回答 let a = NSAlert()
a.messageText = "Delete the document?"
a.informativeText = "Are you sure you would like to delete the document?"
// .alertFirstButtonReturn
a.addButton(withTitle: "Delete")
// .alertSecondButtonReturn
a.addButton(withTitle: "Cancel")
a.alertStyle = .warning
var w: NSWindow?
if let window = view.window{
w = window
}
else if let window = NSApplication.shared.windows.first{
w = window
}
if let window = w{
a.beginSheetModal(for: window){ (modalResponse) in
if modalResponse == .alertFirstButtonReturn {
print("Document deleted")
}
}
}
答案 4 :(得分:0)
我尝试了上述解决方案,但无法获得适当大小的警报。我也定义了警报的大小。
let alert = NSAlert()
alert.messageText = "YOUR MESSAGE"
alert.addButton(withTitle: "BUTTON1")
alert.addButton(withTitle: "BUTTON2")
var frame = alert.window.frame
frame.size.height = 300
frame.size.width = 200
alert.window.setFrame(frame, display: true)
let stackViewer = NSStackView(frame: NSRect(x: 0, y: 0, width: 200, height: 00))
alert.accessoryView = stackViewer
alert.beginSheetModal(for: self.view.window!, completionHandler: { (modalResponse) -> Void in
if modalResponse == NSApplication.ModalResponse.alertFirstButtonReturn {
print("first btn")
}else{
print("second btn")
}
})