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

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

ただいまの
回答率

90.51%

  • Swift

    8726questions

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

【Swift 3.0】画面遷移はViewControllerからじゃないとできない?

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,546

user0024

score 6

前提・実現したいこと

Swift3.0でTableViewのセルをタップして別のStoryboardにあるViewControllerに画面遷移させたいのですが,
画面遷移させる以下のメソッド

present(viewController, animated: true, completion: nil)


がTableViewクラスで実装できません.
このような場合はTableViewControllerを使うしか方法はないのでしょうか?

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

Use of unresolved identifier 'present'

該当のソースコード

/*
 * FolderTableView.swift
 */
import UIKit

class FolderTableView: NSObject, UITableViewDelegate, UITableViewDataSource {

    // 途中省略

    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {

        let storyboard: UIStoryboard = UIStoryboard(name: "Task", bundle: nil)

        let taskListViewController = storyboard.instantiateViewController(withIdentifier: "Task")
        self.present(taskListViewController, animated: true, completion: nil)
     ↑このメソッドで画面遷移させたい
    }

}
/*
 * FolderListViewController.swift
 */
import UIKit
import RealmSwift

class FolderListViewController: UIViewController {

    @IBOutlet weak var folderTableView: UITableView!

    let folderTable = FolderTableView()

    override func viewDidLoad() {
        super.viewDidLoad()

        folderTableView.delegate = folderTable
        folderTableView.dataSource = folderTable

    }

    // 省略    

}

試したこと

・TableViewを呼び出しているFolderListViewController内でpresentメソッドを実装
→セルをタップした時にfolderTableView.delegate = folderTableの行で以下のエラーが発生

fatal error: unexpectedly found nil while unwrapping an Optional value

・presentメソッド用のViewControllerクラスを作成し,FolderTableViewでメソッドを呼び出す
→セルをタップした時に以下のエラーが発生

Warning: Attempt to present <skillup7.TaskListViewController: 0x7f98eb423650> on <skillup7.TestViewController: 0x7f98eb522230> whose view is not in the window hierarchy!


↓↓用意したViewControllerクラス↓↓

/*
 * TestViewController.swift
 */
import UIKit

class TestViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()

        // Do any additional setup after loading the view.
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    func send(viewController: UIViewController) {
        self.present(viewController, animated: true, completion: nil)
    }

}

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

言語:Swift 3.0

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

+1

Use of unresolved identifier 'present'

が出る原因は、FolderTableViewクラスにpresentメソッドが定義されていないためです。
presentメソッドはUIViewControllerで定義されているメソッドですから、
UIViewControllerを継承したクラスで実行する必要があります。

どうしてFolderTableViewクラスを作っているのかわかりませんが、
ここでtableViewのdelegateを処理するのではなく、
FolderListViewControllerで処理すれば呼び出せます。

(サンプル)

/*
 * FolderListViewController.swift
 */
import UIKit
import RealmSwift

class FolderListViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {

    @IBOutlet weak var folderTableView: UITableView!

    override func viewDidLoad() {
        super.viewDidLoad()

        folderTableView.delegate = self
        folderTableView.dataSource = self

    }

    // 途中省略

    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {

        let storyboard: UIStoryboard = UIStoryboard(name: "Task", bundle: nil)

        let taskListViewController = storyboard.instantiateViewController(withIdentifier: "Task")
        self.present(taskListViewController, animated: true, completion: nil)
    }
}


質問に書かれていることを実施するだけなら、FolderTableViewクラスもTestViewControllerも不要だと思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/07/10 12:07

    コメントありがとうございます。
    TakeOneさんのコメントからヒントを得ることができました。

    キャンセル

0

segueは簡単にオブジェクトから作れます。
メインストーリーボード画面を開いて、右下のツールボックス、◉マークをクリック、ViewController、Viewを追加します。ドラッグ&ドロップで、画面の余白に自由に配置できます。そして、最初のViewController画面の■マークを右クリックして、次のViewの画面上にドラッグアンドドロップして、開くポップアップ画面から、present modallyを選んでコンパイル、もしくはビルドするだけです。トプ画面のメニューボックス(右横)の Is Initial pageにチェックを入れることも重要です。トップ画面にどれでもなれます。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/07/07 01:37

    ご回答ありがとうございます.

    大変申し訳ございません.情報不足でした.
    遷移したい先が別のStoryboardにあるViewControllerなのでSegueを利用することができないと思われます.
    質問内容の方を更新させていただきました.
    もしよろしければ,上記の条件のもとでの解決策・アドバイスをいただけないでしょうか?

    キャンセル

  • 2017/07/07 01:44 編集

    TableViewであれば、やはり、◉マークから、テキストボックスや、ボタン、ナビゲーションツールなどを、ドラッグ&ドロップし、そのツールの上で、右クリックして、あとは、そのボタンなり、テキストビューなり、を右クリックして、ViewControllerの上にドラッグします。すると、ポップアップ(動作設定ウィンドウが開くので)、Present modallyを選んでください。それだけで、リンク(セグエ)完了です。また、TableViewController.m(objective-c)(swift?)での実装は、デリゲートが必要な場合があり、TableViewController.m へのViewControllerの接続が必要です。

    @interface TableView : UITableView
    @end
    //delegate
    @interface ViewController : UIViewController <UIViewControllerDelegate>
    @end

    @interprition ..........

    キャンセル

同じタグがついた質問を見る

  • Swift

    8726questions

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