CursosEmpresasBlogLiveConfPrecios

Completando las funciones para generar etiquetas HTML

Clase 14 de 23 • Curso de Programación Funcional en JavaScript por Bedu

Clase anteriorSiguiente clase

Contenido del curso

Introducción al curso y conceptos base
  • 1
    Qué aprenderás sobre la programación funcional

    Qué aprenderás sobre la programación funcional

    01:57
  • 2
    Programación funcional: qué es

    Programación funcional: qué es

    00:15
  • 3
    Boilerplate: Base para el proyecto del curso

    Boilerplate: Base para el proyecto del curso

    02:16
Funciones
  • 4
    Funciones Algebraicas y Funciones de JavaScript

    Funciones Algebraicas y Funciones de JavaScript

    02:49
  • 5
    Qué son funciones puras

    Qué son funciones puras

    02:45
  • 6
    Proyecto: Obtener el valor de los inputs

    Proyecto: Obtener el valor de los inputs

    04:00
  • 7
    Objetos y Tipos de Memoria en JavaScript

    Objetos y Tipos de Memoria en JavaScript

    04:31
  • 8
    Copiar y modificar objetos en JavaScript

    Copiar y modificar objetos en JavaScript

    09:49
  • 9
    Utilizando inmutabilidad en nuestras funciones

    Utilizando inmutabilidad en nuestras funciones

    03:49
  • 10
    Proyecto: Validar inputs

    Proyecto: Validar inputs

    07:38
Estado compartido en funciones
  • 11
    Estado compartido o shared state

    Estado compartido o shared state

    06:24
  • 12
    Proyecto: Agregar elementos a la lista

    Proyecto: Agregar elementos a la lista

    05:36
Composición de funciones, Closures y Currying
  • 13
    Funciones compuestas o Function Composition

    Funciones compuestas o Function Composition

    09:34
  • 14
    Completando las funciones para generar etiquetas HTML

    Completando las funciones para generar etiquetas HTML

    06:14
  • 15
    Closures en programación funcional

    Closures en programación funcional

    02:56
  • 16
    Currying

    Currying

    03:14
  • 17
    Proyecto: Construyendo filas y celdas

    Proyecto: Construyendo filas y celdas

    03:45
Higher Order Functions
  • 18
    Introducción a las Higher Order Functions

    Introducción a las Higher Order Functions

    04:11
  • 19
    Proyecto: Actualizando el total de calorías

    Proyecto: Actualizando el total de calorías

    05:32
  • 20
    Proyecto: Mostrar elementos

    Proyecto: Mostrar elementos

    03:36
  • 21
    Proyecto: Eliminar elementos

    Proyecto: Eliminar elementos

    09:45
Bonus: Declarative Programming
  • 22
    Programación Declarativa

    Programación Declarativa

    06:30
Conclusiones
  • 23
    Conclusiones

    Conclusiones

    01:30
    Juan Castro

    Juan Castro

    teacher•
    hace 7 años

    Este es un micro-framework que nos ayuda a construir aplicaciones web utilizando Componentes, muy parecido a React y Vue:

    • Hyperapp is a JavaScript micro-framework for building web applications - Github
      Carlos Gómez Mont

      Carlos Gómez Mont

      student•
      hace 7 años

      Super aporte, gracias!!

      Mauricio Hernan Cabrera

      Mauricio Hernan Cabrera

      student•
      hace 7 años

      Esta genial eso!

    Waldo Araque

    Waldo Araque

    student•
    hace 6 años

    ¿seguros que este código es más fácil de mantener?

      GABRIELA VALLENILLA

      GABRIELA VALLENILLA

      student•
      hace 6 años

      probablemente no.

      Carlos Rafael Córdova Flores

      Carlos Rafael Córdova Flores

      student•
      hace 5 años

      pensé que era el único que pensaba eso :( está bien confuso.

    Zedovius .

    Zedovius .

    student•
    hace 4 años

    Muy interesante la solución y todo pero, afortunadamente ya tomé el Curso de Manejo de Ansiedad como para permitirme usar jQuery por voluntad propia, más aún teniendo React JS y demás. 😅 Quiéranse mucho!😂

    Jorge Méndez Ortega

    Jorge Méndez Ortega

    student•
    hace 7 años

    Siguiendo el taller y con un poco de curiosidad las funciones que estamos utilizando pueden quedar de la manera siguiente.

    // consiguiendo los atributes para las etiquetas HTML const attributesToString = (obj = {}) => { const ENTRIES = Object.entries(obj); const ATTRS = []; for (let i = 0; i < ENTRIES.length; i += 1) { const AUX = ENTRIES[i]; const ATTR = AUX[0]; const VALUE = AUX[1]; ATTRS.push(`${ATTR}="${VALUE}"`); } return ATTRS.join(""); }; // Creando etiquetas html con atributos const createTagAttr = obj => (content = "") => { const { tag, attr } = obj; return ` <${tag}${attr ? ` ${attributesToString(attr)}` : ""}> ${content} </${tag}>`; }; // Generando tag de maner dinamica const createTag = (tag) => { const TAG = (typeof tag === "string") ? createTagAttr({ tag }) : createTagAttr(tag); return TAG; };``` para poder invocar todo de la siguiente manera.

    createTag({tag:"h1", attr:{"class": "Success"}})("Galletas mmmm");

    espero pueda ser de utilidad par alguien.
    GABRIELA VALLENILLA

    GABRIELA VALLENILLA

    student•
    hace 6 años

    Es un error de principiantes verificar si un objeto tiene propiedades con un simple obj.attr ? '' : '' porque un objecto vacio es truthy

      Carlos Enrique Ramírez Flores

      Carlos Enrique Ramírez Flores

      student•
      hace 6 años

      si hay mucho que mejorar, comparte tu código con tu solucion!

      Manuel Rivera

      Manuel Rivera

      student•
      hace 6 años

      Bastante, ademas que no se esta llevando un orden.

    Alex hernandez mitre

    Alex hernandez mitre

    student•
    hace 4 años

    cada vez más confuso ...

    Ludwing Rivera Amador

    Ludwing Rivera Amador

    student•
    hace 5 años

    Tengo entendido que en la programación funcional no se hace uso de if. Soy nuevo en este paradigma

    Roberto Cortés Monroy

    Roberto Cortés Monroy

    student•
    hace 5 años

    ¿No sería más fácil solo mapear la lista? pregunta seria jajjaja.

    Luis González

    Luis González

    student•
    hace 5 años

    Les comparto una ligera optimización al código del profe.

    // Construccion del html tag con clase const tagAttr = obj => (content = '') => `<${obj.tag} ${obj.attrs && attrToString(obj.attrs)}> ${content} </${obj.tag}>` // Metodo que ejecuta la construccion del tag const tag = t => (typeof t === 'string') ? tagAttr({tag: t}) : tagAttr(t)
    David Leonardo Garzón piña

    David Leonardo Garzón piña

    student•
    hace 3 años

    La verdad me parece un codigo complejo, dificil de mantener, hay formas mas simples de hacer el mismo procedimiento ...

    alberto ayala rodriguez

    alberto ayala rodriguez

    student•
    hace 5 años

    Que fumada de clase again zD

    Alejandro Sebastian Dubon Estrada

    Alejandro Sebastian Dubon Estrada

    student•
    hace 5 años

    Un clousure recuerda el contexto en el que fue creado

    const generateHTMLTag = tag => content => `<${tag}>${content}</${tag}>` const h1 = generateHTMLTag('h1'); h1('bla bla bla'); //<h2>bla bla bla</h2>
    Alan Cabrera

    Alan Cabrera

    student•
    hace 3 años

    ¿Qué manera creen más conveniente de usar, usando funciones como en la clase o haciendo manipulación del DOM? ¿En qué contextos usaríamos cada una?

      David Colin

      David Colin

      teacher•
      hace 3 años

      Lo mejor es crear nodos y manipular el DOM, así lo hacen librerías como React 😉

    Carlos Eduardo Gomez García

    Carlos Eduardo Gomez García

    teacher•
    hace 5 años

    Hmmm, comprendo el punto, esto me recuerda mucho al concepto de High Order Functions, pero pues prácticamente hacer esto es muy similar a lo que vimos en el Curso de buenas prácticas de escritura de código, dividir en funciones

    Bryan Estiven Silva Mercado

    Bryan Estiven Silva Mercado

    student•
    hace 7 años

    Comprender el uso de las tres funciones me costo ver los vídeos un par de veces mas pero ahora quedo perfectamente entendido

    Francisco Garcia [C6]

    Francisco Garcia [C6]

    student•
    hace 5 años

    Muy chevere

    Manuel Rivera

    Manuel Rivera

    student•
    hace 6 años

    Creo que la validación quedaría mejor de la siguiente manera

    `<${obj.tag}${Object.keys(obj.attrs).length > 0 && ' '}${attrsToString(obj.attrs)}>${content}</${obj.tag}>`

    funciones en esta clase.

    // tagAttrs function tagAttrs (obj, content) { return ( `<${obj.tag}${Object.keys(obj.attrs).length > 0 && ' '}${attrsToString(obj.attrs)}>${content}</${obj.tag}>` ) } // create tag html function tag (t) { if (typeof t === 'string') return tagAttrs({tag: t}) return tagAttrs(t); }
    Byron Mesias Cueva Cabrera

    Byron Mesias Cueva Cabrera

    student•
    hace 5 años

    Yo le hice así:

    const tagAttrs = obj => (content = '') => ` <${obj.tag} ${obj.attrs? attrsToString(obj.attrs) : ''} > ${content} </${obj.tag}> ` const tag = t => { if(typeof t === 'string') return tagAttrs({tag: t}) return tagAttrs(t) }

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