質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.40%
iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

解決済

1回答

8810閲覧

エラー:which is already presenting (null)の対処法

Larry

総合スコア28

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

0クリップ

投稿2019/11/02 09:27

編集2019/11/02 09:36

発生している問題・エラーメッセージ

tableViewにsearchBarを設定してnavigationbarにaddボタンを設置しています。

検索状態でaddボタンを押して(このタイミングでエラー1)、その後キャンセルボタンを押すと(このタイミングでエラー2)クラッシュしてしまいます。

以下のようなエラー内容が出ました。

  1. which is already presenting (null)

  2. unrecognized selector sent to instance

  3. unrecognized selector sent to instanceは

addボタンの
let addButton = UIBarButtonItem(barButtonSystemItem: .add, target: self, action:#selector(onAddTapped(_:)))において、

ここを参考にすると、問題ないはずなのですが、
(https://teratail.com/questions/192136)

  1. which is already presenting (null)が分かりません。

alertがすでに表示されているという意味だと思うのですが、、、、

試しに
self.present(alert, animated: true, completion: nil)
の部分をコメントアウトすると上記二つのエラーは消えたので、ここが原因だと思うのですが、この先どうすれば良いのか分かりません。。。

対処法知っておられる方いましたら、教えてください。
よろしくお願いします。

swift

1import UIKit 2class ViewController: UIViewController { 3 4 @IBOutlet weak var tableView: UITableView! 5 var searchController: UISearchController! 6 var words = [String]() 7 var searchResults:[String] = [] 8 9 override func viewDidLoad() { 10 super.viewDidLoad() 11 //高さ自動調整 12 tableView.rowHeight = UITableView.automaticDimension 13 //余分なセルを非表示 14 self.tableView.tableFooterView = UIView() 15 navigationItem.leftBarButtonItem = editButtonItem 16 let addButton = UIBarButtonItem(barButtonSystemItem: .add, target: self, action:#selector(onAddTapped(_:))) 17 navigationItem.rightBarButtonItem = addButton 18 19 setupSearchBar() 20 } 21 22 func setupSearchBar() { 23 searchController = UISearchController(searchResultsController: nil) 24 searchController.searchResultsUpdater = self 25 searchController.searchBar.delegate = self 26 27 searchController.searchBar.frame = CGRect(x: 0, y: 0, width: 0, height: 60) 28 //searchController.searchBar.sizeToFit() 29 searchController.searchBar.placeholder = "WAROTA" 30 searchController.searchBar.tintColor = UIColor.red 31 searchController.searchBar.keyboardType = UIKeyboardType.default 32 33 searchController.dimsBackgroundDuringPresentation = false 34 searchController.hidesNavigationBarDuringPresentation = false 35 36 tableView.tableHeaderView = searchController.searchBar 37 } 38 39 @objc func onAddTapped(_ sender: Any) { 40 let alert = UIAlertController(title: "単語を登録", message: "Enter Chinese",preferredStyle: .alert) 41 alert.addTextField {(ChineseTH) in ChineseTH.placeholder = "words" } 42 let cancelAction = UIAlertAction(title: "Cancel", style: .cancel, handler: nil) 43 let okAction = UIAlertAction(title: "Add", style: .default) { (_) in 44 45 guard let word = alert.textFields?.first?.text, word.count > 0 else { return } 46 self.insertCellRow(word) 47 48 } 49 50 alert.addAction(cancelAction) 51 alert.addAction(okAction) 52 53 self.present(alert, animated: true, completion: nil) 54 55 } 56 57 func insertCellRow(_ word: String){ 58 words.insert(word, at: 0) 59 let indexPath = IndexPath(row: 0, section: 0)//初期化 60 tableView.insertRows(at: [indexPath], with: .automatic)//新しいセルを挿入しているだけ 61 62 } 63 64} 65 66// MARK: - tabeleView 67extension ViewController: UITableViewDelegate, UITableViewDataSource { 68 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 69 return words.count 70 } 71 72 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 73 let cell = tableView.dequeueReusableCell(withIdentifier: "Cell") 74 let word = words[indexPath.row] 75 cell?.textLabel?.text = word 76 return cell! 77 } 78} 79 80// MARK: - searchBar 81extension ViewController: UISearchResultsUpdating { 82 func updateSearchResults(for searchController: UISearchController) { 83 self.searchResults = words.filter{ 84 $0.lowercased().contains(searchController.searchBar.text!.lowercased()) 85 } 86 } 87} 88 89// MARK: - searchBar 90extension ViewController: UISearchBarDelegate { 91 92 func searchBar(_ searchBar: UISearchBar, textDidChange searchText: String) { 93 } 94 95 func searchBarCancelButtonClicked(_ searchBar: UISearchBar) { 96 searchBar.text = "" 97 tableView.reloadData() 98 } 99 100 func searchBarTextDidBeginEditing(_ searchBar: UISearchBar) { 101 } 102} 103

補足情報(FW/ツールのバージョンなど)

xcode11.1

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

self の上にすでに UISearchControllerpresent されているので、その状態でさらに別のViewControllerを selfpresent することはできません。

searchController.isActivefalse にして、 self が最上位レイヤーの状態にしてから AlertController を present するか、次のコードで最上位レイヤーのViewControllerを取得して、その上に AlertController を present するようにしてください

swift

1var frontViewController = self; 2while(frontViewController.presentedViewController) { 3 frontViewController = frontViewController.presentedViewController 4} 5frontViewController.present(alert, animated: true, completion: nil)

投稿2019/11/03 13:58

編集2019/11/04 23:44
thyda.eiqau

総合スコア2982

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.40%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問