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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Xcode 7

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

Swift

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

Q&A

解決済

1回答

2744閲覧

<Swift>TableViewについて

TsksHsgw

総合スコア23

Xcode 7

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

Swift

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

0グッド

0クリップ

投稿2016/05/21 23:50

編集2016/05/22 18:41

###前提・実現したいこと
<Swift>
TODOアプリのように、TableViewCell内にTextFieldを組み込んで、
直接文字入力ができるような機能を実装したいと思い、
ネット上で参考になりそうなサンプルを探して実装してみたのですが、エラーが出てしまいます。

どのように改善すればいいかわからずに悩んでいます。
もし、お詳しい方がいらっしゃれば、ご享受いただければ幸いです。

###ソースコード
ViewController.swift

import UIKit class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate, InputTextTableCellDelegate { @IBOutlet weak var tableView: UITableView! override func viewDidLoad() { super.viewDidLoad() } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() } // MARK: - UITableViewDataSource func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return 10; } func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell { let cell: InputTextTableCell = tableView.dequeueReusableCellWithIdentifier("InputTextCell", forIndexPath: indexPath) as! InputTextTableCell cell.delegate = self return cell } // MARK: - InputTextTableCellDelegate func textFieldDidEndEditing(cell: InputTextTableCell, value: NSString) -> () { let path = tableView.indexPathForRowAtPoint(cell.convertPoint(cell.bounds.origin, toView: tableView)) NSLog("row = %d, value = %@", path!.row, value) } // MARK: - UITableViewDelegate func tableView(tableView: UITableView, heightForRowAtIndexPath indexPath: NSIndexPath) -> CGFloat { return InputTextTableCell.height() } }

InputTextTableCell.swift

import UIKit protocol InputTextTableCellDelegate { func textFieldDidEndEditing(cell: InputTextTableCell, value: NSString) -> () } class InputTextTableCell: UITableViewCell, UITextFieldDelegate { override func awakeFromNib() { super.awakeFromNib() } override func setSelected(selected: Bool, animated: Bool) { super.setSelected(selected, animated: animated) } static func height() -> CGFloat { return 75.0 } // MARK: - UITextFieldDelegate internal func textFieldShouldReturn(textField: UITextField) -> Bool { textField.resignFirstResponder() return true } internal func textFieldDidEndEditing(textField: UITextField) { self.delegate.textFieldDidEndEditing(self, value: textField.text!) } }

ソースコードは以上で、2箇所にエラーが出てしまっています。
###該当のソースコード
まず、1箇所目はViewController.swiftの関数<tableView(...CellForRowAtIndexPath){...}>内の以下の部分です。

cell.delegate = self

2箇所目はInputTextTableCell.swiftの<internal func textFieldDidEndEditing>内の以下の部分です。

self.delegate.textFieldDidEndEditing(self, value: textField.text!)

2箇所とも、下記の表記でエラーが出ている状態です。
###エラーの内容

Value of type 'InputTextTableCell' has no member 'delegate'.

エラーの表記内容から、InputTextTableCellのdelegateの部分でエラーが起こってしまっているのかなと思うのですが、
改善の方法がわからず、ご質問した次第です。

どのように改善すればいいのかお分かりの方がいらっしゃったら、改善方法をご享受頂きたく存じます。

よろしくお願い申し上げます。

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

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

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

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

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

guest

回答1

0

ベストアンサー

Delegateの使い方については以下を参考にしてみてください。

【Swift】delegateを完全克服するためのまとめ

以下コードで変更したところ

swift

1// delegateにweak属性を付ける為にclassを追記します 2 3protocol InputTextTableCellDelegate: class { 4 func textFieldDidEndEditing(cell: InputTextTableCell, value: NSString) -> () 5}

swift

1 2class InputTextTableCell: UITableViewCell, UITextFieldDelegate { 3 4 // InputTextTableCellDelegateの変数を定義 5 weak var delegate: InputTextTableCellDelegate! 6 // Storyboardにテキストフィールドを追加 7 @IBOutlet weak var inputTextField: UITextField! 8 9 override func awakeFromNib() { 10 super.awakeFromNib() 11 12 // TextFieldのDelegateをselfに設定、Storyboardで設定してもOK 13 inputTextField.delegate = self 14 } 15 16 // ・・・・ 以下は変更無し 17}

追加質問の回答

以下を見てまだ不明であれば質問してください。
image
image
image
image

投稿2016/05/22 01:04

編集2016/05/23 00:07
_Kentarou

総合スコア8490

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

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

TsksHsgw

2016/05/22 19:10 編集

Kenterou様 ご回答いただき、誠にありがとうございます。 また、Delegateについて参考になるWEBサイトまでお教えいただき、 ありがとうございます。拝見して勉強させていただきます。 早速、コードを直してみたのですが、 <inputTextField>をStoryboard上のTextFieldとの紐付けが上手くできていないのか、シュミレータを起動しようとすると上手く立ち上がりませんでした。 シュミレータを立ち上げようとすると ViewController.swiftの <let cell: InputTextTableCell = ... as! InputTextTableCell>の文が赤くなり、 <Thread1: signal SIGBART>という表記が出るような状態になってしまいました。 ログを見ると、 <Could not cast value of type 'UITableViewCell' (0x108e30128) to 'TableView.InputTextTableCell' (0x107728490). >という表示が出ています。 【UITableViewCellをInputTextTableCellにキャストする事は出来ない】 と書いてあるのだと思うのですが、コードにエラーが出ていない為、何をどのように改善したら良いか検討がつきません。 質問ばかりになってしまい、誠に申し訳ないのですが、 ①inputTextFieldをStoryboard上のTextFieldと結びつける方法 ②let cell: InputTextTableCell 〜 as! InputTextTableCellのエラーの改善方法 について、もし可能であれば、併せてお伺いできますでしょうか?
_Kentarou

2016/05/23 00:07

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

2016/05/23 05:12

Kenterou様 重ね重ね、ご丁寧にご回答頂きまして、誠にありがとうございます。 追記を頂いた通りに設定したところ、改善致しました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問