< Return to Video

Методи об'єкту

  • 0:00 - 0:04
    В попередньому обговоренні, ми дізналися,
    про те як зробити тип об'єкта для подання
  • 0:04 - 0:06
    наших двох Вінстонів як об'єктів
  • 0:06 - 0:09
    а потім встановили їх з конструкторами.
  • 0:09 - 0:13
    Тепер, тип об'єкта не тільки повинен бути
    пов'язаним з властивостями
  • 0:13 - 0:17
    Це також може пов'язуватись з
    функціональністю. Подумайте про світ і всі
  • 0:17 - 0:19
    типи об'єктів в ньому
  • 0:19 - 0:24
    як про нас, людей. У всіх нас є рісті вік,
    але є те, що ми можемо робити, це спати,
  • 0:24 - 0:26
    смачно поїсти, і програмувати.
  • 0:26 - 0:31
    І ми хочемо бути в змозі зв'язати ці
    функції з тими типами об'єктів.
  • 0:31 - 0:36
    У цій програмі, де ми зупинилися минулого
    разу, ми маємо функцію тут,
  • 0:36 - 0:41
    drawWinston, що ми викликаємо по обох
    об'єктах Вінстон. Чи Не було б здорово,
  • 0:41 - 0:43
    якщо б ми могли просто прикріпити це
  • 0:43 - 0:49
    до типу об'єкта Вінстон. Ну ми можемо, і
    це легко зробити.
  • 0:49 - 0:56
    Тому, під нашим конструктором, ми введемо
    Winston.prototype велика W
  • 0:56 - 0:59
    і prototype, це нове слово, яке ви,
    ймовірно, не бачили
  • 0:59 - 1:06
    І прототип це властивість об'єкта,
    до якого ми можемо приєднати функції
  • 1:06 - 1:13
    і це буде означати, що кожен об'єкт, який
    є екземпляром, матиме ці функції.
  • 1:13 - 1:20
    Отже, ми можемо ввести ".prototype.", а
    потім ім'я функції, тому ми вводимо "draw"
  • 1:20 - 1:26
    рівне, і тоді ми можемо взяти наш
    drawWinston код і ми можемо покласти його
  • 1:26 - 1:33
    перемістити його всередину сюди. Добре так
    що тепер, що ми додали функцію draw
  • 1:33 - 1:37
    до нашого Winston prototype. А це значить,
    ми повинні бути в змозі викликати draw()
  • 1:37 - 1:40
    будь-якого типу об'єкта Вінстон
  • 1:40 - 1:42
    Гаразд, отже, ми повинні бути в змозі
    викликати draw () по
  • 1:42 - 1:45
    winstonTeen або winstonAdult.
  • 1:45 - 1:50
    І коли у нас є функція, як ця, то
    ми можемо викликате по об'єкті,
  • 1:50 - 1:53
    ми фактично називаємо це "метод" так що ви
    можете чути як я кажу "метод"зараз.
  • 1:54 - 1:58
    Гаразд, скажемо це " метод відображення"
    Гаразд.
  • 1:58 - 2:03
    Отже, тепер ми видалимо це, і ось це і
    тепер побачимо чи ми можемо викликати
  • 2:03 - 2:07
    draw() winstonTeen.draw()
  • 2:07 - 2:14
    Гаразд. У нас помилка, що стирчить тут, і
    вона говорить: "winstObject не визначений"
  • 2:14 - 2:21
    І перш ніж, ми пропустимо цей аргумент
    в drawWinston, що був об'єктом Вінстон
  • 2:21 - 2:26
    але тепер ми не пропускаємо його отже, ми
    могли б змінити це, щоб пропускати.
  • 2:26 - 2:31
    а тоді, ми подивимося, чи проходимите тут?
    Ми слід би пропустити winstonTeen. Гаразд.
  • 2:31 - 2:37
    Спрацювало, але це, здається, теж не дуже
    розумно. Я і так вже викликаю draw на
  • 2:37 - 2:38
    самому об'єкті.
  • 2:38 - 2:44
    Це не повинно пройти в об'єкті також.
    Це здається зайвим.
  • 2:44 - 2:48
    І це правда, ми не повинні робити це, так
    що видалимо це тут, а тепер подумаємо.
  • 2:48 - 2:54
    Якщо ми всередині об'єкту, що використати
    щоб мати доступ до властивостей об'єкту?
  • 2:54 - 3:00
    ви можете поглянути на наш конструктор і
    пам'ятаєте спеціальне ключове слово "this"
  • 3:00 - 3:09
    "А, якщо ми просто змінимо це, на ось це!
    Отже, ми міняємо winstObject на "this".
  • 3:09 - 3:13
    Так як ми знаходимося всередині об'єкту
    прямо зараз. Ця функція обраховується
  • 3:13 - 3:16
    відповідно об'єкту, отже, "this"
    відноситиметься до цього поточного об'єкту
  • 3:16 - 3:20
    І так, спосіб, яким ми можемо просто
    сказати: "this", і ми отримаємо доступ до
  • 3:20 - 3:23
    всіх властивостей цього поточного об'єкту
  • 3:23 - 3:31
    І це повністю працює, бачите? Чи не круто?
    І тепер можемо ввести WinstonAdult.draw()
  • 3:32 - 3:38
    І це матиме доступ до властивостей winston
    Adult так як це об'єкт, що виклкається.
  • 3:38 - 3:44
    Ось це дійсно здорово про "This" ключове
    слово, хоча це іноді заплутує коли говориш
  • 3:46 - 3:52
    Добре, що ж було весело, тому додамо ще
    один метод. І що ще може робити Вінстон?
  • 3:52 - 3:58
    Можливо він розкаже. Тому, зробимо Winston
    .prototype.talk тому, ми можемо додати
  • 3:58 - 4:01
    стільки методів скільки хочем до прототипу
  • 4:01 - 4:05
    Так що ми скажемо: "Я Вінстон!"
  • 4:05 - 4:13
    І тоді ми просто введемо this.x+20,і
    this.y+150.
  • 4:13 - 4:17
    А в результаті, нічого не сталося, але,
    звичайно, це тому, що я ще не
  • 4:17 - 4:20
    викликаю цю функцію.
  • 4:20 - 4:24
    Отже, зробимо щоб підліток говорив
    winstonTeen.talk() [нерозбірливо] говорить
  • 4:24 - 4:25
    весь час, гаразд.
  • 4:25 - 4:30
    Я Вінстон. А потім winstonAdult.talk ()
  • 4:30 - 4:37
    Добре, тепер маємо цей тип об'єкту Вінстон
    що має властивості: прізвисько,
  • 4:37 - 4:42
    вік, х, у; і він має функціональності:
    способи, методи; які діють по-різному
  • 4:42 - 4:45
    в залежності від властивостей
  • 4:45 - 4:48
    і ми можемо створити стільки екземплярів
    Вінстона, скільки ми хочемо, і викликати
  • 4:48 - 4:50
    за одним з цих методів на ньому.
  • 4:51 - 4:53
    Досить круто, так?
Title:
Методи об'єкту
Description:

Це просто показ екрану нашої інтерактивної бесіди щодо кодування, готової щоб полегшити створення перекладу і субтитрів. Краще дивитися наші бесіди тут:
https://www.khanacademy.org/cs/programming/

more » « less
Video Language:
English
Duration:
04:54
Іван Соломаха edited Ukrainian subtitles for Object Methods (Video Version)
Іван Соломаха edited Ukrainian subtitles for Object Methods (Video Version)
Іван Соломаха edited Ukrainian subtitles for Object Methods (Video Version)
Іван Соломаха edited Ukrainian subtitles for Object Methods (Video Version)
Іван Соломаха edited Ukrainian subtitles for Object Methods (Video Version)
Іван Соломаха edited Ukrainian subtitles for Object Methods (Video Version)
Іван Соломаха edited Ukrainian subtitles for Object Methods (Video Version)
Іван Соломаха edited Ukrainian subtitles for Object Methods (Video Version)
Show all

Ukrainian subtitles

Incomplete

Revisions