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

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

ただいまの
回答率

90.37%

  • Swift 2

    1341questions

    Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。

UITableViewCell内のTextFieldの値を取得したい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 2,864

mochi9902

score 21

UITableViewCell内にTextFieldを配置し、
改行、もしくはタップしたタイミングで入力した値を取得したいです。

具体的には、カスタムのUITableViewCellクラスであるTextFieldEditCellクラスを定義し、そこにUILabelとUITextFieldを設置、さらにカスタムのDelegateとしてTextFieldEditCellDelegateをprotcolとして追加しました。
対象のViewControllerにUITableViewを設置し、そのセルに上記のクラスを設定。
TextFieldEditCellDelegateで定義したtextFieldDidEndEditingメソッドを呼び出して入力した値を取得します。

以下のソースコードでは、UserOptionTableViewController.swiftのtextFieldDidEndEditingメソッドが呼び出されず、入力した値が取得できていない状態です。

どうすれば、メソッドを呼び出すことができるのでしょうか?
ご教授お願いします。

TextFieldEditCell.swift

import UIKit

protocol TextFieldEditCellDelegate: class {
    func textFieldDidEndEditing(cell: TextFieldEditCell, value: NSString)
}

class TextFieldEditCell: UITableViewCell, UITextFieldDelegate {

    @IBOutlet weak var titleLabel: UILabel!
    @IBOutlet weak var textField: UITextField!
    weak var delegate: TextFieldEditCellDelegate! = nil

    override func awakeFromNib() {
        super.awakeFromNib()
        // Initialization code
    }

    override func setSelected(selected: Bool, animated: Bool) {
        super.setSelected(selected, animated: animated)

        // Configure the view for the selected state
    }

    func setCell(name: String, value: String?) {
        titleLabel.text = name
        textField.text = value
    }

    internal func textFieldShouldReturn(textField: UITextField) -> Bool {
        textField.resignFirstResponder()
        return true;
    }

    internal func textFieldDidEndEditing(textField: UITextField) {
        self.delegate.textFieldDidEndEditing(self, value: textField.text!)
    }
}

UserOptionTableViewController.swift

class UserOptionViewController: UIViewController, UITableViewDelegate,UITableViewDataSource, TextFieldEditCellDelegate {

    var optionEntity: OptionEntity = OptionEntity();
    var viewData: Array<OptionProperty> = []
    @IBOutlet weak var optionDataTableView: UITableView!
    @IBAction func saveTransaction(sender: AnyObject) {

    }

    override func viewDidLoad() {
        super.viewDidLoad()

        let transaction = PostDataTransaction()
        transaction.selectOption("xxx@gmail.com")

        let defaults = NSUserDefaults.standardUserDefaults()
        if let data = defaults.objectForKey("optionData") {
            let optionData: NSData = data as! NSData
            do {
                let optionDataObj: NSDictionary = try NSJSONSerialization.JSONObjectWithData(optionData, options: NSJSONReadingOptions.AllowFragments) as! NSDictionary

                optionEntity.setAccountName(optionDataObj["accountname"] as! String)
                optionEntity.setPassword(optionDataObj["password"] as! String)
                optionEntity.setSmtphost(optionDataObj["smtphost"] as! String)
                optionEntity.setSmtpuser(optionDataObj["smtpuser"] as! String)
                optionEntity.setSmtppassword(optionDataObj["smtppassword"] as! String)
                optionEntity.setSmtpssl(optionDataObj["smtpssl"] as! String)
                optionEntity.setSmtpauth(optionDataObj["smtpauth"] as! String)
                optionEntity.setSmtpport(optionDataObj["smtpport"] as! String)
            } catch {
                // error
            }
        }

        viewData = optionEntity.toArrayForView()
        //let optionDataTableView = UITableView(frame: view.frame, style: .Grouped)
        optionDataTableView.delegate = self
        optionDataTableView.dataSource = self
        //optionDataTableView.allowsSelectionDuringEditing = true
    }

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

    // MARK: - Table view data source

    func numberOfSectionsInTableView(tableView: UITableView) -> Int {
        // #warning Incomplete implementation, return the number of sections
        return 2
    }

    func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        // #warning Incomplete implementation, return the number of rows
        if section == 0 {
            return 2
        }
        return 5
    }

    // セクションのタイトル
    func tableView(tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
        if(section == 0) {
            return "アカウント情報"
        } else {
            return "SMTP情報"
        }
    }

    func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        let cell: TextFieldEditCell = tableView.dequeueReusableCellWithIdentifier("optionCell", forIndexPath: indexPath) as! TextFieldEditCell
        cell.delegate = self
        if indexPath.section == 0 {
            cell.setCell(viewData[indexPath.row].key, value: viewData[indexPath.row].value)
        } else {
            cell.setCell(viewData[indexPath.row + 2].key, value: viewData[indexPath.row + 2].value)
        }
        return cell
    }

    // 入力が終わったタイミングで以下のメソッドが実行し、入力した値を取得したいが、実行されていない状態。
    func textFieldDidEndEditing(cell: TextFieldEditCell, value: NSString){
        let path = optionDataTableView.indexPathForRowAtPoint(cell.convertPoint(cell.bounds.origin, toView: optionDataTableView))
        print("row=%d, value = %@", path!.row, value)
        //NSLog("row=%d, value = %@", path!.row, value)
    }
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

+1

試してませんが、セルのTextFieldのdelegateが設定されていますか?
Storyboardで設定されているのでした違う原因だと思いますが、確認してください。

override func awakeFromNib() {
    super.awakeFromNib()
    textField.delegate = self
}

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/07/24 15:00

    ありがとうございます。
    おかげで解決できました。

    キャンセル

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

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

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

  • Swift 2

    1341questions

    Swift 2は、Apple社が独自に開発を行っている言語「Swift」のアップグレード版です。iOSやOS X、さらにLinuxにも対応可能です。また、throws-catchベースのエラーハンドリングが追加されています。