YouTube

Got a YouTube account?

New: enable viewer-created translations and captions on your YouTube channel!

Ukrainian subtitles

← Розміщення елементів в CSS

Get Embed Code
7 Languages

Showing Revision 3 created 04/27/2016 by Julia@0503.

  1. Зараз ми вивчимо, як
    використовуючи CSS,

  2. можна переміщати об'єкти.
  3. Не просто ставити їх один біля одного,
  4. а справді розміщувати їх один на одному.
  5. Тут ми маємо веб-сторінку
  6. з декількома заголовками, зображеннями
  7. і декількома абзацами ось тут.
  8. І всі вони зараз розставлені
  9. за стандартним принципом розміщення,
  10. яку використовує браузер
  11. і яку ми називаємо
    статичне або нормальне розміщення.
  12. Це означає, що рядкові елементи,
  13. такі як зображення,
  14. розміщені зліва направо,
  15. а блокові елементи,
  16. такі як заголовки і абзаци,
  17. розміщені з верху до низу.
  18. Ми можемо змінити цей принцип розміщення
  19. за допомогою властивостей розміщення CSS.
  20. Спробуймо це зробити на цьому
    зображенні пейзажу (landscape).
  21. Ми напишемо "position" (розміщення),
    двокрапку
  22. і значення "relative" (відносний).
  23. Відносний принцип розміщення означає:
  24. "Розмісти його, як зазвичай,
  25. але потім змісти його
    на певну кількість одиниць".
  26. Щоб сказати браузеру, на яку кількість одиниць
  27. потрібно змістити об'єкт,
  28. ми маємо використати поєднання
  29. чотирьох нових властивостей CSS:
  30. Top (верх), bottom (низ) , left
    (лівий бік), і right (правий бік).
  31. Скажімо, ми хочемо, щоб зображення
  32. було на 20 пікселів нижче.
  33. Напишімо: top: 20 px,
  34. І ще на 10 пікселів вліво...
  35. Ми напишемо: left: 10px.
  36. Це достатньо точно,
  37. але не ідеально точно.
  38. Я хочу показати вам щось значно крутіше.
  39. Абсолютне розміщення.
  40. Ми його використовуємо, щоб
  41. забрати елемент зі звичного русла
  42. і поставити його будь-де на екрані.
  43. Щоб зробити це,
  44. Я зміню "relative"
  45. на "absolute"
  46. на цьому пейзажі,
  47. і збережу його у лівому верхньому куті.
  48. І ви можете побачити,
  49. що тепер пейзаж
  50. перекрив наші зображення
    і заголовок "dance party".
  51. І зараз ми це виправимо.
  52. Почнімо з Вінстона (winston).
  53. Ми додамо йому правило
  54. і напишемо в ньому "position: absolute",
  55. і потім, скажімо,
  56. верх: 40 пікселів,
  57. оу, краще 50 пікселів.
  58. Ліва сторона: 50 пікселів.
  59. Гаразд, так виглядає добре.
  60. І Хопер (hopper) також дуже хоче
  61. залізти наверх.
  62. Тому ми також дамо Хоперу
  63. абсолютне розміщення
  64. і напишемо: верх: 30 пікселів
  65. і зліва: 60 пікселів.
  66. Добре, моя мета
  67. зробити так, наче Хопер
  68. танцює перед Вінстоном.
  69. Але зараз це так не виглядає,
  70. тому що Вінстон намальований
  71. поверх Хопера.
  72. Щоб виправити це,
  73. я можу змінити порядок розміщення
  74. тегів в коді HTML.
  75. Але існує кращий спосіб —
  76. використати властивість CSS "z-index".
  77. Ми можемо використати її,
    щоб сказати браузеру,
  78. в якому саме порядку
  79. розміщувати елементи,
  80. надавши їм різні індекси.
  81. Я почну з пейзажу
  82. і дам йому "z-index" 1.
  83. Далі йде Вінстон з цифрою 2
  84. і Хопер вилазить нагору з цифрою 3.
  85. Чудово!
  86. Тепер Хопер танцює перед Вінстоном,
  87. навіть якщо останньому це не подобається...
  88. але йому доведеться змиритись.
  89. Але в нас досі є приховані заголовки
    і текст.
  90. Тому... спробуймо поставити...
  91. Можливо, я хочу, щоб
  92. заголовок "Dance party" був зверху
    над усім.
  93. Тому я додам йому
  94. абсолютне розміщення
  95. і "z-index" 4.
  96. Так виглядає добре.
  97. Можливо, лівіше на 10 пікселів.
  98. Просто пересунемо його трохи.
  99. Може, трошки більше.
  100. Чудово, так це все має гарний вигляд.
  101. Тепер, слова пісні.
  102. Я насправді хочу,
  103. щоб вони відображалися знизу під всім.
  104. Тому я думаю тут скористатись
  105. відносним розміщенням
  106. і потім просто додати
    значення верху,
  107. яке, як ви знаєте,
  108. буде дорівнювати висоті зображення.
  109. Це буде двісті двадцять пікселів.
  110. Гаразд, тепер виглядає справді добре.
  111. У нас зараз відбувається справді
    драйвова вечірка.
  112. Зараз, якщо ви зупините відео
    і спробуєте прокрутити сторінку,
  113. ви побачите, що все прокручується разом.
  114. І важливим є те,
  115. що абсолютне розміщення є відносним
    до верху сторінки.
  116. Тому, коли ви будете
    прокручувати сторінку вниз,
  117. об'єкти, які мали 10 пікселів зверху,
  118. не залишатимуться на екрані,
  119. тому що ви рухатиметесь далі вниз.
  120. Ще однією можливістю
  121. є фіксоване розміщення (fixed),
  122. яке буде виглядати так, наче
  123. елементи не рухаються взагалі.
  124. І якщо ви хочете це випробувати,
  125. ми можемо просто змінити
  126. h1 з абсолютного на фіксований.
  127. А тепер поставте на паузу відео і спробуйте
  128. прокрутити сторінку, і ви побачите,
  129. що напис "Dance party" залишається на одному
    й тому ж місці.
  130. Тому що зараз він є відносним
  131. до верху самого екрана, вікна.
  132. Гаразд, ми навчились, як використовувати
  133. три різні властивості розміщення,
  134. щоб робити справді класні речі.
  135. Що ж, коли ми використовуємо
  136. абсолютне і фіксоване розміщення?
  137. Ви можете використовувати його,
  138. щоб зробити певну гру,
  139. як я зробила тут,
  140. тому що ви захочете розмістити
  141. усі частини дійства в браузері.
  142. Але ви також можете використовувати їх
  143. і для звичайних веб-сторінок,
  144. таких як на Khan Academy.
  145. Ми використовуємо абсолютне розміщення
    для моделей,
  146. які розташовані посередині сторінки,
  147. а фіксоване розміщення
  148. для поля пошуку на сторінці команди,
  149. щоб його завжди було видно
    під час прокрутки.
  150. Напевно, ви не будете використовувати
  151. розміщення на кожній сторінці,
  152. але коли використовуватимете,
  153. ви будете дуже щасливі,
    що така можливість існує.
  154. Переклад на українську мову: Зоряна Гаврилюк, рев'юер: Юлія Білаш, Благодійний фонд "MagneticOne.org"