CursosEmpresasBlogLiveConfPrecios

Proyecto: Mostrar elementos

Clase 20 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 min
  • 2
    Programación funcional: qué es

    Programación funcional: qué es

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

    Boilerplate: Base para el proyecto del curso

    02:16 min

Funciones

  • 4
    Funciones Algebraicas y Funciones de JavaScript

    Funciones Algebraicas y Funciones de JavaScript

    02:49 min
  • 5
    Qué son funciones puras

    Qué son funciones puras

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

    Proyecto: Obtener el valor de los inputs

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

    Objetos y Tipos de Memoria en JavaScript

    04:31 min
  • 8
    Copiar y modificar objetos en JavaScript

    Copiar y modificar objetos en JavaScript

    09:49 min
  • 9
    Utilizando inmutabilidad en nuestras funciones

    Utilizando inmutabilidad en nuestras funciones

    03:49 min
  • 10
    Proyecto: Validar inputs

    Proyecto: Validar inputs

    07:38 min

Estado compartido en funciones

  • 11
    Estado compartido o shared state

    Estado compartido o shared state

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

    Proyecto: Agregar elementos a la lista

    05:36 min

Composición de funciones, Closures y Currying

  • 13
    Funciones compuestas o Function Composition

    Funciones compuestas o Function Composition

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

    Completando las funciones para generar etiquetas HTML

    06:14 min
  • 15
    Closures en programación funcional

    Closures en programación funcional

    02:56 min
  • 16
    Currying

    Currying

    03:14 min
  • 17
    Proyecto: Construyendo filas y celdas

    Proyecto: Construyendo filas y celdas

    03:45 min

Higher Order Functions

  • 18
    Introducción a las Higher Order Functions

    Introducción a las Higher Order Functions

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

    Proyecto: Actualizando el total de calorías

    05:32 min
  • 20
    Proyecto: Mostrar elementos

    Proyecto: Mostrar elementos

    Viendo ahora
  • 21
    Proyecto: Eliminar elementos

    Proyecto: Eliminar elementos

    09:45 min

Bonus: Declarative Programming

  • 22
    Programación Declarativa

    Programación Declarativa

    06:30 min

Conclusiones

  • 23
    Conclusiones

    Conclusiones

    01:30 min
Tomar examen
    Julio J Yépez

    Julio J Yépez

    student•
    hace 7 años

    La función renderItems() redefinida sin jQuery, sería algo como:

    const renderItems = () => { document.querySelector('tbody').innerHTML = '' list.map(item => { const row = document.createElement('tr') row.innerHTML = tableRow([ item.description, item.calories, item.carbs, item.protein ]) document.querySelector('tbody').appendChild( row ) }) }

    IMO

      Gabriel De Andrade

      Gabriel De Andrade

      student•
      hace 7 años

      Yo por mi parte modifiqué el innerHTML De una vez en el elemento HTML quedando algo así

      const renderItems = () => { const listWrapper = document.querySelector('tbody') listWrapper.innerHTML = "" list.map(item => { listWrapper.innerHTML += tableRow([ item.description, item.calories, item.carbs, item.proteins ]) }) }
      Fernando Alejandro Yerena Ramos

      Fernando Alejandro Yerena Ramos

      student•
      hace 7 años

      @gabrielelpido, ¿Al colocar += no se repiten los elementos ya renderizados de la lista, en la tabla? 🤔

    Jorge Méndez Ortega

    Jorge Méndez Ortega

    student•
    hace 7 años

    Una variante de la función renderItems, para este caso no utilizamos jQuery y tampoco utilizo el createElement de JS ya que realmente es inecesario ya que la creacion de los tags ya existe dentro de las funciones.

    const renderItems = () => { // otra manera de poder obtener un elemento por el name TAG // solo que este metodo consigue un arreglo de elementos const $CONTAINER = document.getElementsByTagName("tbody")[0]; $CONTAINER.innerHTML = ""; const ROWS = LIST.map((item) => { const { calorias, description, carboidratos, proteinas, } = item; return tableRow([description, calorias, carboidratos, proteinas]); }); $CONTAINER.innerHTML = ROWS.join(""); };
      Diego Andres Cardenas Caro

      Diego Andres Cardenas Caro

      student•
      hace 7 años

      Genia. me gusto tu solucion sin usar jquery y aplicando destructuring. 👌

      Carlos Enrique Ramírez Flores

      Carlos Enrique Ramírez Flores

      student•
      hace 6 años

      Gracias!! yo use document.querySelector("tbody");

    Bryan Estiven Silva Mercado

    Bryan Estiven Silva Mercado

    student•
    hace 7 años

    obtengo el siguiente error

    main.js:150 Uncaught TypeError: undefined is not a function

    El error es en esta linea

    const tableCells = items => items.map(tableCell).join('')

    alguna idea ?

      Bryan Estiven Silva Mercado

      Bryan Estiven Silva Mercado

      student•
      hace 7 años

      tableCell tiene un estado de undefined

      Danelia Sanchez Sanchez

      Danelia Sanchez Sanchez

      student•
      hace 7 años

      Podría ser algún error de digitación, a mí me sucedió que en la función tag había omitido la palabra return.

    Fernando Quinteros Gutierrez

    Fernando Quinteros Gutierrez

    student•
    hace 5 años

    Codigo vanilla JS hasta el momento

    const compose = (...functions) => (data) => functions.reduceRight((value, func) => func(value), data); const attrsToString = (obj = {}) => Object.keys(obj) .map((key) => `${key}="${obj[key]}"`) .join(""); const tagAtrrs = ({ tag, attrs }) => (content = "") => `<${tag} ${attrs && attrsToString(attrs)}>${content}</${tag}>`; const tag = (t) => { if (typeof t === "string") { return tagAtrrs({ tag: t }); } else { return tagAtrrs(t); } }; const tableRowTag = tag("tr"); // const tableRow = (items) => tableRowTag(tableCells(items)); const tableRow = (items) => compose(tableRowTag, tableCells)(items); const tableCell = tag("td"); const tableCells = (items) => items.map(tableCell).join(""); let description = document.getElementById("description"); let calories = document.getElementById("calories"); let carbs = document.getElementById("carbs"); let protein = document.getElementById("protein"); let $inputs = document.querySelectorAll("input"); let $btnSubmit = document.getElementById("submit-button"); let list = []; $inputs.forEach((input) => { input.addEventListener("keypress", function () { this.classList.remove("is-invalid"); }); }); const validateInputs = () => { description.value ? "" : description.classList.add("is-invalid"); calories.value ? "" : calories.classList.add("is-invalid"); carbs.value ? "" : carbs.classList.add("is-invalid"); protein.value ? "" : protein.classList.add("is-invalid"); if (description.value && calories.value && carbs.value && protein.value) { add(); } }; const add = () => { const newItem = { description: description.value, calories: parseInt(calories.value), carbs: parseInt(carbs.value), protein: parseInt(protein.value), }; list.push(newItem); cleanInputs(); updateTotals(); renderItems(); }; const updateTotals = () => { let calories = 0, carbs = 0, protein = 0; list.map((item) => { calories += item.calories; carbs += item.carbs; protein += item.protein; }); document.getElementById("totalCalories").innerText = calories; document.getElementById("totalCarbs").innerText = carbs; document.getElementById("totalProtein").innerText = protein; }; const cleanInputs = () => { description.value = ""; calories.value = ""; carbs.value = ""; protein.value = ""; }; const renderItems = () => { document.querySelector("tbody").innerHTML = ""; list.map((item) => { const row = document.createElement("tr"); const { description, calories, carbs, protein } = item; row.innerHTML = tableRow([description, calories, carbs, protein]); document.querySelector("tbody").appendChild(row); }); }; $btnSubmit.addEventListener("click", validateInputs);
    Jorge Méndez Ortega

    Jorge Méndez Ortega

    student•
    hace 7 años

    Una manera un poco diferente de crear elementos de manera dinamica

    const createElement = Object.create({ config: null, customSettings: null, contetPanel: null }, { init: { get() { this.config = { tag: "div", id: `id_${Math.random().toString(36).substr(2)}`, label: "empty", }; Object.assign(this.config, this.customSettings); }, // get:function }, // init factory: { get() { if (this.contetPanel !== null) { const panel = document.createElement(this.config.tag); let source = ""; let config = ""; const ENTRIES = Object.entries(this.config); ENTRIES.forEach((item) => { const PROPERTY = item[0]; config = this.config[PROPERTY]; source = (PROPERTY === "infoText") ? `panel.innerHTML = '${config}';` : `panel.${PROPERTY} = '${config}';`; eval(source); }); if (this.config.label !== "" && this.config.label !== "empty") { const tagLabel = document.createElement("label"); tagLabel.innerHTML = this.config.label; this.contetPanel.appendChild(tagLabel); }// if (config.label != '' && config.label != 'empty') this.contetPanel.appendChild(panel); this.contetPanel = null; } }, // get:function() }, // factory create: { value(custom, selector = "") { this.customSettings = custom; this.contetPanel = (selector !== "") ? document.querySelector(selector) : document.body; this.init; this.factory; return this.config.id; }, // value }, // create });// createElement const CONFIG = { tag: "div", id: "demo", className: "style", } // ejemplo createElement.create(CONFIG, "body");
    Angelo Zambrano

    Angelo Zambrano

    student•
    hace 6 años

    Les comparto mi código en Vanilla JS:

    funcional-js.png

    View:

    funcional-jsview.png

    Eder Raúl Abarca Raviela

    Eder Raúl Abarca Raviela

    student•
    hace 3 años

    Mi versión de la función renderItems() usando reduce y JS vanilla:

    Nota: **dataList **es el array que el maestro nombró como list

    function renderItems() { tableContent.innerHTML = ''; let dataTable= dataList.reduce((acc, item)=> { acc = acc + tableRow([item.description, item.calories, item.carbs, item.protein]) +'\n' return acc; },''); // console.log(dataTable); tableContent.innerHTML= dataTable; }
    JOSE RANGEL

    JOSE RANGEL

    student•
    hace 3 años

    En la forma en como lo estoy realizando, simplemente recibo el objeto con la data que voy a agregar a la tabla. . Así está la función addItem()

    const addItem = (data) => { const tbody = document.querySelector('tbody'); const row = document.createElement('tr'); for(let prop in data){ row.innerHTML += tag('td')(data[prop]) } tbody.appendChild(row) }

    Saludos!

    Francisco Garcia [C6]

    Francisco Garcia [C6]

    student•
    hace 6 años

    Muy interesante.

    const renderItems = () => { $('tbody').empty() list.map(item => { $('tbody').append(tableRow([item.description, item.calories, item.carbs, item.protein])) }) }
    Carlos Eduardo Gomez García

    Carlos Eduardo Gomez García

    teacher•
    hace 5 años

    Que gracioso, a mi se me están imprimiendo los códigos de las funciones tal cual jajaja....

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