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

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

ただいまの
回答率

90.46%

  • Swift

    8993questions

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

  • Xcode

    5066questions

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

TableViewControllerからViewControllerのテキストの内容を変化させたい。

解決済

回答 1

投稿 編集

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

ptpt

score 8

前提・実現したいこと

TableViewControllerにあるボタンを押すと、ViewControllerへ遷移すると同時にViewControllerのTextViewに決まった文字(例えば"テスト"など)を表示するようにしたい。
遷移はstoryboardで行っている。

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

TextViewが空白のまま。

該当のソースコード

**label版**

import UIKit

class ViewController: UIViewController, TableViewControllerDelegate {

    @IBOutlet weak var mytext: UITextView!

    @IBOutlet weak var label: UILabel!
    override func viewDidLoad() {
        super.viewDidLoad()
    }

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

    func setText(text: String) {
        label?.text = test
    }

    override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {

        if let tableV = segue.destinationViewController as? TableViewController {
            tableV.delegate = self
        }
    }

}


**ViewController**

import UIKit

class ViewController: UIViewController,TableViewControllerDelegate
{

    @IBOutlet weak var mytext: UITextView!

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


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


    func setText(text: String) {
        mytext.text = text
    }
}


**TableViewController**

import UIKit

protocol TableViewControllerDelegate: class {
    func setText(text: String)
}

class TableViewController: UITableViewController{

    weak var delegate: TableViewControllerDelegate!

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


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

    @IBAction func zenbun(sender: AnyObject) {
        delegate?.setText("test")
    }

}

storyboard

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

0

画面遷移する際にTableViewControllerDelegateselfを設定してください。

import UIKit

class ViewController: UIViewController, TableViewControllerDelegate {

    @IBOutlet weak var mytext: UITextView!

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

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

    func setText(text: String) {
        mytext.text = text
    }

    override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {

        if let tableV = segue.destinationViewController as? TableViewController {
            tableV.delegate = self
        }
    }
}

確認手順

s

回答追記

import UIKit

class ViewController: UIViewController {

    @IBOutlet weak var label: UILabel!
    var labelText: String = ""

    override func viewDidLoad() {
        super.viewDidLoad()

        label.text = labelText
    }
}


class TableViewController: UITableViewController {

    var text = ""

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

    @IBAction func zenbun(sender: AnyObject) {
        text = "test"
        performSegueWithIdentifier("next", sender: nil)
    }

    override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
        if let viewC = segue.destinationViewController as? ViewController {
            viewC.labelText = text
        }
    }
}


イメージ説明

イメージ説明

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/08/13 22:09

    設定してみましたが空白のままです。可能性としてはほかに何かありますでしょうか?

    キャンセル

  • 2016/08/13 22:13

    ちなみにTableViewControlerでボタンを押した時にViewControllerのsetTextメソッドは呼ばれてますか?

    キャンセル

  • 2016/08/13 22:27

    呼ばれてます。

    キャンセル

  • 2016/08/13 22:41

    ラベルの上になにかViewが乗っていて見えていなとか考えられないですか、ラベルの背景色に色を付けて画面にそもそも表示されている事を確認してください。

    キャンセル

  • 2016/08/13 22:56

    表示されています。

    キャンセル

  • 2016/08/13 22:59

    ViewControllerでsetTextで文字を設定するとラベルに表示されますか?

    キャンセル

  • 2016/08/13 23:02

    表示されません。

    キャンセル

  • 2016/08/13 23:03

    textViewの高さを広げて実行してみてください。

    キャンセル

  • 2016/08/13 23:09

    実行してみましたがダメです。

    キャンセル

  • 2016/08/13 23:11

    試しにUILabelに変更して実行しても同じ結果ですか?

    キャンセル

  • 2016/08/13 23:16

    同じ結果です。

    キャンセル

  • 2016/08/13 23:21

    UILabelに変更した状態でいいので質問のコードを現在のものに変更してもらえますか?

    キャンセル

  • 2016/08/13 23:22

    ちなみにzenbunというボタンはTableViewControllerの何処に配置してありますか?

    キャンセル

  • 2016/08/13 23:26

    追加しました。zenbunというボタンはTableViewControllerのstatic cellsの上に貼っています。

    キャンセル

  • 2016/08/13 23:28

    ViewControllerのviewDidLoadとかでLabelに文字を設定すると表示されますか?

    キャンセル

  • 2016/08/13 23:31

    表示されました!!

    キャンセル

  • 2016/08/13 23:36

    直接設定しているので、表示されるのは当然ですがDelegate経由だと表示されないですよね、、、

    その状態でTableViewControlerでボタンを押した時にViewControllerのsetTextメソッドは呼ばれているかもう一度確認してもらってもよいですか?

    キャンセル

  • 2016/08/13 23:50

    メソッドが呼ばれてるか調べる方法を間違えてるかもしれないので、教えていただくことは可能でしょうか?

    キャンセル

  • 2016/08/14 00:07

    確認手順を回答に追記しました、確認してください。

    キャンセル

  • 2016/08/14 00:18

    確認しました。ありがとうございます。また、メソッドは呼ばれています。

    キャンセル

  • 2016/08/14 00:24 編集

    それでもLabelには文字列(test)が設定されていないということですよね?

    label?.text = text
    となっていますが、?を取り
    label.text = text
    にして実行してみてください。

    キャンセル

  • 2016/08/14 00:30

    実行すると
    fatal error: unexpectedly found nil while unwrapping an Optional value
    (lldb)
    というエラーメッセージが表示されます。

    キャンセル

  • 2016/08/14 00:33

    ああ、labelが開放されているみたいですね、、、

    キャンセル

  • 2016/08/14 00:36

    画面遷移はsegueで結んでいるだけですか?どの様になっているでしょうか?

    キャンセル

  • 2016/08/14 00:41

    画面遷移はsegueで結んでるだけです。他の結びはボタンとzenbun関数(setText)で繋がっています。

    キャンセル

  • 2016/08/14 00:44

    ViewControllerに記述しているのは載せてい頂いているコードだけですよね。

    Storyboardの画像載せてもらう事はできますか?該当部分だけで良いので。

    キャンセル

  • 2016/08/14 00:46

    あとlabelの?をはずした状態でviewDidLoadでラベルに文字を設定すると表示されますか?

    キャンセル

  • 2016/08/14 00:48

    > 他の結びはボタンとzenbun関数(setText)で繋がっています。

    これはTableViewControllerの中だけで完結しているIBActionですよね?

    キャンセル

  • 2016/08/14 00:55

    すみません、これはTableViewControllerからViewControllerへの遷移ですか?

    キャンセル

  • 2016/08/14 00:57

    載せてるコードで全部です。
    この画像で大丈夫でしょうか?
    viewDidLoadでも?をつけないと同様のエラーメッセージが出ます。
    完結してるの意味がわかりませんが上に載せた通りのコードです。

    キャンセル

  • 2016/08/14 00:58

    そうです。TableViewControllerからViewControllerへの遷移です。

    キャンセル

  • 2016/08/14 01:00

    これはただ、遷移先のViewControllerに対してラベルに文字を設定したいという質問ですか?

    キャンセル

  • 2016/08/14 01:01

    > TableViewControllerからViewControllerへの遷移です。

    この場合Delegateは必要ありません。

    キャンセル

  • 2016/08/14 01:04

    ViewControllerへの画面遷移のアクションは何をした時に実行されますか?

    そのようなボタンが無いのと、TableViewControllerにSegueを呼ぶようなメソッドがないので、、、

    キャンセル

  • 2016/08/14 01:06

    TableViewControllerのボタンを押すとそこで初めてViewControllerに文字が表示されるという仕組みの質問です。

    キャンセル

  • 2016/08/14 01:13

    Segue(画面遷移)が実行されるのはzenbunボタンを押した時ですか?

    キャンセル

  • 2016/08/14 01:15

    そうです。

    キャンセル

  • 2016/08/14 01:18 編集

    zenbunボタンで遷移するようにすると値が設定できないのでSegueをViewControllerにむすんでperformSegueWithIdentifierで遷移を呼ぶように変更してみてください。
    ※Identifierはnextという文字列
    後は回答に追記したように変更すればいけると思います。

    キャンセル

  • 2016/08/14 01:27

    なにからSegueをViewControllerに結ぶんでしょうか?
    またperformSegueWithIdentifierはViewControllerに書くんでしょうか?

    キャンセル

  • 2016/08/14 01:40

    performSegueWithIdentifierは回答に追記した様に記述してください。

    結び方は画像を載せました。

    キャンセル

  • 2016/08/14 01:58

    結び方がわかりません。申し訳ないですが何からViewControllerにsegueを結ぶんでしょうか?

    キャンセル

  • 2016/08/14 02:02

    一枚目の画像が見えていませんでした。↑は忘れてください。

    キャンセル

  • 2016/08/14 02:02

    画像で分かりませんか?TableViewControllerの黄色いところから結べると思いますが。
    左のツリー表示の所のTableViewControllerのところからでも同じです。

    キャンセル

  • 2016/08/14 02:03

    すみません、一枚目の画像うまく載せられず遅れてました。

    キャンセル

  • 2016/08/14 02:04

    最初にボタンから結んであったSegueは一度削除してくださいね。画面遷移を2度してしまいます。

    キャンセル

  • 2016/08/14 02:06

    ありがとうございました!!とうとう完成しました!!感謝します!!

    キャンセル

  • 2016/08/14 02:07

    お疲れ様でした\(^o^)/

    キャンセル

  • 2016/08/14 02:08

    ちなみにDelegateは遷移先から遷移元の画面に値を設定したい場合に使用したりします。

    キャンセル

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

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

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

  • Swift

    8993questions

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

  • Xcode

    5066questions

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