Crear un formulario de Mailchimp con React
Updated July 14, 2023
Also available in:
Aprende a crear un formulario de React para crear suscriptores en tu cuenta de Mailchimp.
1. Prepara tu proyecto
Instala la biblioteca de ayuda de React en tu proyecto:
npm install @formspree/react
Luego añade el FormspreeProvider a tu componente de aplicación de nivel superior. Por ejemplo, si estás usando Next.js, así podría verse tu archivo pages/_app.js:
import { FormspreeProvider } from '@formspree/react';
function App({ Component, pageProps }) {
return (
<FormspreeProvider project="{your-project-id}">
<Component {...pageProps} />
</FormspreeProvider>
);
}
export default App;
2. Configura tu formulario
En tu archivo formspree.json, añade un formulario de opt-in.
{
"forms": {
"optInForm": {
"name": "Opt-In Form",
"actions": [{
"app": "mailchimp",
"type": "addOrUpdateContact",
"audience": "8djs8fg8d",
"apiKey": "$MAILCHIMP_APIKEY"
}]
}
}
}
Luego, despliega tus cambios a Formspree:
formspree deploy -k <your-deploy-key>
Más información sobre las acciones de Mailchimp →
3. Construye tu formulario
Conecta tu componente de formulario usando el hook useForm:
import React from 'react';
import { useForm, ValidationError } from '@formspree/react';
function OptInForm() {
const [state, handleSubmit] = useForm("optInForm");
if (state.succeeded) {
return <p>Thanks for joining!</p>;
}
return (
<form onSubmit={handleSubmit}>
<label htmlFor="email">
Email Address
</label>
<input
id="email"
type="email"
name="email"
/>
<ValidationError
prefix="Email"
field="email"
errors={state.errors}
/>
<button type="submit" disabled={state.submitting}>
Sign Up
</button>
</form>
);
}
export default OptInForm;
Más información sobre el CLI de Formspree →
Más información sobre Formspree y React →