TG Telegram Group & Channel
Frontend | Вопросы собесов | United States America (US)
Create: Update:

🤔 На что можно заменить интерфейсы в js?

В JavaScript нет встроенной поддержки интерфейсов, как в TypeScript, Java или C#. Однако, их можно заменить несколькими способами, в зависимости от задачи.

🟠Использование JSDoc (аннотации типов)
Можно описывать структуру объектов с помощью @typedef и @param, что помогает при автодополнении и статическом анализе кода.

/**
* @typedef {Object} User
* @property {string} name
* @property {number} age
*/

/**
* @param {User} user
*/
function printUser(user) {
console.log(`Имя: ${user.name}, Возраст: ${user.age}`);
}

const person = { name: "Alice", age: 30 };
printUser(person); // Работает!


🟠Использование классов (Abstract Class Pattern)
Можно создать абстрактный класс с методами-заглушками, которые нужно реализовать в потомках.
class Animal {
constructor(name) {
if (new.target === Animal) {
throw new Error("Нельзя создать экземпляр абстрактного класса!");
}
this.name = name;
}

makeSound() {
throw new Error("Метод makeSound() должен быть переопределён!");
}
}

class Dog extends Animal {
makeSound() {
return "Гав-гав!";
}
}

const dog = new Dog("Бобик");
console.log(dog.makeSound()); // "Гав-гав!"

// const animal = new Animal("Лев"); // Ошибка!


🟠Проверка структуры объекта (Duck Typing)
Можно просто проверять, есть ли нужные методы и свойства у объекта перед использованием.
function useDevice(device) {
if (typeof device.turnOn !== "function") {
throw new Error("Объект должен иметь метод turnOn()");
}
device.turnOn();
}

const phone = { turnOn: () => console.log("Телефон включен!") };
useDevice(phone); // "Телефон включен!"

const invalidDevice = { power: true };
// useDevice(invalidDevice); // Ошибка: "Объект должен иметь метод turnOn()"


🟠Использование TypeScript (лучший вариант)
TypeScript добавляет поддержку интерфейсов в JavaScript.
interface User {
name: string;
age: number;
}

function printUser(user: User) {
console.log(`Имя: ${user.name}, Возраст: ${user.age}`);
}

const person: User = { name: "Alice", age: 30 };
printUser(person); // Работает!


Ставь 👍 и забирай 📚 Базу знаний

🤔 На что можно заменить интерфейсы в js?

В JavaScript нет встроенной поддержки интерфейсов, как в TypeScript, Java или C#. Однако, их можно заменить несколькими способами, в зависимости от задачи.

🟠Использование JSDoc (аннотации типов)
Можно описывать структуру объектов с помощью @typedef и @param, что помогает при автодополнении и статическом анализе кода.
/**
* @typedef {Object} User
* @property {string} name
* @property {number} age
*/

/**
* @param {User} user
*/
function printUser(user) {
console.log(`Имя: ${user.name}, Возраст: ${user.age}`);
}

const person = { name: "Alice", age: 30 };
printUser(person); // Работает!


🟠Использование классов (Abstract Class Pattern)
Можно создать абстрактный класс с методами-заглушками, которые нужно реализовать в потомках.
class Animal {
constructor(name) {
if (new.target === Animal) {
throw new Error("Нельзя создать экземпляр абстрактного класса!");
}
this.name = name;
}

makeSound() {
throw new Error("Метод makeSound() должен быть переопределён!");
}
}

class Dog extends Animal {
makeSound() {
return "Гав-гав!";
}
}

const dog = new Dog("Бобик");
console.log(dog.makeSound()); // "Гав-гав!"

// const animal = new Animal("Лев"); // Ошибка!


🟠Проверка структуры объекта (Duck Typing)
Можно просто проверять, есть ли нужные методы и свойства у объекта перед использованием.
function useDevice(device) {
if (typeof device.turnOn !== "function") {
throw new Error("Объект должен иметь метод turnOn()");
}
device.turnOn();
}

const phone = { turnOn: () => console.log("Телефон включен!") };
useDevice(phone); // "Телефон включен!"

const invalidDevice = { power: true };
// useDevice(invalidDevice); // Ошибка: "Объект должен иметь метод turnOn()"


🟠Использование TypeScript (лучший вариант)
TypeScript добавляет поддержку интерфейсов в JavaScript.
interface User {
name: string;
age: number;
}

function printUser(user: User) {
console.log(`Имя: ${user.name}, Возраст: ${user.age}`);
}

const person: User = { name: "Alice", age: 30 };
printUser(person); // Работает!


Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM


>>Click here to continue<<

Frontend | Вопросы собесов




Share with your best friend
VIEW MORE

United States America Popular Telegram Group (US)