-
Notifications
You must be signed in to change notification settings - Fork 11
Моисеев Михаил #11
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: master
Are you sure you want to change the base?
Моисеев Михаил #11
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -4,8 +4,21 @@ | |
| * Когда присваивается корректный e-mail в консоль выводится сообщение email valid. | ||
| * Когда присваивается некорректный e-mail возбуждается ошибка. | ||
| */ | ||
|
|
||
| function decorEmail(target: object, propertyKey: string): any { | ||
| let regExp = /[a-z]+@[a-z]+\.[a-z]+/gi; | ||
| let property: PropertyDescriptor = { | ||
| set: (value: string) => { | ||
| if (regExp.test(value)) { | ||
| console.log("e-mail valid"); | ||
| } else { | ||
| console.log("Error"); | ||
| } | ||
| } | ||
| }; | ||
| return property; | ||
| } | ||
| class Example { | ||
| @decorEmail | ||
| public email: string = ""; | ||
| } | ||
|
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 3 бала |
||
|
|
||
|
|
||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -1,39 +1,61 @@ | ||
| /** Задача 3 | ||
| * Ниже представлен код в котором, пропущены участки кода. | ||
| * Требуется дописать участки кода так, чтобы программа компилировалась. | ||
| * Использование типа any допустимо только в Control<any>. | ||
| * Переопределенные методы getValue и setValue в классах TextBox и SelectBox должны | ||
| * принимать и возвращать только свой результирующий тип (string и SelectItem) | ||
| * Методы register и getInstance класса FactoryControl. Должны принимать и возвращать только те типы, | ||
| * которые унаследованы от класса Control<T>. | ||
| */ | ||
|
|
||
| /**Базовый класс для контролов */ | ||
| abstract class Control<T> { | ||
| public name: string = ""; | ||
|
|
||
| protected value: T; | ||
|
|
||
| constructor(value: T, name: string) { | ||
| this.name = name; | ||
| this.value = value; | ||
| } | ||
| /**взять значение из контрола */ | ||
| public abstract getValue(): T; | ||
| /**установить значение в контрол */ | ||
| public abstract setValue(val: T): void; | ||
| } | ||
| /**Класс описывает TextBox контрол */ | ||
| class TextBox extends Control<string> { | ||
| constructor(value: string = '', name: string) { | ||
| super(value, name); | ||
| } | ||
|
|
||
| public getValue(): string { | ||
| return this.name; | ||
| } | ||
| public setValue(val: string): void { | ||
| this.name = val; | ||
| } | ||
| } | ||
| /**value контрола selectBox */ | ||
| class SelectItem { | ||
| public value: string; | ||
| public id: number; | ||
|
|
||
| constructor(value: string = "", id: number = 0) { | ||
| this.value = value; | ||
| this.id = id; | ||
| } | ||
| } | ||
|
|
||
| /**Класс описывает SelectBox контрол */ | ||
| class SelectBox extends Control<SelectItem> { | ||
| private item: SelectItem; | ||
| public getValue(): SelectItem { | ||
| return this.item; | ||
| } | ||
| public setValue(val: SelectItem): void { | ||
| this.item = val; | ||
| } | ||
| } | ||
|
|
||
| class Container { | ||
| public instance: Control<any>; | ||
| public type: string; | ||
|
|
||
| constructor(instance: Control<any>, type: string) { | ||
| this.instance = instance; | ||
| this.type = type; | ||
| } | ||
| } | ||
|
|
||
| /**Фабрика которая отвечает за создание экземпляров контролов */ | ||
|
|
@@ -45,13 +67,24 @@ class FactoryControl { | |
| this._collection = []; | ||
| } | ||
|
|
||
| public register<?>(type: ?) { | ||
| public register(type: Function) { | ||
|
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. почему убрал использование generic-типа? |
||
| const typeStr = type.name; | ||
| if (!this.existType(typeStr)) { | ||
| this._collection.push(new Container(type(), typeStr)) | ||
| } | ||
| } | ||
|
|
||
| public getInstance<?>(type: ?): ? { | ||
| public getInstance(type: Function): Control<any> { | ||
| const typeStr = type.name; | ||
| const container = this._collection.find(x => x.type === typeStr); | ||
| if (container) { | ||
| return container.instance; | ||
| } | ||
| this.register(type); | ||
| return this._collection[this._collection.length - 1].instance; | ||
| } | ||
|
|
||
| private existType(type: string) { | ||
| private existType(type: string): boolean { | ||
| return this._collection.filter(g => g.type === type).length > 0; | ||
| } | ||
| } | ||
|
|
@@ -61,5 +94,5 @@ factory.register(SelectBox); | |
|
|
||
| const selectBoxInstance = factory.getInstance(SelectBox); | ||
|
|
||
| selectBoxInstance.setValue("sdfsdf") // компилятор TS не пропускает | ||
| //selectBoxInstance.setValue("sdfsdf") // компилятор TS не пропускает | ||
| selectBoxInstance.setValue(new SelectItem()) // компилятор TS пропускает | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -6,6 +6,8 @@ function getProperty<T, K extends keyof T>(obj: T, key: K): T[K] { | |
| return obj[key]; | ||
| } | ||
|
|
||
| const x = undefined; | ||
| const x = { | ||
| m: "", | ||
| }; | ||
|
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 3 бала |
||
|
|
||
| console.log(getProperty(x, "m")); | ||
| console.log(getProperty(x, "m")); | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -7,28 +7,55 @@ | |
| * Если поле не заполнено, то генерируется эксепшен. | ||
| */ | ||
|
|
||
| class ValueExample1 { | ||
| public value: string; | ||
| public id: number; | ||
| public constructor(value?: string, id?: number) { | ||
| this.value = value; | ||
| this.id = id; | ||
| } | ||
| } | ||
|
|
||
| class ValueExample2 { | ||
| public undefinedProp: undefined; | ||
| public booleanProp: boolean; | ||
| public constructor(undefinedProp?: undefined, booleanProp?: boolean) { | ||
| this.undefinedProp = undefinedProp; | ||
| this.booleanProp = booleanProp; | ||
| } | ||
| } | ||
|
|
||
| class Example { | ||
| @validate(ValueExample1, "id") | ||
| public propValueExample1: any; | ||
|
|
||
| @validate(ValueExample2, "booleanProp") | ||
| public propValueExample2: any; | ||
| } | ||
| function validate(type: object, propertyKey: string) { | ||
| return function validate(target: Object, propertyName: string){ | ||
| let descriptor: PropertyDescriptor = { | ||
| get() { | ||
| return type; | ||
| }, | ||
| set(newType) { | ||
| if (newType === type) { | ||
|
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Сюда приходит не тип а объект, для проверки типа недо было использовать generic тип устанавливаемый в момент инициализации объекта. |
||
| console.log('valid type'); | ||
| type = newType; | ||
| } else { | ||
| throw 'exception'; | ||
| } | ||
| if (!propertyName[propertyKey]) { | ||
| throw 'field is empty'; | ||
| } | ||
| return type; | ||
| } | ||
| } | ||
|
|
||
| Object.defineProperty(target, propertyName, { | ||
| get: descriptor.get, | ||
| set: descriptor.set | ||
| }); | ||
| } | ||
| } | ||
|
|
||
| class ValueExample1 { | ||
| public value: string; | ||
| public id: number; | ||
| public constructor(value?: string, id?: number) { | ||
| this.value = value; | ||
| this.id = id; | ||
| } | ||
| } | ||
|
|
||
| class ValueExample2 { | ||
| public undefinedProp: undefined; | ||
| public booleanProp: boolean; | ||
| public constructor(undefinedProp?: undefined, booleanProp?: boolean) { | ||
| this.undefinedProp = undefinedProp; | ||
| this.booleanProp = booleanProp; | ||
| } | ||
| } | ||
|
|
||
| class Example { | ||
| @validate(ValueExample1, "id") | ||
| public propValueExample1: any; | ||
|
|
||
| @validate(ValueExample2, "booleanProp") | ||
| public propValueExample2: any; | ||
| } | ||
|
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. прикладываю правильное решение } class ValueExample1 { class ValueExample2 { class Example { } let ex1 = new Example(); let objValExample = new ValueExample1(); ex1.propValueExample2 = false; |
||
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
это не реализация патерна декоратор
https://refactoring.guru/ru/design-patterns/decorator/typescript/example