-
Notifications
You must be signed in to change notification settings - Fork 16
scroll
garevna edited this page Dec 25, 2018
·
3 revisions
✅ scrollHeight
полная высота элемента
✅ scrollWidth
полная ширина элемента
✅ clientHeight
высота видимой части элемента
( за вычетом полосы прокрутки )
✅ clientWidth
ширина видимой части элемента
( за вычетом полосы прокрутки )
✅ offsetHeight
высота видимой части элемента
( с учетом полосы прокрутки )
✅ offsetWidth
ширина видимой части элемента
( с учетом полосы прокрутки )
✅ scrollTop
высота "прокрученной" части элемента
( сверху )
✅ scrollLeft
ширина "прокрученной" части элемента
( слева )
| ☕ 1️⃣ |
|---|
var randomMovie = ( function ( url ) {
function randomPosition ( axis ) {
return Math.round (
Math.random() * window[ `inner${[ "Height", "Width" ][ axis ]}` ]
- logo [ `offset${[ "Height", "Width" ][ axis ]}` ]
)
}
var logo = document.body.appendChild (
document.createElement ( "img" )
)
logo.src = url
logo.width = 70
logo.style = `
transition: all 1s;
position: fixed;
top: ${randomPosition ( 0 )}px;
left: ${randomPosition ( 1 )}px;
`
function randomDistance ( axis ) {
return randomPosition ( axis ) -
logo [ `offset${[ "Top", "Left" ][ axis ]}` ]
}
return function ( num ) {
while ( num --> 0 ) {
var sign = Math.random() < 0.5 ? -1 : 1
var transformations = [
`scale(${Math.max(Math.random(),0.3)})`,
`rotate(
${sign * Math.round( Math.random()*360 )}deg)`,
`translate(
${randomDistance(1)}px,
${randomDistance(0)}px
)`
]
var transformation = transformations [
Math.round ( Math.random()*( transformations.length - 1 ) )
]
setTimeout (
( function ( img, mc ) {
return function () {
img.style.transform = mc
}
})( logo, transformation )
, Math.round ( 1000*num )
)
}
}
})( "https://cdn.vuetifyjs.com/images/logos/v-alt.svg" )
randomMovie ( 50 )
© Irina H.Fylyppova 2018
Использование данных материалов или любой их части коммерческими школами ( курсами ) является нарушением авторских прав
| 1 | 2 | 3 | 4 | 5 |
| 6 | 7 | 8 | 9 | 10 |
| 11 | 12 | 13 | 14 | 15 |
| 16 | 17 | 18 | 19 |
| ⏬ |
|---|
- Блок-схема алгоритма
- Developer Tools
- Chrome DevTools
- Переменные
- Оператор typeof
- Структуры данных
- Операторы присваивания
- Логические выражения
- Условные операторы
- Инкремент
- Свойство length
- Оператор цикла for
- UTF-8
Homework
- Приведение типов
- NaN | null | Infinity
- BigInt (ES10)
- Функции
- Методы
- Методы строк
- Методы массивов
- Date ()
Самостоятельная работа
Практика (XSS)
Homework
- Циклы while и do...while
- Циклы for...of и for...in
- Параметры по умолчанию
- Объект function
Практика
Homework
- Нативные и host-объекты
- Литерал объекта
- Унаследованные свойства
- Конструктор
- Модель наследования
- Публичные и приватные свойства
- Оператор in
1
Homework
- Итерирующие методы массивов
- Тестирование производительности
- SHA
Homework
- Размеры и прокрутка элемента
- Event Loop
- async | await
- API
- REST | HATEOAS
- status codes
JSON placeholder-
JSON server
fake chat
Homework
- strict mode
- Вычисляемые имена свойств
- Краткий синтаксис методов
- Краткий литерал объекта
- Классы
Homework
- :not(:defined)
- Shadow DOM
- Custom elements
- Lifecycle hooks
- whenDefined
- <template>
- slot
1
2
3
Homework
- npm
- webpack
Упражнение 1- ES6 модули
Упражнение 2- --mode | --watch
Упражнение 3
Упражнение 4
Упражнение 5
Упражнение 6
Упражнение 7
Упражнение 8
Homework
| ⏫ |
|---|

Дополнительно
Справочная инфо
Git Bush
TCP/IP
Коды символов