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
    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 4 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 5 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 5 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 4 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 5 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

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