-
Notifications
You must be signed in to change notification settings - Fork 16
calculated prop names
garevna edited this page Oct 31, 2018
·
5 revisions
☕ 1️⃣
var bag = {
[ "prop" + 1 ]: "👜",
[ "prop" + 2 ]: '🍄',
[ "prop" + 3 ]: "🎓",
}
console.log ( bag.prop1 ) // 👜
console.log ( bag.prop2 ) // 🍄
console.log ( bag.prop3 ) // 🎓☕ 2️⃣
var prop = "prop"
var id = "____"
var num = [ 1, 2, 3 ]
var bag = {
[ prop + id + num [ 0 ] ]: "👜",
[ prop + id + num [ 1 ] ]: '🍄',
[ prop + id + num [ 2 ] ]: "🎓",
}
console.log ( bag.prop____1 ) // 👜
console.log ( bag.prop____2 ) // 🍄
console.log ( bag.prop____3 ) // 🎓☕ 3️⃣
var prop = [ "smile", "clock", "book" ]
var bag = {
[ `____${prop [ 0 ]}` ]: "😉",
[ `____${prop [ 1 ]}` ]: '⏰',
[ `____${prop [ 2 ]}` ]: "📖",
}
console.log ( bag.____smile ) // 😉
console.log ( bag.____clock ) // ⏰
console.log ( bag.____book ) // 📖☕ 4️⃣
let sample = {}
let props = [
{ prop: "mouse", val: "🐭" },
{ prop: "monkey", val: '🐒' },
{ prop: "chicken", val: "🐥" }
]
for ( let x of props ) {
Object.assign( sample, { [ x.prop ] : x.val } )
}
console.log ( sample.mouse )
console.log ( sample.monkey )
console.log ( sample.chicken )☕ 5️⃣
var bag = {
name: "👜",
putContent: ( function ( things ) {
return function () {
for ( let item of things ) {
this[ `get${item.name}` ] = function () {
return item.val
}
}
delete this.putContent
}
}) ([
{ name: "Rose", val: '🌹' },
{ name: "Flower", val: "🌸" },
{ name: "Mashroom", val: "🍄" }
])
}
console.log ( bag )
bag.putContent ()
console.log ( bag )
console.log ( bag.getRose() )
console.log ( bag.getFlower() )
console.log ( bag.getMashroom() )► {name: "👜", putContent: ƒ}
► {name: "👜", getRose: ƒ, getFlower: ƒ, getMashroom: ƒ}
🌹
🌸
🍄
© 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
Коды символов