What is Unbounce?
Unbounce is a well-known and well-regarded landing page creation tool designed to allow HTML novices to create impressive and impactful landing pages, while offering scope for more experienced coders to have a bit more fun.
In this post, I’m going to list some solutions to what I refer to as the “one form” problem of Unbounce, their strengths and weaknesses, and which I personally prefer.
What is the "one form" problem?
As with any system that tries to take complex processes and make them simple to implement, there’s a certain amount of nuance and flexibility that has to be sacrificed.
One limitation is that each landing page on Unbounce can only have one embedded form (there are a few community articles discussing the topic, for instance: 1, 2, 3). While there’s a definite risk of call-to-action fatigue if you bombard your visitors with forms, it’s a reasonable requirement to want to provide easy access to your form at more than one point.
For example, you could lead with a strong call to action and the form at the top of the page, then follow up further down the page when users have had time to absorb more information about your offering. A simple example of this is the below Teambit landing page, which was featured in Hubspot’s 16 of the Best Landing Page Design Examples You Need to See in 2017.
Potential solutions to the one-form issue
Now that we’ve established the problem, let’s run through some solutions, shall we?
Fortunately, there are a few possible ways to solve this problem, either using built-in Unbounce tools or by adding code through open HTML, CSS, and JavaScript inputs.
It’s worth bearing in mind that one solution is to not have the form on your page at all, and have your call-to-action buttons linking to other pages with forms. This is the approach Unbounce uses in the example below. While that’s a perfectly valid approach, I wouldn’t call it so much a solution to this problem as a completely different format, so I haven’t included it in the list below.
1. Scrolling anchor button
This is potentially the simplest solution, as it’s natively supported by Unbounce:
- Create a button further down the page where you would want your second form.
- Edit that button, in the “Click Action” section of the right-hand button settings panel, where you would normally put the URL you are linking to
- Add in the unique ID code for the box that holds your form (you can find that by editing the box and scrolling to the bottom of the right-hand panel to "Element Metadata")
Benefits
Quick and easy to implement, little direct JavaScript or HTML manipulation needed.
Drawbacks
There are far more seamless ways to achieve this from the user perspective. Even with smooth scrolling (see “bonus points” below), the experience can be a little jarring for users, particularly if they want to go back to check information elsewhere on a page.
Bonus points
Just adding that in as-is will mean a pretty jarring experience for users. When they click the button, the page will jump back to your form as though it’s loaded a new page. To help visitors understand what’s going on, add smooth scrolling through JavaScript. Unbounce has how-to information here.
Double bonus
The link anchors work by aligning the top of your screen with the top of the thing you’ve anchored. That can leave it looking like you’ve undershot a bit, because the form is almost falling off the screen. You can solve this simply by putting a tiny, one-pixel-wide box a little bit above the form, with no fill or border, positioning it how you want, and linking to the ID of that box instead, allowing a bit of breathing room above your form.
2. iFrames
Unbounce allows free <HTML> blocks, which you can use to embed a form from another service or even another Unbounce page that consists of only a form. You’ll need to drag the “Custom HTML” block from the left bar to where you want the form to be and paste in your iFrame code.
Benefits
This will allow for multiple forms, for each form to be positioned differently on the page, to function in a different way, and for entries to each form to be tagged differently (which will offer insight on the effectiveness of the page).
This solution will also allow you to make the most of functionality from other services, such as Wufoo (Unbounce has documented the process for that here).
Drawbacks
Having chosen Unbounce as a one-stop-shop for creating landing pages, breaking out of that to use external forms could be considered a step away from the original purpose. This also introduces complications in construction, because you can’t see how the form will look on the page in the editing mode. So your workflow for changes could look like:
- Change external form
- Review page and see styling issues
- Change layout in Unbounce editor
- Review page and see that the external form isn’t as readable
- Change external form
- Etc.
Bonus points
Unbounce can’t track conversions through an iFrame, so even if you use another Unbounce page as the form you draw in, you’re going to be breaking out of Unbounce’s native tracking. They have a script here you can use to fire external tracking hits to track page success more centrally so you get more of a feel for whether individual pages are performing well.
Double bonus
Even if you’re using an identical Unbounce page to pull through the same form functionality twice, tag the form completions differently to give you an idea of whether users are more likely to convert at the top of the page before they get distracted, or lower down when they have had time to absorb the benefits of your offering.
3. Sticky form (always there)
An option that will keep everything on the same page is a sticky form. You can use CSS styling to fix it in place on a screen rather than on a page, then when your visitor scrolls down, the form or CTA will travel with them — always within easy reach.
This simple CSS code will fix a form on the right-hand side of a page for screen widths over 800px (that being where Unbounce switches from Desktop to Mobile design, meaning the positioning needs to be different).
Each ID element below corresponds to a different box which I wanted to move together. You’ll need to change the “lp-pom-box-xxx” below to match the IDs of what you want to move down the page with the user (you can find those IDs in the “Element Metadata” section as described in the Scrolling Anchor Button solution above).
<style> @media (min-width: 800px) { #lp-pom-box-56{ position:fixed; left:50%; margin-left: 123px; top:25%; margin-top:-70px} #lp-pom-form-59{ position:fixed; left:50%; margin-left: 141px; top:25%; margin-top:60px} #lp-pom-box-54{ position:fixed; left:50%; margin-left: 123px; top:25%; margin-top:50px}} </style>
Benefits
This allows you to keep tracking within Unbounce. It cuts out a lot of the back and forth of building the form elsewhere and then trying to make that form, within an iFrame, act on your page the way you want it to.
Drawbacks
The problem with this is that users can quickly become blind to a CTA that travels with them, adding some kind of regular attention seeking effect is likely to just annoy them. The solution here is to have your call to action or form obscured during parts of the page, only to reappear at other, more appropriate times (as in the next section).
It can be difficult to see exactly where the form will appear because your CSS changes won’t take effect in the editor preview, but you will be able to see the impact when you save and preview the page.
4. Sticky form (appearing and disappearing)
The simplest way to achieve this is using z-index. In short, the z-index is a way of communicating layers through HTML, an image with a z-index of 2 will be interpreted as closer to the user than a box with a z-index of 1, so when viewing the page it’ll look like the image is in front of the box.
For this method, you’ll need some kind of opaque box in each section of your page. The box can be filled with a color, image, gradient — it doesn’t matter as long as it isn’t transparent. After you’ve put the boxes in place, make a note of their z-index, which you can find in the “Meta Data” section of the right-hand settings bar, the same place that the Element ID is shown.
Then use CSS to select the elements you’re moving down the page and set their z-index to a lower number. In the below lines I’ve selected two elements and set their z-index to 30, which means that they’ll be hidden behind the box above, which has a z-index of 31. Again, here you’ll want to replace the IDs that start #lp-pom-box-xxxx with the same IDs you used in the Sticky Form (Always There) solution above.
<style> #lp-pom-box-133{z-index: 30; } #lp-pom-box-135{z-index: 30; } </style>
When you're choosing the place where you want your form to be visible again, just remove any items that might obscure the form during that section. It’ll scroll into view.
Benefits
This will allow you to offer a full form for users to fill out, at different points on the page, without having to worry about it becoming wallpaper or whether you can marry up external conversions. Using only CSS will also mean that you don’t have to worry about users with JavaScript turned off (while the bonus points below rely on JavaScript, this will fall back gracefully if JavaScript is turned off).
Drawbacks
Unlike the iFrame method, this won’t allow you to use more than one form format. It also requires a bit more CSS knowledge (and the bonus points will require at least a bit of trial and error with JavaScript).
Bonus points
Use JavaScript to apply and remove CSS classes based on your scrolling position on the page. For example you can create CSS classes like these which make elements fade in and out of view.
CSS:
<style> @media (min-width: 800px) { /* make the opacity of an element 0 where it has this class */ .hide { opacity: 0; } /* instead of applying an effect immediately, apply it gradually over 0.2 seconds */ .transition { -webkit-transition: all 0.2s ease-in-out; -moz-transition: all 0.2s ease-in-out; -o-transition: all 0.2s ease-in-out; transition: all 0.2s ease-in-out; }} </style>
You could then use this JavaScript to apply the .hide class when user scrolls through certain points, and remove it when they get to the points where you want them to see the form. This can be used for finer-grained control of where the form appears, without having to just cover it up. As before, you’ll need to update the #lp-pom-box-xxx strings to match the IDs in your account.
JavaScript:
<script> // This script applies the “hide” class, which makes opacity zero, to certain elements when we scroll more than 100 pixels away from the top of the page. Effectively, if we scroll down the page these items will fade away. $(window).scroll(function() { if ($(window).scrollTop() > 100 ){ $('#lp-pom-box-54').addClass('hide'); $('#lp-pom-box-228').addClass('hide'); } // This section removes the hide class if we’re less than 500 pixels from the bottom of the page or scroll back up to be less than 100 from the top. This means that those elements will fade back into view when we’re near the bottom of the page or go back to the top. if ($(document).height() - ($(window).height() + $(window).scrollTop()) < 500 || $(window).scrollTop() < 100 ){ $('#lp-pom-box-54').removeClass('hide'); $('#lp-pom-box-228').removeClass('hide'); }} </script>
Double bonus
You could consider using JavaScript to selectively hide or show form fields at different points. That would allow you to show a longer form initially, for example, and a shorter form when it appears the second time, despite it actually being the same form each time.
For this, you’d just add to your .scroll JavaScript function above:
if ($(document).height() - ($(window).height() + $(window).scrollTop()) < 75){ // This part hides the “full name” part of the form, moves the submit button up and reduces the size of the box when we scroll down to less than 75 pixels away from the bottom of the page $('#container_full_name').addClass('hide'); $('#lp-pom-box-54').stop().animate({height: "200px"},200); $('.lp-pom-button-60-unmoved').animate({top: '-=75'}, 200); $('#lp-pom-button-60').removeClass('lp-pom-button-60-unmoved'); $('#lp-pom-button-60').addClass('lp-pom-button-60-moved');} else{ // This part adds the “full name” part back in to the form, moves the submit button back down and increases the size of the box if we scroll back up. $('#container_full_name').removeClass('hide'); $('#lp-pom-box-54').stop().animate({height: "300px"},200); $('.lp-pom-button-60-moved').animate({top: '+=75'}, 200); $('#lp-pom-button-60').removeClass('lp-pom-button-60-moved'); $('#lp-pom-button-60').addClass('lp-pom-button-60-unmoved');
Conclusion
In the table below I’ve pulled together a quick list of the different solutions and their strengths and weaknesses.
Solution |
Strengths |
Weaknesses |
---|---|---|
Scrolling anchor button |
Easy implementation, little coding needed |
Jarring user experience |
iFrame |
Multiple different forms |
Requires building the form elsewhere and introduces some styling and analytics complexity to workflow |
Sticky form (always there) |
Keeps and design tracking within one Unbounce project |
CTA fatigue, using up a lot of page space |
Sticky form (appearing and disappearing) |
The benefits of a sticky form, plus avoiding the CTA fatigue and large space requirement |
CSS knowledge required, can only use one form |
Personally, my favorite has been the Sticky Form (appearing and disappearing) option, to reduce the need to integrate external tools, but if I had to use multiple different forms I could definitely imagine using an iFrame.
Which is your favorite? Have I missed any cool solutions? Feel free to ping me in the comments.
Thanks for this post, Robin! I love that you took the time to breakdown how to manage forms on a landing page when there sometimes can be a use case for more than one. I'm Chelsea and I work at Unbounce. As you can imagine, we're big advocates for one form only for exactly the reason you mentioned – you don't want to cause someone form fatigue. Your landing page should have one job and multiple forms can be distracting, but things like lightboxes and sticky buttons are great ways to draw attention to that one goal you've set without creating multiple "things to do." :)
Additionally, for anyone who's got pages already and wants to see how they stack up in the industry, head on over to our Landing Page Analyzer (unbounce.com/landing-page-analyzer). It gives personalized recommendations for your page in just a few minutes so you can optimize it for the most conversions possible. Happy to answer any questions anyone else might have. :)
Great insight on how to overcome only having one-form with Unbounce, Robin. I am more of a fan of HubSpot personally, but HS is not always a good fit for every client, will definitely log this strategy with using Unbounce away for future reference. Gracias for sharing sir!
Happy to help!
Thank you so much for sharing these workarounds, always worried about how clunky it looked with the button linking to the one form. And never have the time to accurately investigate alternatives. Thanks to you, it's all here. Much obliged!
I've used Unbounce extensively in the past. It is a comprehensive tool for easily building, tracking and testing landing pages. I believe there is (or was) a limited free version, if I'm not mistaken.
I've come to dislike the manner in which Unbounce displays the forms, however. I personally find a long form (any longer than two fields, anyways) to be too mentally taxing for the typical visitor.
I prefer to offer a form that visually presents each field on an individual page with a smooth progression between pages, so as to lessen the burdensome feeling of completing the form. I don't believe Unbounce provides that option yet, although I may be wrong.
Lacking that alternative, I agree with your preference for using the Sticky Form (appearing and disappearing) option.
I have never used Unbounce either, but I'll look into it for sure. I guess I never liked the idea of landing pages as I have never sold a product. The sticky form would be my choice as long as it is done tastefully.
Thanks for the read! Something to think about.
Doesn't have to just be for selling things. Any time you're trying to get a conversion (newsletter signup, video views, ebooks, webinars, etc) you should think about using a landing page. Web pages are too noisy and distract a visitor from your conversion goals. But, a landing page keeps that visitors focused on converting by presenting all of the benefits in a concise manner and only offers the CTA button as a way to continue forward.
I never thought much about the scope in which I could use a landing page. I'll definitely look into how I can utilize it to help promote things in the future.
Good stuff Robin! We didn't know how to really utilize the Scrolling Anchor Button before (definitely seems easier than the Sticky Form disappearing tactic). Thanks for your analysis and bonus tips on this good sir!
I have never used Unbounce, but after this post I am going to give it a try.
I will tell you my experience.
Thanks Robin for sharing this post!
I'm surprised by the number of people who haven't heard of or stumbled upon landing page solutions before. It's the easiest way to improve quality score and maximize revenue from ads! :D
A great alternative to the cognitive load that is Unbounce is Instapage. It has a more intuitive landing page builder, with robust analytics (including heatmaps built into pages for optimization insights), integration partners with major CRMs, automation, and other marketing tools, plus custom code can be used to implement any of Robin's 1 form workaround ideas.
Have never been using Unbounce so far, but it seems to be a pretty great tool and simple to use, especially for newbies!
Sticky form (appearing and disappearing) seems the best solution.
Still, sticky form (always there) could be a good solution if used in an unobtrusive way. Social share buttons on Moz blog are good example. They use light colors for buttons and generous white space between text and buttons, so it doesn't afect readability. And when i use browser's zoom tool and increase font-size, at the moment when text gets too close to the buttons, those buttons disappear from the right side of the page and are placed at the top of the page under the title, and at the bottom of the post, above comment section. Very elegant solution.
I have never used Unbounce, but after this post I am going to give it a try.
Thanks,
Hi Robin,
Thanks for sharing such a great insight on overcoming the one form problem. The article is very helpful in creating an engaging landing page.
Once I tried to use "unbounce" and left it aside. I will try to give him another chance but already my first time he did not give me good results.
Thank you.
Hey Odenmc! If you ever have any questions about working with Unbounce, feel free to let me know! I'm happy to help out.
Very interesting. The truth is that I did not know this tool for landing page, maybe in my country it does not have as much fame or maybe it's me that did not know it. But I have seen that it is really useful for creating landing pages as support or section, for example to an online shop
Thank you very much Robin for sharing this post
Hola Jonathan,
I'm Pablo Penadés, and I work at Unbounce. I'm part of the international marketing team, helping Spanish speaking marketers to discover Unbounce and how it can help to get-things-done (and more conversions!!!). I'd love to connect and discuss about conversion marketing, tapas y vinos, or bad jokes.
Btw, we'll be in The Inbounder Conference next April 25-26th in Madrid. Wanna come with us? Oli, Unbounce's founder, is one of the speakers (and he's la bomba!).
Abrazo.
I say as estentor said
I have never used Unbounce but almost after this good post I am going to give it a try.
Thank svery much Robin for sharing this Nice post
I'd like to know how well unbounce forms perform from an seo perspective?
Hi, I wouldn't recommend Unbounce as an SEO solution, but it is good for paid landing pages!
Do you have any solid examples of bigger corporations using this in their campaigns?
Good question.
Hi there, I don't actually - one of the motivations for putting together this how-to was the fact that I couldn't see many examples of people using these solutions. If you find some I'd love to see them!
Thanks for the post Robin! I´ve never thought about this before, but is good to have your point of view, because it will be very useful for my new projects :-)
Thanks for this tool but this tool is paid. Can you please suggest me any free tool for making a awesome landing page for generating leads for my website.
Hi Deepak, you'd have to decide how much time you had to build them, and what is "awesome" for you. You could build incredible landing pages on WordPress for free but solutions that do all the heavy lifting for you tend to be paid. If you find something that fits the bill, do comment back, I'll be interested to hear.
Popup form can bad impact on SEO?
Hi there, often the purpose of these landing pages is to catch referrals from a medium other than SEO. I would focus main site pages on SEO ranking and keep these pages out of the index because in general they won't be set up to maximise SEO performance.
Thanks a lot, so you mean which page have popup, need to ignore this page from Google Index?
As long as you follow best practices from the CBA you will be fine. Unbounce also offers a number of triggering and targeting options to allow you to provide relevant messaging to the right audiences vs hitting everyone with a generic offer all the time. You can check out the guidelines from the Coalition for Better Ads.