<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>Forem: Jorge Garzón</title>
    <description>The latest articles on Forem by Jorge Garzón (@jgarzon97).</description>
    <link>https://forem.com/jgarzon97</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F767166%2F1e8ef5a8-9be4-46e3-9a69-086c704d81e9.png</url>
      <title>Forem: Jorge Garzón</title>
      <link>https://forem.com/jgarzon97</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://forem.com/feed/jgarzon97"/>
    <language>en</language>
    <item>
      <title>Campos dinámicos desde el frontend 🚀</title>
      <dc:creator>Jorge Garzón</dc:creator>
      <pubDate>Wed, 11 Sep 2024 17:35:20 +0000</pubDate>
      <link>https://forem.com/jgarzon97/campos-dinamicos-desde-el-frontend-9ka</link>
      <guid>https://forem.com/jgarzon97/campos-dinamicos-desde-el-frontend-9ka</guid>
      <description>&lt;p&gt;Hoy quiero compartir una solución sencilla y eficiente para crear campos dinámicos en formularios desde el frontend, utilizando &lt;strong&gt;Angular&lt;/strong&gt; y &lt;strong&gt;Node.js&lt;/strong&gt; con &lt;strong&gt;Express&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;🔑 &lt;strong&gt;Frontend:&lt;/strong&gt; El formulario es flexible y genera dinámicamente los campos iterando sobre un array, lo que permite que nuevos campos se integren sin tocar el código base.&lt;/p&gt;

&lt;p&gt;&lt;code&gt;&amp;lt;div *ngFor="let columna of columnas"&amp;gt;&lt;br&gt;
  &amp;lt;label&amp;gt;{{ columna }}&amp;lt;/label&amp;gt;&lt;br&gt;
  &amp;lt;input [(ngModel)]="persona[columna]" /&amp;gt;&lt;br&gt;
&amp;lt;/div&amp;gt;&lt;br&gt;
&lt;/code&gt;&lt;br&gt;
🛠️ &lt;strong&gt;Backend:&lt;/strong&gt; Cuando el usuario añade un nuevo campo, enviamos una solicitud POST a nuestro servidor, el cual ajusta la tabla de la base de datos en &lt;strong&gt;PostgreSQL&lt;/strong&gt; para incluir este nuevo campo de manera dinámica.&lt;/p&gt;

&lt;p&gt;&lt;code&gt;app.post('/personas/add-field', async (req, res) =&amp;gt; {&lt;br&gt;
  const { name, type } = req.body;&lt;br&gt;
  await pool.query(`ALTER TABLE persona ADD COLUMN ${name} ${obtenerTipoSQL(type)}`);&lt;br&gt;
  res.status(200).json({ message: 'Campo agregado exitosamente' });&lt;br&gt;
});&lt;br&gt;
&lt;/code&gt;&lt;br&gt;
Con esta solución, puedes escalar tu aplicación y adaptarte a los requerimientos cambiantes sin romper la estructura existente. 🌟&lt;/p&gt;

&lt;p&gt;Revisa el código acá;&lt;br&gt;
🔑 &lt;a href="https://bit.ly/4cZttTh" rel="noopener noreferrer"&gt;frontend&lt;/a&gt;&lt;br&gt;
🛠️ &lt;a href="https://bit.ly/4dVAu8J" rel="noopener noreferrer"&gt;backend&lt;/a&gt;&lt;/p&gt;

</description>
      <category>webdev</category>
      <category>postgres</category>
      <category>angular</category>
      <category>frontend</category>
    </item>
  </channel>
</rss>
