Help us understand the problem. What is going on with this article?

猿がもがきまくって理解したSwiftのデリゲート(Delegate)という仕組み

More than 3 years have passed since last update.

iOSの勉強を始めて少し経つと、たいていの人は大きな山に遭遇する。

それがDelegate(デリゲート)だ。

いろんな人たちがこのDelegateという山をより分かりやすく説明できないものかと挑んできたが、意外とまだ登りやすいルートは見つかっていないような気がする。

もしかしたら人間は、猿だった頃の記憶を瞬く間に失ってしまうのかもしれない。

幸い僕は運よく(残念ながら)今でも猿なので、Delegateに遭遇した時の、

「Delegateってそもそも一体なんなんだ!」


と思っていた気持ちと、

訳が分からなくて、もがいていた頃の記憶が鮮明に残っている。

あの頃僕が(猿が)七転八倒しながらようやく分かった(気がする)Delegateというものについて説明してみたい。


結論から言うと、

デリゲートというのは一言で言えば「仕組み」だ


どんな仕組みかというと「クラス同士が連絡を取り合う仕組み」

きっと今「デリゲートってなんなんだー!」と思っている人たちの多くは、UIKitのDelegateに遭遇しているのではないだろうか?

UITableViewDelegate
UITextFieldDelegate

とか。

デリゲートっていうのはクラス同士が連絡を取り合う仕組みだと知った上で、「こいつらは何なのか?」と考えると、こういうことになる。

1つ目のUITableViewDelegateは
「テーブルビューが他のクラスと連絡を取るための仕組み」で、

2つ目のUITextFieldDelegateも同様に、
「テキストフィールドが他のクラスと連絡を取るための仕組み」である。



今回はUITextFieldDelegateを例にして説明してみたい。

何も載せてない画面にテキストフィールドを載せるとこうなる。
スクリーンショット_2017-03-11_9_42_17.png

テキストフィールドがViewControllerのプロパティになっている。
(ctrlキーを押しながらstoryboardのテキストフィールドをコードの中にドラッグした)

ViewControllerは、プロパティであるテキストフィールドに直接連絡できる

こんな風に。
スクリーンショット_2017-03-11_10_10_06.png

スクリーンショット 2017-03-11 10.27.25.png

しかし逆の場合はどうだろう?

こうなる。
スクリーンショット 2017-03-11 10.32.02.png

テキストフィールドはviewControllerをプロパティに持ってないので、
連絡方法がない

そこでデリゲートの登場である。


この状況下でテキストフィールドがviewControllerに連絡を取るための仕組みがUITextFieldDelegateである。

こんな風に書いて連絡をする。
スクリーンショット_2017-03-11_11_03_15.png

よくデリゲートの説明に出てくる「3つの呪文」と言うやつだ。
スクリーンショット_2017-03-11_11_06_17.png

デリゲートという仕組みはこんな風に使うのだ。



ちなみにここではUITextFieldDelegateを使ってテキストフィールドから受け取れる連絡メソッドを1つだけしか載せていないが、テキストフィールドから受け取れる連絡は、ユーザが編集を開始した時(textFieldDidBeginEditing)以外にも色々ある。
スクリーンショット 2017-03-11 11.12.58.png
全部で8個?

ここに載っているデリゲートメソッドには、どれもoptional(「オプションだから使っても使わなくてもいいよ」という意味)とついているので、使いたい連絡方法だけを選んでコードに記述すればいい

※(UITextFieldのデリゲートメソッドは全てoptionalだが、他のデリゲートの仕組みではoptionalが付いてないこともある。その場合は必ず書かなければいけない連絡方法ということなので、書く必要がある)


これでデリゲートという仕組みの猿的理解による説明は以上です。


少しは「デリゲートって一体何なんだ!!」という気持ちが収まったでしょうか?

今回は「デリゲートってそもそも何なのよ?」というところにフォーカスしたかったので、UIKitのデリゲートの説明を中心にやりましたが、

このDelegateという仕組みは自分で作ることもできます

例えば自分でUIViewのカスタマイズクラスを作ってViewControllerに載せた場合、自作のクラスにはDelegateは標準装備されてませんので、自作クラスからviewControllerに連絡を取る方法がありません。

そんな場合には自分でDelegateを作ってしまえばいいのです。

機会があればそのやり方についても猿流でお伝えしたいと思います。

最後まで読んでいただいてありがとうございました。

ika_tarou
iPhoneアプリ開発からプログラミング始めた猿。 5年ほど2・3人のチームでカジュアルゲームを作って暮らしてました(cocos2d)。 これからはSwiftでiOSのアプリを作りたいと思っています。
Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
Comments
No comments
Sign up for free and join this conversation.
If you already have a Qiita account
Why do not you register as a user and use Qiita more conveniently?
You need to log in to use this function. Qiita can be used more conveniently after logging in.
You seem to be reading articles frequently this month. Qiita can be used more conveniently after logging in.
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
ユーザーは見つかりませんでした