CursosEmpresasBlogLiveConfPrecios

Object

Clase 13 de 32 • Curso de TypeScript 3

Clase anteriorSiguiente clase

Contenido del curso

Introducción a TypeScript

  • 1
    El lenguaje de programación TypeScript

    El lenguaje de programación TypeScript

    08:43 min
  • 2
    Instalación de herramientas para TypeScript

    Instalación de herramientas para TypeScript

    05:47 min
  • 3

    Instalación de herramientas en Windows

    01:05 min
  • 4
    Navegación y refactorización

    Navegación y refactorización

    04:37 min

Entorno de Desarrollo

  • 5
    El compilador de TypeScript

    El compilador de TypeScript

    08:00 min
  • 6
    El archivo de configuración de TypeScript

    El archivo de configuración de TypeScript

    07:22 min
  • 7
    Mi primer proyecto TypeScript

    Mi primer proyecto TypeScript

    05:09 min

Tipos en TypeScript

  • 8
    Tipado en TypeScript

    Tipado en TypeScript

    01:37 min
  • 9
    Number, Boolean y String

    Number, Boolean y String

    14:09 min
  • 10
    Any

    Any

    08:28 min
  • 11
    Void y never

    Void y never

    15:58 min
  • 12
    null y undefined

    null y undefined

    11:03 min
  • 13
    Object

    Object

    Viendo ahora
  • 14
    Array

    Array

    09:44 min
  • 15
    Tupla

    Tupla

    11:25 min
  • 16
    Enum

    Enum

    10:59 min
  • 17
    Unión de Tipos, Alias y Tipos Literales

    Unión de Tipos, Alias y Tipos Literales

    11:58 min
  • 18
    Aserciones de tipo

    Aserciones de tipo

    11:26 min
  • 19
    Funciones en TypeScript

    Funciones en TypeScript

    14:19 min
  • 20
    Resumen

    Resumen

    06:54 min

Tipos Personalizados

  • 21
    Interfaces

    Interfaces

    10:18 min
  • 22
    Interfaces: propiedades opcionales

    Interfaces: propiedades opcionales

    10:57 min
  • 23
    Extensión de interfaces

    Extensión de interfaces

    10:54 min
  • 24
    Clases

    Clases

    14:02 min
  • 25
    Clases públicas y privadas

    Clases públicas y privadas

    15:10 min
  • 26
    Métodos Get y Set

    Métodos Get y Set

    08:46 min
  • 27
    Herencia de clases y propiedades estáticas

    Herencia de clases y propiedades estáticas

    17:41 min
  • 28
    Resumen

    Resumen

    13:24 min

Módulos

  • 29
    Principios de responsabilidad única

    Principios de responsabilidad única

    15:03 min
  • 30
    Resolviendo módulos

    Resolviendo módulos

    10:04 min
  • 31
    Webpack y agrupación de Módulos

    Webpack y agrupación de Módulos

    14:02 min

Cierre

  • 32
    Cierre

    Cierre

    00:57 min
Tomar examen

Escuelas

  • Desarrollo Web
    • Fundamentos del Desarrollo Web Profesional
    • Diseño y Desarrollo Frontend
    • Desarrollo Frontend con JavaScript
    • Desarrollo Frontend con Vue.js
    • Desarrollo Frontend con Angular
    • Desarrollo Frontend con React.js
    • Desarrollo Backend con Node.js
    • Desarrollo Backend con Python
    • Desarrollo Backend con Java
    • Desarrollo Backend con PHP
    • Desarrollo Backend con Ruby
    • Bases de Datos para Web
    • Seguridad Web & API
    • Testing Automatizado y QA para Web
    • Arquitecturas Web Modernas y Escalabilidad
    • DevOps y Cloud para Desarrolladores Web
  • English Academy
    • Inglés Básico A1
    • Inglés Básico A2
    • Inglés Intermedio B1
    • Inglés Intermedio Alto B2
    • Inglés Avanzado C1
    • Inglés para Propósitos Específicos
    • Inglés de Negocios
  • Marketing Digital
    • Fundamentos de Marketing Digital
    • Marketing de Contenidos y Redacción Persuasiva
    • SEO y Posicionamiento Web
    • Social Media Marketing y Community Management
    • Publicidad Digital y Paid Media
    • Analítica Digital y Optimización (CRO)
    • Estrategia de Marketing y Growth
    • Marketing de Marca y Comunicación Estratégica
    • Marketing para E-commerce
    • Marketing B2B
    • Inteligencia Artificial Aplicada al Marketing
    • Automatización del Marketing
    • Marca Personal y Marketing Freelance
    • Ventas y Experiencia del Cliente
    • Creación de Contenido para Redes Sociales
  • Inteligencia Artificial y Data Science
    • Fundamentos de Data Science y AI
    • Análisis y Visualización de Datos
    • Machine Learning y Deep Learning
    • Data Engineer
    • Inteligencia Artificial para la Productividad
    • Desarrollo de Aplicaciones con IA
    • AI Software Engineer
  • Ciberseguridad
    • Fundamentos de Ciberseguridad
    • Hacking Ético y Pentesting (Red Team)
    • Análisis de Malware e Ingeniería Forense
    • Seguridad Defensiva y Cumplimiento (Blue Team)
    • Ciberseguridad Estratégica
  • Liderazgo y Habilidades Blandas
    • Fundamentos de Habilidades Profesionales
    • Liderazgo y Gestión de Equipos
    • Comunicación Avanzada y Oratoria
    • Negociación y Resolución de Conflictos
    • Inteligencia Emocional y Autogestión
    • Productividad y Herramientas Digitales
    • Gestión de Proyectos y Metodologías Ágiles
    • Desarrollo de Carrera y Marca Personal
    • Diversidad, Inclusión y Entorno Laboral Saludable
    • Filosofía y Estrategia para Líderes
  • Diseño de Producto y UX
    • Fundamentos de Diseño UX/UI
    • Investigación de Usuarios (UX Research)
    • Arquitectura de Información y Usabilidad
    • Diseño de Interfaces y Prototipado (UI Design)
    • Sistemas de Diseño y DesignOps
    • Redacción UX (UX Writing)
    • Creatividad e Innovación en Diseño
    • Diseño Accesible e Inclusivo
    • Diseño Asistido por Inteligencia Artificial
    • Gestión de Producto y Liderazgo en Diseño
    • Diseño de Interacciones Emergentes (VUI/VR)
    • Desarrollo Web para Diseñadores
    • Diseño y Prototipado No-Code
  • Contenido Audiovisual
    • Fundamentos de Producción Audiovisual
    • Producción de Video para Plataformas Digitales
    • Producción de Audio y Podcast
    • Fotografía y Diseño Gráfico para Contenido Digital
    • Motion Graphics y Animación
    • Contenido Interactivo y Realidad Aumentada
    • Estrategia, Marketing y Monetización de Contenidos
  • Desarrollo Móvil
    • Fundamentos de Desarrollo Móvil
    • Desarrollo Nativo Android con Kotlin
    • Desarrollo Nativo iOS con Swift
    • Desarrollo Multiplataforma con React Native
    • Desarrollo Multiplataforma con Flutter
    • Arquitectura y Patrones de Diseño Móvil
    • Integración de APIs y Persistencia Móvil
    • Testing y Despliegue en Móvil
    • Diseño UX/UI para Móviles
  • Diseño Gráfico y Arte Digital
    • Fundamentos del Diseño Gráfico y Digital
    • Diseño de Identidad Visual y Branding
    • Ilustración Digital y Arte Conceptual
    • Diseño Editorial y de Empaques
    • Motion Graphics y Animación 3D
    • Diseño Gráfico Asistido por Inteligencia Artificial
    • Creatividad e Innovación en Diseño
  • Programación
    • Fundamentos de Programación e Ingeniería de Software
    • Herramientas de IA para el trabajo
    • Matemáticas para Programación
    • Programación con Python
    • Programación con JavaScript
    • Programación con TypeScript
    • Programación Orientada a Objetos con Java
    • Desarrollo con C# y .NET
    • Programación con PHP
    • Programación con Go y Rust
    • Programación Móvil con Swift y Kotlin
    • Programación con C y C++
    • Administración Básica de Servidores Linux
  • Negocios
    • Fundamentos de Negocios y Emprendimiento
    • Estrategia y Crecimiento Empresarial
    • Finanzas Personales y Corporativas
    • Inversión en Mercados Financieros
    • Ventas, CRM y Experiencia del Cliente
    • Operaciones, Logística y E-commerce
    • Gestión de Proyectos y Metodologías Ágiles
    • Aspectos Legales y Cumplimiento
    • Habilidades Directivas y Crecimiento Profesional
    • Diversidad e Inclusión en el Entorno Laboral
    • Herramientas Digitales y Automatización para Negocios
  • Blockchain y Web3
    • Fundamentos de Blockchain y Web3
    • Desarrollo de Smart Contracts y dApps
    • Finanzas Descentralizadas (DeFi)
    • NFTs y Economía de Creadores
    • Seguridad Blockchain
    • Ecosistemas Blockchain Alternativos (No-EVM)
    • Producto, Marketing y Legal en Web3
  • Recursos Humanos
    • Fundamentos y Cultura Organizacional en RRHH
    • Atracción y Selección de Talento
    • Cultura y Employee Experience
    • Gestión y Desarrollo de Talento
    • Desarrollo y Evaluación de Liderazgo
    • Diversidad, Equidad e Inclusión
    • AI y Automatización en Recursos Humanos
    • Tecnología y Automatización en RRHH
  • Finanzas e Inversiones
    • Fundamentos de Finanzas Personales y Corporativas
    • Análisis y Valoración Financiera
    • Inversión y Mercados de Capitales
    • Finanzas Descentralizadas (DeFi) y Criptoactivos
    • Finanzas y Estrategia para Startups
    • Inteligencia Artificial Aplicada a Finanzas
    • Domina Excel
    • Financial Analyst
    • Conseguir trabajo en Finanzas e Inversiones
  • Startups
    • Fundamentos y Validación de Ideas
    • Estrategia de Negocio y Product-Market Fit
    • Desarrollo de Producto y Operaciones Lean
    • Finanzas, Legal y Fundraising
    • Marketing, Ventas y Growth para Startups
    • Cultura, Talento y Liderazgo
    • Finanzas y Operaciones en Ecommerce
    • Startups Web3 y Blockchain
    • Startups con Impacto Social
    • Expansión y Ecosistema Startup
  • Cloud Computing y DevOps
    • Fundamentos de Cloud y DevOps
    • Administración de Servidores Linux
    • Contenerización y Orquestación
    • Infraestructura como Código (IaC) y CI/CD
    • Amazon Web Services
    • Microsoft Azure
    • Serverless y Observabilidad
    • Certificaciones Cloud (Preparación)
    • Plataforma Cloud GCP

Platzi y comunidad

  • Platzi Business
  • Live Classes
  • Lanzamientos
  • Executive Program
  • Trabaja con nosotros
  • Podcast

Recursos

  • Manual de Marca

Soporte

  • Preguntas Frecuentes
  • Contáctanos

Legal

  • Términos y Condiciones
  • Privacidad
  • Tyc promociones
Reconocimientos
Reconocimientos
Logo reconocimientoTop 40 Mejores EdTech del mundo · 2024
Logo reconocimientoPrimera Startup Latina admitida en YC · 2014
Logo reconocimientoPrimera Startup EdTech · 2018
Logo reconocimientoCEO Ganador Medalla por la Educación T4 & HP · 2024
Logo reconocimientoCEO Mejor Emprendedor del año · 2024
De LATAM conpara el mundo
YoutubeInstagramLinkedInTikTokFacebookX (Twitter)Threads
        Paula Kneeteman

        Paula Kneeteman

        student•
        hace 5 años

        Like si ves los videos de Luis en 1.5x

          Alfredo Pacheco

          Alfredo Pacheco

          student•
          hace 5 años

          1,75x

          Aris Jhovannys Perea

          Aris Jhovannys Perea

          student•
          hace 5 años

          2x

        Javi Felices

        Javi Felices

        student•
        hace 6 años

        Estaría bien que Luis comentara para qué usaría object.

          Edwin Alberto Equihua Ochoa

          Edwin Alberto Equihua Ochoa

          student•
          hace 5 años

          HAHAHAHAHA xD

          Juan David Merchán Torres

          Juan David Merchán Torres

          student•
          hace 4 años

          Hola 👋 No se usa en gran medida, se usa mas es por dentro de typescript. Los casos de usos aplicables a object seria no usar un null o undefinend y definir un union con object para el valor por default. Espero haberles aportado algo 🚀

        Diego Fernando Rojas Quintero

        Diego Fernando Rojas Quintero

        student•
        hace 5 años

        No tengo la más absoluta idea de como y que casos usar object.

        Se tenia que decir y se dijo.

          Omar Lopez

          Omar Lopez

          student•
          hace 5 años

          Esto es lo que dice la documentacion de typescript: Generally, you won’t need to use this. En pocas palabras, ignoren el tipo object

          Mauro Nava

          Mauro Nava

          student•
          hace 5 años

          No tiene un uso muy útil, lo suelo usar sólo para que los editores me recuerden que la variable es un objeto

        Henry Villavicencio

        Henry Villavicencio

        student•
        hace 5 años

        Se me ocurre que puede ser de utilidad cuando uno quiere evitar mutar una variable. En el ejemplo voy a guardar user en una variable auxiliar newUser, luego voy a actualizar el nombre del primer usuario y finalmente voy a mostrar sus resultados.

        caso 1) Object

        const user = { id: 1, name: 'Harry' } const newUser = user user.name = 'Henry'; console.log('user', user); // user { id: 1, name: 'Henry' } console.log('newUser', newUser); // newUser { id: 1, name: 'Henry' }

        caso 2): object

        let user: object; user = {} user = { id: 1, name: 'Harry' } const newUser = user // user.name = 'Henry' // Error user = {...user, name: 'Henry'} console.log('user', user); // user { id: 1, name: 'Henry' } console.log('newUser', newUser); // newUser { id: 1, name: 'Harry' }

        Como podemos observar debido a que en el caso 1 es posible acceder a la propiedad name se puede llegar a mutar la variable lo que puede causar errores, mientras que para el caso 2 debido a que no es posible acceder a las propiedades del objeto nos vemos forzados a buscar otra alternativa que causa que las variables no muten.

          Andrés Felipe Eslava Zuluaga

          Andrés Felipe Eslava Zuluaga

          student•
          hace 5 años

          Excelente ejemplo

          Platzi Team

          Platzi Team

          student•
          hace 5 años

          Excelente ejemplo compañero

        Edwin Ivan Ortiz Zelada

        Edwin Ivan Ortiz Zelada

        student•
        hace 5 años

        El profesor debería haber aclarado los usos de object de TS. No ha quedado claro de para que usar el tipo de dato TS. Ese era el tema del capitulo. no instanciar un Object de JS.

        Carlos Viteri

        Carlos Viteri

        student•
        hace 6 años

        Esta lectura les puede ayudar a comprender mejor la diferencia https://2ality.com/2020/01/typing-objects-typescript.html#object-vs.-object-in-typescript

        Boris Vargas Paucara

        Boris Vargas Paucara

        student•
        hace 6 años
        // ------ Tipo: object ------ // explicito let user: object; user = {}; // Object user = { id: 1, username: 'paparazzi', firstname: 'Pablo', isPro: true }; console.log('user', user); // console.log('user.username', user.username); // --> no se puede acceder al dato username /* * Object: instancia de la clase Object de JavaScript * object: tipo para valores no primitivos */ // ---- Object vs object (Clase JS vs tipo TS) ---- // considera como tipo instancia Object de JavaScript const myObj = { id: 1, username: 'paparazzi', firstname: 'Pablo', isPro: true }; const isInstance = myObj instanceof Object; // trueo o false console.log('isInstance : ', isInstance); // clase Object JavaScript console.log('myObj.username : ', myObj.username); // --> se puede acceder al dato username
          Luis Alejandro Vera Hernandez

          Luis Alejandro Vera Hernandez

          student•
          hace 5 años

          Hare uso de tu aporte. Muchas gracias

        Federico Walovnik

        Federico Walovnik

        student•
        hace 5 años
        • Object

          Es un tipo de dato no primitivo.

          Declarar a una variable con el tipo object no es lo mismo que crear un Object nativo de JS

          Si tenemos un objeto declarado con el object de TS no podremos acceder a sus atributos mientras que si lo hacemos regularmente como en vanilla JS si podremos hacerlo.

          Por lo tanto declarar una variable como object de TS nos puede llegar a servir para una situacion en la que no querramos que el objeto pueda mutar.

          Sintaxis:

          //Explicito let user: object = { id: 234, name: "Federico"} //Implicito //Este objeto sera creado como un objeto nativo de JS let user = { id: 234, name: "Federico"}
        Juan Esteban Galvis

        Juan Esteban Galvis

        student•
        hace 6 años

        Siento que la object de TypeScript solo la usaría para mostrar un Objeto que no tenga que editar ni acceder a sus atributos. De resto la gracia de un objeto es acceder a sus atributos.

          Alan Cordova

          Alan Cordova

          student•
          hace 6 años

          Tal cual, no le vi mucho sentido a usar object de typescript, o igual aun no veo el escenario ideal para usarlo.

          Andrés Felipe Eslava Zuluaga

          Andrés Felipe Eslava Zuluaga

          student•
          hace 5 años

          Piensalo dos veces... Si quieres manipular el objeto, en JS es totalmente mutable y accesible - Por el contrario en TS esto lo debes realizar de otra forma. Mucho mejor control

        Jose Daniel Barría Reyes

        Jose Daniel Barría Reyes

        student•
        hace 6 años

        Diferencias entre object y Object. Object: instancia de la clase Object de Javascript object: tipo para valores no primitivos. Con este tipo no se puede acceder a las propiedades del objeto.

        Valentin Rivetti

        Valentin Rivetti

        student•
        hace 5 años

        Muy mal, el profesor deberia responder su propia pregunta al final de la clase, no puede ser que se tome todo el tiempo del mundo para explicar algo tan basico como tipos de datos primitivos (Que sinceramente deberia darse por sabido en el curso) y no se tome ni 2 minutos en responder algo tan importante y confuso como el uso de este 'object' de typescript que no parece tener ninguna ventaja por sobre 'Object' de js. Por favor, no tengan miedo en comentar sus opiniones y en especial de puntuar este curso con las estrellas que merece.

        Cristian Blandon

        Cristian Blandon

        student•
        hace 5 años

        Siento que veníamos divinamente y en las últimas 3 clases no he entendido nada.

          Alex hernandez mitre

          Alex hernandez mitre

          student•
          hace 4 años

          x2, si he entendido pero no les veo utilidad.

        Daniel Caita

        Daniel Caita

        student•
        hace 5 años

        Object en JS viene siendo una clase cual se ha manejado toda la vida en POO, cuando hablamos de object en TS nos estamos refiriendo simplemente un tipo, como un string, o un number, que viene siendo algo más abstracto, por lo cual object en TS no hereda nada de un Object en JS. Si estoy mal me corrigen please jejeje

          Andrés Felipe Eslava Zuluaga

          Andrés Felipe Eslava Zuluaga

          student•
          hace 5 años

          Estás en lo correcto!

        Enrique Tecayehuatl

        Enrique Tecayehuatl

        student•
        hace 6 años

        Una alternativa para usar el tipado en un objeto similar es crear una interface: const user: IUser; interface IUser { name: string; age: number; }

        Jose Daniel Hernandez Quiceno

        Jose Daniel Hernandez Quiceno

        student•
        hace 6 años

        Para que lo tengan en cuenta... si te lo preguntas, en el minuto 6:52, el profesor solo cambio uno de los dos parametros que recibe el console.log, el segundo parametro paso de ser user.username a myObj.username pero se olvido de hacer el cambio en el primer parametro, ese console.log que realizo al final deberia haber quedado asi console.log( 'myObj.username', myObj.username )

          Jorge Cruz Perez

          Jorge Cruz Perez

          student•
          hace 5 años

          Cierto pero el primero es una cadena de texto, es decir no es un error sintactico, pero tienes todas la razon

        Luis Palomo

        Luis Palomo

        student•
        hace 4 años

        Yo probé usar instanceof en cada uno y ambos me daba "true". Entonces, TS al convertirlo en JS lo convierte en un objeto normal ne Js nuevamente. ¿O estoy equivocado?

          Diego Fernando Caviedes Camaho

          Diego Fernando Caviedes Camaho

          student•
          hace 4 años

          me pasa lo mismo y hay si no entendí jejeje

          Bramucci Candela

          Bramucci Candela

          student•
          hace 4 años

          Tengo la misma duda

        Iván Antonio Bustos Calderón

        Iván Antonio Bustos Calderón

        student•
        hace 5 años

        Es primera vez que veo dos veces un vídeo en Platzi. El profesor domina la materia claramente, pero no logra ser lo suficientemente claro para que yo domine el entendimiento de su explicación... Pienso que deberían agregar una clase adicional para ejemplificar de mejor manera el uso.

        Andres David Sanchez

        Andres David Sanchez

        student•
        hace 5 años

        la verdad no le encuentro mucho sentido a object Pues typescript se creo precisamente para tener control de las variables. Esta propiedad no permite acceder a las propiedades, sooooooo

        Alejandro Andrade Soriano

        Alejandro Andrade Soriano

        student•
        hace 5 años

        Se me ocurre, que se podría usar en casos en los que quieras asigna a un objeto la información de un usuario que sea secreto y que quisieras proteger el acceso a la información de el usuario para que no pueda ser accedida.

        Jorge Méndez Ortega

        Jorge Méndez Ortega

        student•
        hace 6 años

        le estoy dando una repasada al curso ya que realmente para usar POO en JS si es necesario usar TS, ya que el POO en JS es algo basico por lo que para usar los principios de solid creo que si necesito TS para entenderlos al 100 los comprendo JS pero no al 100

          César Palma

          César Palma

          student•
          hace 4 años

          este curso conversa bien con los cursos de POO en JS