-
Notifications
You must be signed in to change notification settings - Fork 16
Object.defineProperty
• Object.assign()
• Object.create()
Этот метод позволяет создать объекту свойство с дескриптором
- Первый аргумент метода - ссылка на объект, которому добавляется свойство
- Второй аргумент - имя свойства ( строка )
- Третий аргумент - объект дескриптора свойства
☕ 1️⃣
Добавим свойство type объекту sample и сделаем это свойство неперечислимым
var sample = {
name: "figure",
size: 100,
color: "red"
}
Object.defineProperty ( sample, 'type', {
value: "svg",
enumerable: false
})
Object.keys ( sample )► (3) ["name", "size", "color"]☕ 2️⃣
Добавим еще одно свойство объекту sample
Свойство operation будет с геттером и сеттером
get() и set() в дескрипторе свойства, нельзя использовать атрибуты writable и value
Object.defineProperty ( sample, "operation", {
get: () => this.operation ?
this.operation.substr ( 0, 1 ) : "?",
set: newVal => this.operation = newVal + "***"
})▼ {name: "figure", size: 100, color: "red", type: "svg"}
color: "red"
name: "figure"
size: 100
operation: (...)
type: "svg"
► get operation: () => {…}
► set operation: newVal => this.operation = newVal + "***"
► __proto__: Object☕ 3️⃣
var course = 28
var thing = {
name: "Утюг",
mark: "Tefal",
priceUSD: 20
}
Object.defineProperty ( thing, "priceUAH", {
get: function () {
return this.priceUSD * course
},
set: function ( newPriceUAH ) {
this.priceUSD = newPriceUAH / course
}
})
console.log ( thing.priceUAH )560Теперь выполним присваивание значения вычисляемому свойству ( вызывая под капотом сеттер этого свойства ):
thing.priceUAH = 450
console.log ( thing.priceUDS )8.928571428571429Выведем в консоль дескриптор вычисляемого свойства priceUAH
console.log (
Object.getOwnPropertyDescriptor ( thing, "priceUAH" )
)▼ {get: ƒ, set: ƒ, enumerable: true, configurable: true}
configurable: true
enumerable: true
► get: ƒ priceUAH()
► set: ƒ priceUAH( newPriceUAH )
► __proto__: Object• Object.defineProperties()
• Object.entries()
• Object.freeze()
• Object.getOwnPropertyDescriptor()
• Object.getOwnPropertyDescriptors()
• Object.getOwnPropertyNames()
• Object.getOwnPropertySymbols()
• Object.getPrototypeOf()
• Object.is()
• Object.isExtensible()
• Object.isFrozen()
• Object.isSealed()
• Object.keys()
• Object.preventExtensions()
• Object.seal()
• Object.setPrototypeOf()
• Object.values()
© 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
Коды символов