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

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

ただいまの
回答率

90.51%

  • Swift

    7272questions

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

  • iOS

    4008questions

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

  • Xcode 7

    615questions

    Xcode 7は、ソフトウェア開発のためのアップルの統合開発環境であるXcodeのバージョン。UIを作成するために用いるグラフィカルツールです。iOS9/OS X El Capitan/watchOS2に対応。Swift 2コンパイラーが搭載されています。

tableviewからの画面遷移での多量データの値渡しの手段

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 273

LFOHP

score 11

前提・実現したいこと

NextViewControllerにTableViewからの値渡しをしたいのですが、現時点ではAppDelegateを使ってindexPath.rowは取れています。
クイズアプリを想定していますが、容易に更新可能な多くのデータを受け渡しするとなると・・・
(1)すべてAppDelegateに書き込む。
(2)csvファイルなどを作ってAppDelegate.swift読み込ませる
(3)その他の方法
などが思い浮かびますが、上級者の皆さんのスタンダードな方法はどれでしょうか?
(2)(3)の方法を教えてもらえると勉強になります。

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

エラーメッセージ
でていません。下記でindexPath.rowは受け渡しできています

該当のソースコード

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

    var window: UIWindow?
    var num:Int?

    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
        // Override point for customization after application launch.
        return true
    }
class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {
      let appDelegate = UIApplication.shared.delegate as! AppDelegate


    private let myItems: NSArray = ["TEST1", "TEST2", "TEST3","TEST4"]
    private var myTableView: UITableView!

    override func viewDidLoad() {
        super.viewDidLoad()


        let barHeight: CGFloat = UIApplication.shared.statusBarFrame.size.height


        let displayWidth: CGFloat = self.view.frame.width
        let displayHeight: CGFloat = self.view.frame.height


        myTableView = UITableView(frame: CGRect(x: 0, y: barHeight, width: displayWidth, height: displayHeight - barHeight))


        myTableView.register(UITableViewCell.self, forCellReuseIdentifier: "MyCell")


        myTableView.dataSource = self


        myTableView.delegate = self


        self.view.addSubview(myTableView)
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
    }


     func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        print("Num: \(indexPath.row)")
        print("Value: \(myItems[indexPath.row])")

        tableView.deselectRow(at: indexPath, animated: true)
         appDelegate.num = indexPath.row

        self.present(NextViewController(), animated: true, completion: nil)


    }


    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return myItems.count
    }


    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {


        let cell = tableView.dequeueReusableCell(withIdentifier: "MyCell", for: indexPath as IndexPath)

        cell.textLabel!.text = "\(myItems[indexPath.row])"

        return cell
    }


}
class NextViewController: UIViewController {
    var label :UILabel = UILabel()
    let backButton:UIButton = UIButton()

     let appDelegate = UIApplication.shared.delegate as! AppDelegate

    override func viewDidLoad() {
        super.viewDidLoad()
        self.view.backgroundColor = UIColor.green

        label.frame = CGRect(x: self.view.frame.width/2-150, y:  self.view.frame.height/2, width:  300, height: 60)
        label.textAlignment = .center
        label.textColor = UIColor.white
        label.text = "Num:\(String(describing: appDelegate.num!)) "
        label.font = UIFont.boldSystemFont(ofSize: 30)
        label.adjustsFontSizeToFitWidth = true
        label.layer.masksToBounds = true
        label.layer.cornerRadius = 5.0
        view.addSubview(label)


        backButton.frame = CGRect(x: 0, y: 0, width: 100, height: 100)
        backButton.setTitle("back", for: .normal)
        backButton.setTitleColor(UIColor.blue, for: .normal)
        backButton.layer.position = CGPoint(x: self.view.frame.width/2, y: self.view.frame.height/2+100)
        backButton.addTarget(self, action: #selector(back), for: .touchUpInside)
        self.view.addSubview(backButton)

    }

    @objc func back() {
        self.dismiss(animated: true, completion: nil)
    }

        // Do any additional setup after loading the view.

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
}
}

試したこと

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

Swift4

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

check解決した方法

+1

func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        //print("Num: \(indexPath.row)")
        //print("Value: \(myItems[indexPath.row])")
        num =  Int(indexPath.row)
       vc.nu = num


        tableView.deselectRow(at: indexPath, animated: true)

        self.present(vc, animated: true, completion: nil)

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

NextViewControllerに受け渡し用のプロパティを作って直接渡せばいいと思います。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/12/21 11:26

    具体的に教示して頂けますと幸いです。

    キャンセル

  • 2017/12/21 11:41 編集

    具体的に書いているつもりですが、どの部分が分からないのでしょうか?

    キャンセル

  • 2017/12/21 11:42

    コードを書いてもらえると助かるのですが。「プロパティを作る」とはどうするのでしょうか?

    キャンセル

  • 2017/12/21 11:55

    あなたがAppDelegateに書いている、
    var num:Int?
    こういうのがプロパティです。

    キャンセル

  • 2017/12/21 12:10

    App/Delegateのvar num:Int?を消して
    class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {

    let num:Int = 0

    class NextViewController: UIViewController {

    var num:Int?

    label.text = "Num:\(String(describing: num)) "

    としてみましたが、nilになります

    キャンセル

  • 2017/12/21 12:18

    受け渡し用のプロパティとは、どのように作るのでしょうか?

    キャンセル

  • 2017/12/21 12:47

    受け渡し用のプロパティはそれでいいですが、そこに値を入れないといけません。
    NextViewControllerのインスタンスに対して、プロパティに値を入れて下さい。

    キャンセル

  • 2017/12/21 13:10

    class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {
    var num:Int = 0
    let second:NextViewController = NextViewController()
    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {

    second.num = indexPath.row

    class NextViewController: UIViewController {
    let second:NextViewController = NextViewController()
    var num:Int?
    label.text = "Num:\(String(describing:second.num)) "


    こんなエラーになるのですが、どこがいけないのでしょうか
    Thread 1: EXC_BAD_ACCESS (code=2, address=0x7ffee0944ff8)

    キャンセル

  • 2017/12/21 17:02

    class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {
    var num :Int = 0
    let vc:NextViewController = NextViewController()

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

    num = indexPath.row
    vc.num = num

    //セルの選択解除
    tableView.deselectRow(at: indexPath, animated: true)

    //ここに遷移処理を書く
    self.present(NextViewController(), animated: true, completion: nil)

    class NextViewController: UIViewController {

    var num:Int = 0

    override func viewDidLoad() {

    super.viewDidLoad()
    label.text = " \(String(describing:num))"

    これだと、 var num:Int = 0の0しかでてこないのですが、どこが間違っているのでしょうか

    キャンセル

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

  • ただいまの回答率 90.51%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

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

  • Swift

    7272questions

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

  • iOS

    4008questions

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

  • Xcode 7

    615questions

    Xcode 7は、ソフトウェア開発のためのアップルの統合開発環境であるXcodeのバージョン。UIを作成するために用いるグラフィカルツールです。iOS9/OS X El Capitan/watchOS2に対応。Swift 2コンパイラーが搭載されています。