在每次调用UIImagePickerController()的dismiss()之后调用viewDidLoad()是不合适的做法。viewDidLoad()是UIViewController生命周期中的一个方法,它在视图控制器的视图加载完成后调用,通常只会在视图控制器初始化时调用一次。而dismiss()是用于关闭模态视图控制器的方法,当调用dismiss()后,模态视图控制器会被移除,返回到上一个视图控制器。
如果需要在dismiss()之后执行一些操作,可以考虑使用代理模式或闭包回调来实现。具体的实现方式如下:
// 在模态视图控制器中定义代理协议
protocol ImagePickerDelegate: class {
func imagePickerDidDismiss()
}
class ImagePickerViewController: UIViewController {
weak var delegate: ImagePickerDelegate?
// 在dismiss()之后调用代理方法
func dismissImagePicker() {
dismiss(animated: true) {
self.delegate?.imagePickerDidDismiss()
}
}
}
class MainViewController: UIViewController, ImagePickerDelegate {
// 在MainViewController中实现代理方法
func imagePickerDidDismiss() {
// 在dismiss()之后执行相应操作
viewDidLoad()
}
// 弹出模态视图控制器
func presentImagePicker() {
let imagePicker = ImagePickerViewController()
imagePicker.delegate = self
present(imagePicker, animated: true, completion: nil)
}
}
class ImagePickerViewController: UIViewController {
var dismissCompletion: (() -> Void)?
// 在dismiss()之后调用闭包回调
func dismissImagePicker() {
dismiss(animated: true) {
self.dismissCompletion?()
}
}
}
class MainViewController: UIViewController {
// 弹出模态视图控制器
func presentImagePicker() {
let imagePicker = ImagePickerViewController()
imagePicker.dismissCompletion = {
// 在dismiss()之后执行相应操作
self.viewDidLoad()
}
present(imagePicker, animated: true, completion: nil)
}
}
以上是两种常见的实现方式,根据具体情况选择适合的方式来处理dismiss()之后的操作。
领取专属 10元无门槛券
手把手带您无忧上云