Make a Marketo Form Submission in the background | Community
Skip to main content
Kenny_Elkington
New Participant
September 30, 2015

Make a Marketo Form Submission in the background

  • September 30, 2015
  • 65 replies
  • 35403 views

This post originally appears on the Marketo Developers Blog

When your organization has many different platforms for hosting web content and customer data it becomes fairly common to need parallel submissions from a form so that the resulting data can be gathered in separate platforms. There are several strategies to do this, but the best one is often the simplest: Using the Forms 2 API to submit a hidden Marketo form. This will work with any new Marketo Form, but ideally you should create an empty form for this, which has no fields:

Empty Form

This will ensure that the form doesn’t load any more data than necessary, since we don’t need to render anything. Now just grab the embed code from your form and add it to the body of your desired page, making a small modification. You embed code includes a form element like this:

<form id="mktoForm_1068"></form>

You’ll want to add ‘style=”display:none”‘ to the element so it is not visible, like this:

<form id="mktoForm_1068" style="display:none"></form>

Once the form is embedded and hidden, the code to submit the form is really quite simple:

var myForm = MktoForms2.allForms()[0]; 
myForm
.addHiddenFields({
     //These are the values which will be submitted to Marketo
     "Email":"test@example.com",
     "FirstName":"John",
     "LastName":"Doe" });
myForm
.submit();

Forms submitted this way will behave exactly like if the lead had filled out and submitted a visible form. Triggering the submission will vary between implementations since each one will have a different action to prompt it, but you can make it occur on basically any action. The important part is setting your fields and values correctly. Be sure to use the SOAP API name of your fields which you can find with Export Field Names to esnure correct submission of values.

65 replies

October 2, 2015

Hi Kenny, we tried the code pasted in the above post, and MktoForms2.allForms[0] should be (MktoForms2.allForms())[0]. Must have changed into a function at some point.

October 2, 2015

Hi Kenny, do you have a link to some api documentation so we can figure out how to call a function on completion of the marketo form submission? Or a code snippet would do.

October 1, 2015

Thanks Kenny. I probably need some help with that part of it.

Kenny_Elkington
New Participant
October 1, 2015

Exactly, Matt.  You'd likely use a callback on your form validation in the browser to submit the hidden Marketo form, then have your primary submission go through on completion of the Marketo submission.

October 1, 2015

Hi Kenny. Great post. So are you saying, if I had say, a .php landing page with a form which submits to a platform, I could also include this code and, when submitted, it would also write the fields I want, into a Marketo lead? Because that is what I need to do.