CursosEmpresasBlogLiveConfPrecios

Historial de Cambios en el Motor

Clase 4 de 5 • Taller de Secretos Ocultos de JavaScript: Protección de Clases y Objetos

Clase anteriorSiguiente clase

Contenido del curso

¡Salva al Capitán DC!
  • 1
    Programación Orientada a Objetos en JavaScript para Emergencias Espaciales

    Programación Orientada a Objetos en JavaScript para Emergencias Espaciales

    00:50
  • 2

    Recupera el Sistema de Comunicaciones

    00:01
  • 3

    Vulnerabilidades del Sistema de Navegación

    00:20
  • 4

    Historial de Cambios en el Motor

    00:20
  • 5
    Solución de Errores y Seguridad en Sistemas de Navegación Espacial

    Solución de Errores y Seguridad en Sistemas de Navegación Espacial

    00:37
    Juan Castro

    Juan Castro

    teacher•
    hace 3 años

    ¡Un reto más, Platzinauta! :muscle:

    El manejo de la memoria y la copia o comparación de objetos en JavaScript es un tema con varios niveles de complejidad.

    Si es tu primera vez enfrentándote a este tipo de problemas, te recomiendo estos materiales:

    • Cómo funciona la memoria en JS
    • Shallow copy en JS
    • JSON.parse y JSON.stringify
      Jesus Espinosa

      Jesus Espinosa

      student•
      hace 3 años

      Wow. Hicieron su hackathon interactivo y trajeron estudiantes al proceso, súper.

    Luis Paredes

    Luis Paredes

    student•
    hace 3 años

    listo mi solucion

    export class Motor { constructor(propulsionTo, historyInstance) { let status = "off" let history = historyInstance; this.getStatus = () => status; let setStatus = (newStatus) => { if (status != newStatus) { history.agragarEvento(propulsionTo, newStatus) status = newStatus; } }; this.turnOn = () => setStatus("on"); this.turnOff = () => setStatus("off"); this.getHistory = () => history.getFullState(); } } export class History { constructor() { let history = []; this.getFullState = () => history; this.agragarEvento = (direccion, estado) => history.push({"propulsionTo": direccion, "status": estado}) } }
    Yefri Enmanuel Encarnación Jiménez

    Yefri Enmanuel Encarnación Jiménez

    student•
    hace 3 años

    Excelente! Apoyo para que se sigan haciendo este tipo de clases: son entretenidas, pones en practica tus conocimientos y si te falta algo lo repasas o vas y lo aprendes de verdad excelente!

      Natalia Villegas

      Natalia Villegas

      teacher•
      hace 3 años

      Cuéntanos qué tipo de ejercicios te gustaría ver en la plataforma?

      luis carlos rojano vergara

      luis carlos rojano vergara

      student•
      hace 3 años

      ejercicios tipo hackathon, que obliguen a explorar los conceptos más avanzados del lenguaje.

    Jorge Méndez Ortega

    Jorge Méndez Ortega

    student•
    hace 3 años

    esto es muy divertido

    Andrés Schuster

    Andrés Schuster

    student•
    hace 3 años
    // Clase Motor export class Motor { // Constructor de la clase `Motor`. constructor(propulsionTo, history) { // Establece una propiedad llamada `propulsionTo` para el objeto `Motor`. this.propulsionTo = propulsionTo; // Establece una propiedad llamada `history` para el objeto `Motor`. this.history = history; // Establece una propiedad llamada `status` para el objeto `Motor`. this.status = "off"; } // Método que cambia el valor de la propiedad `status` del objeto `Motor` a "on" y agrega un objeto de cambio al historial. turnOn() { this.status = "on"; this.history.addChange(this.propulsionTo, this.status); } // Método que cambia el valor de la propiedad `status` del objeto `Motor` a "off" y agrega un objeto de cambio al historial. turnOff() { this.status = "off"; this.history.addChange(this.propulsionTo, this.status); } } // Clase History export class History { constructor() { // Si la instancia de la clase `History` no existe, crea una nueva y establece una propiedad llamada `history` como un array vacío. if (!History.instance) { History.instance = this; this.history = []; } // Devuelve la instancia existente de la clase `History`. return History.instance; } // Método que agrega un objeto de cambio al historial si el último objeto agregado tiene una propiedad diferente de `propulsionTo` o `status`. addChange(propulsionTo, status) { const lastChange = this.history[this.history.length - 1]; if (!lastChange || lastChange.propulsionTo !== propulsionTo || lastChange.status !== status) { this.history.push({ propulsionTo, status }); } } // Método que devuelve una copia del historial. getFullState() { return this.history.slice(); } }
      Brandon Lee Aguero Fernandez

      Brandon Lee Aguero Fernandez

      student•
      hace 2 años

      Gran solución

    David Ochoa

    David Ochoa

    student•
    hace 3 años

    Spoler . . . . . . . . . . . . . . . . . . . . . . .

    Lo hice sencillo, sin ningún tipo de shallow copy o utilizando stringify y parse

    export class Motor { constructor(propulsionTo, historyInstance) { let status = "off" let dir = propulsionTo let history = historyInstance; this.getStatus = () => status; let setStatus = (newStatus) => { status = newStatus; history.addRecord({propulsionTo:dir, status:status}) }; this.turnOn = () => setStatus("on"); this.turnOff = () => setStatus("off"); this.getHistory = () => history.getFullState(); } } export class History { constructor() { let history = []; this.getFullState = () => history; this.addRecord = (record) => { const lastRecord = history[history.length - 1] if (!lastRecord) { history.push(record) console.log("First added") return } const isSamePropulsion = lastRecord.propulsionTo == record.propulsionTo const isSameStatus = lastRecord.status == record.status if (isSamePropulsion && isSameStatus) { console.log("Not added") return } history.push(record) console.log("Added") } } }
    luis carlos rojano vergara

    luis carlos rojano vergara

    student•
    hace 3 años

    Propuesta de solución utilizando JSON.stringify y JSON.parse, para realizar un deep copy, en vez de referenciar a los objetos directamente. Esto permite guardar nuevos objetos en el historial, sin apuntar a los objetos originales.

    export class Motor { constructor(propulsionTo, historyInstance) { this.status = "off" this.propulsionTo = propulsionTo; let history = historyInstance; this.getStatus = () => this.status; let setStatus = (newStatus) => { history.addStatus(this, newStatus); this.status = newStatus; }; this.turnOn = () => setStatus("on"); this.turnOff = () => setStatus("off"); this.getHistory = () => history.getFullState(); } } export class History { constructor() { this.history = []; this.lastMotor = {} this.addStatus = (motor, status) => { if (Object.is(motor, this.lastMotor) && motor.status === status) { console.log("same as last motor") } else { motor.status = status const newMotor = JSON.parse(JSON.stringify(motor)); this.history.push(newMotor) this.lastMotor = motor; } } this.getFullState = () => this. History; } }
    CRISTIAN DARIO AGUDELO PORRAS

    CRISTIAN DARIO AGUDELO PORRAS

    student•
    hace 3 años

    Comparto mi solucion, es realmente satisfactorio lograrlo con tus propios conocimientos. . . . . . . . . . . . . . . . . . . .

    class Motor { constructor(propulsionTo, historyInstance) { let status = "" let history = historyInstance; this.getStatus = () => status; let setStatus = (newStatus) => { if(status !== newStatus){ status = newStatus; mensajeEstadoMotor(propulsionTo, newStatus); } }; this.turnOn = () => setStatus("on"); this.turnOff = () => setStatus("off"); this.getHistory = () => history.getFullState(); let setHistory = (mensaje) => { history.setFullState(mensaje); }; let mensajeEstadoMotor = (motorName, MotorStatus) => { const mensaje = { "propulsionTo": motorName, "status": MotorStatus, } setHistory(mensaje); }; } } class History { constructor() { let history = []; this.getFullState = () => history; this.setFullState = (mensaje) => { history.push(mensaje) } } }
    Jean Paul Mamani Coaquira

    Jean Paul Mamani Coaquira

    student•
    hace 3 años

    '

    " "" " " " "" " " " " " "

    export class Motor { constructor(propulsionTo, historyInstance) { let status = "off" let history = historyInstance; this.getStatus = () => status; let setStatus = (newStatus) => { status = newStatus history.addRecord(newStatus, propulsionTo) }; this.turnOn = () => setStatus("on"); this.turnOff = () => setStatus("off"); this.getHistory = () => history.getFullState(); } } export class History { constructor() { let history = []; this.getFullState = () => { return history }; this.addRecord = (newStatus, propulsionTo) => { let lastObj = history[history.length - 1] if (lastObj?.propulsionTo === propulsionTo && lastObj?.status === newStatus ) { return false } history.push({ "propulsionTo": propulsionTo, "status": newStatus }) } } }
    Andres Eduardo Maneiro Antunez

    Andres Eduardo Maneiro Antunez

    student•
    hace 3 años

    Spoiler mi Solucion . . . . . . . . . . . . . . . . . . . . . . . .

    export class Motor { constructor(propulsionTo, historyInstance) { let status = "off" let history = historyInstance; this.getStatus = () => status; let setStatus = (newStatus) => { status = newStatus; }; this.turnOn = () => { setStatus("on") this.setHistory() }; this.turnOff = () => { setStatus("off") this.setHistory() }; this.setHistory = () => { const lastHistory = history.getFullState() const payload = { propulsionTo: propulsionTo, status: this.getStatus() } const isEqual = JSON.stringify((lastHistory[lastHistory.length - 1])) === JSON.stringify(payload) if (!isEqual) { history.setHistory(payload) } } this.getHistory = () => history.getFullState(); } } export class History { constructor() { let history = []; this.getFullState = () => history; this.setHistory = (payload) => { history.push(payload) } } }
    Felipe Moreno

    Felipe Moreno

    student•
    hace 3 años

    Mi solución 👇 . . . . . . . . . . . . . .

    export class Motor { constructor(propulsionTo, historyInstance) { let status = "off"; let history = historyInstance; this.getStatus = () => status; let setStatus = (newStatus) => { status = newStatus; historyInstance.historyEvent = { propulsionTo, status } }; this.turnOn = () => setStatus("on"); this.turnOff = () => setStatus("off"); this.getHistory = () => history.getFullState(); } } export class History { constructor() { this.history = []; this.getFullState = () => this.history; } set historyEvent(event) { if (JSON.stringify(this.history.at(-1)) !== JSON.stringify(event)) { this.history.push(event); } } }
    Brandon Lee Aguero Fernandez

    Brandon Lee Aguero Fernandez

    student•
    hace 2 años

    Debo decir que tuve problemas con este ejercicio 😕, pero gracias a los aportes logre superarlo 😅.

    Harold Zurita Simon

    Harold Zurita Simon

    student•
    hace 2 años

    Solución 😄..

    . . . .

    export class Motor { constructor(propulsionTo, historyInstance) { let status = "off" let history = historyInstance; this.getStatus = () => status; let setStatus = (newStatus) => { status = newStatus; }; this.turnOn = () => { setStatus("on"); history.addToHistory(propulsionTo, status); }; this.turnOff = () => { setStatus("off"); history.addToHistory(propulsionTo, status); }; this.getHistory = () => history.getFullState(); } } export class History { constructor() { let history = []; this.getFullState = () => history; this.addToHistory = (propulsionTo, status) => { let lastRecord = history[history.length - 1]; let record = { "propulsionTo": propulsionTo, "status": status }; if ( JSON.stringify(record) !== JSON.stringify(lastRecord) ) { history.push(record); } }; } }
    Josman Jimenez

    Josman Jimenez

    student•
    hace 2 años
    export class Motor { constructor(propulsionTo, historyInstance) { let status = "off"; let history = historyInstance; this.getPropulsionTo = () => propulsionTo; this.getStatus = () => status; let setStatus = (newStatus) => { status = newStatus; }; this.turnOn = () => { setStatus("on") history.setFullState({ propulsionTo: this.getPropulsionTo(), status: this.getStatus() }) }; this.turnOff = () => { setStatus("off"); history.setFullState({ propulsionTo: this.getPropulsionTo(), status: this.getStatus() }) } ; this.getHistory = () => history.getFullState(); } } export class History { constructor() { let history = []; this.getFullState = () => history; this.setFullState = ({ propulsionTo, status }) => { if (history.length===0||history[history.length-1].propulsionTo!=propulsionTo|| history[history.length-1].status!=status) history.push({ propulsionTo, status }) } } } ```aca mi solucion.
    Daniel Carmona

    Daniel Carmona

    student•
    hace 2 años

    Uff muy buenos pero me hace falta aprender mucho!

    diego Marcos

    diego Marcos

    student•
    hace 2 años

    :) :) :) :) :) :) :) :) :) :) :) :) :) :) Lo realize con mi propia logica 😅, aunque despues de ver las demas resoluciones, la mia quedo muy grande y engorrosa.

    export class Motor { constructor(propulsionTo, historyInstance) { let status = "off"; let fullHistory = []; //validacion de history if (historyInstance instanceof History) { //obteniendo el historial completo fullHistory = historyInstance.getFullState(); } this.getStatus = () => status; function setStatus(newStatus) { //evaluando si el ultimo status es igual al nuevo if ( fullHistory[fullHistory.length - 1]?.propulsionTo !== propulsionTo || fullHistory[fullHistory.length - 1]?.status !== newStatus ) { historyInstance.setHistory({ propulsionTo: propulsionTo, status: newStatus, }); } status = newStatus; } this.turnOn = () => setStatus("on"); this.turnOff = () => setStatus("off"); this.getHistory = () => history.getFullState(); } } export class History { //trabaje con private fields #_history; constructor() { this.#_history = []; this.setHistory = (history) => { this.#_history.push(history); }; this.getFullState = () => this.#_history; } }
    Enrique Aguilera

    Enrique Aguilera

    student•
    hace 2 años

    . . . . . . . . . . . . . . . . . . . . . .

    .

    export class Motor { constructor(propulsionTo, historyInstance) { let status = "off" let history = historyInstance; this.getStatus = () => status; let setStatus = (newStatus) => { status = newStatus; historyInstance.add(propulsionTo, status) }; this.turnOn = () => setStatus("on"); this.turnOff = () => setStatus("off"); this.getHistory = () => history.getFullState(); } } export class History { constructor() { let history = []; this.getFullState = () => history; this.add = (propulsionTo, status) => { const lastElement = history[history.length - 1] if (lastElement && lastElement.propulsionTo === propulsionTo && lastElement.status === status) return history.push({ propulsionTo, status, }) } } }
    Mauricio Carrasco

    Mauricio Carrasco

    student•
    hace 2 años

    Mi solución agregando métodos y validaciones en ambas clases: . . . . . . . . .

    export class Motor { constructor(propulsionTo, historyInstance) { let propulsion = propulsionTo; let status = "off"; let history = historyInstance; this.getPropulsion = () => propulsion; this.getStatus = () => status; let setStatus = newStatus => { status = newStatus; }; this.turnOn = () => { if (this.getStatus() !== "on") { setStatus("on"); history.addRecord(this); } }; this.turnOff = () => { if (this.getStatus() !== "off") { setStatus("off"); history.addRecord(this); } }; this.getHistory = () => history.getFullState(); } } export class History { constructor() { let history = []; this.addRecord = motor => { history.push({ propulsionTo: motor.getPropulsion(), status: motor.getStatus(), }); }; this.getFullState = () => history; } }
    Frandel Corporan Rodríguez

    Frandel Corporan Rodríguez

    student•
    hace 2 años

    Ufff este se me lio mucho mas pero lo consegui, ahora a desenmascarar a ese impostor!!!

    export class Motor { constructor(propulsionTo, historyInstance) { let status = "off" let history = historyInstance this.getStatus = () => status; let setStatus = (newStatus) => { if (newStatus !== status) { status = newStatus; history.addStatus({propulsionTo,status}) } }; this.turnOn = () => setStatus("on"); this.turnOff = () => setStatus("off"); this.getHistory = () => history.getFullState(); } } export class History { constructor() { let history = []; this.getFullState = () => history; this.addStatus = (obj) => history.push(obj) } }
    Jorge Humberto Nemogá Pinzón

    Jorge Humberto Nemogá Pinzón

    student•
    hace 3 años

    Esta es mi solución usando el método structuredClone() en vez de JSON.stringify/parse

    También modifique las propiedades y métodos para usarlos como privados o públicos según corresponda.

    export class Motor { #STATUS_ON = "on"; #STATUS_OFF = "off"; #id; #status; #history; constructor(id, historyInstance) { this.#id = id; this.#status = this.#STATUS_OFF; this.#history = historyInstance; } getStatus() { return this.#status; } turnOn() { this.#setStatus({ status: this.#STATUS_ON }); this.#saveNewState(); } turnOff() { this.#setStatus({ status: this.#STATUS_OFF }); this.#saveNewState(); } #setStatus({ status }) { this.#status = status; } #saveNewState() { const status = this.getStatus(); const lastState = this.#history.getLastState({ propulsionTo: this.#id, }); if (lastState === undefined || lastState?.status !== status) { this.#history.recordLog({ status, propulsionTo: this.#id }); } // probamos modificar el último state por ser un objeto // if (lastState !== undefined) lastState.status = "ON_FAKE"; } } export class History { #history; constructor() { this.#history = []; } getFullState() { return structuredClone(this.#history); } recordLog({ status, propulsionTo }) { this.#history.push({ status, propulsionTo }); } getLastState({ propulsionTo }) { // structuredClone reeplazaría el JSON.stringify/parse return structuredClone( this.#history.findLast( (state) => state.propulsionTo === propulsionTo ) ); } }

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