Mailchimp一个列表的多个订阅表单

时间:2014-12-24 15:17:53

标签: javascript html forms mailchimp

我在html页面中嵌入了三个不同的自定义mailchimp表单,指向一个列表(每个表单有两个相似的字段和一个不同的隐藏字段)。

一切都在排除一件事。响应消息(成功或错误)仅显示在第一个表单的div #mce-response中的同一页面中。在另外两个中,响应被加载并显示在另一个空白页面中。我希望在所有三种表单的同一页面中显示响应。 我不是Java Script用户,但经过一些研究后我发现这涉及外部脚本:

<script type='text/javascript' src='http://s3.amazonaws.com/downloads.mailchimp.com/js/mc-validate.js'></script>

通过mailchimp设置是否有任何解决方案,或者我们必须使用JavaScript文件?

我知道这个脚本仅对第一个表单有效。 知道怎么做吗? 感谢

3 个答案:

答案 0 :(得分:2)

显然使用iframe有效。

请参阅this文章/视频。

文章中的文字说明:

不是将代码从“注册表单嵌入代码”页面粘贴到您的站点中,而是将其粘贴到文本文档中(使用NotePad(PC)或TextEdit(Mac))并将其命名为“signup-form.html”或类似那。您可能希望将表单包装在div中以进行样式设置并添加一些内联样式。所以HTML文档看起来像这样:

<style type="text/css">
<!--
lots of CSS to make your form look pretty
//-->
</style>

<div id="sign-up">
at least 50 lines of code copied from MailChimp goes here
</div>

然后将此HTML文档(“signup-form.html”或其他任何名称)上传到服务器上的某个位置。

然后,为了在页面上嵌入代码(根据需要多次),您可以使用iframe调用HTML in:

<iframe src="http://your-site.com/mailchimp-form.html" frameborder="0" width="654" height="200">
<a href="http://link-to-form-on-mailchimp-site" target="_blank">Anchor text saying "click here to sign up" or something like that for people whose browsers can't read iframes</a>
</iframe>

答案 1 :(得分:2)

使用Ajax Chimp。这将(1)阻止您的订阅者远离您的页面,(2)允许多种形式。

https://github.com/scdoshi/jquery-ajaxchimp

答案 2 :(得分:0)

如果将每个mailchimp表单包装在..中,然后在页面上运行此脚本,它将重新分配非重点表单的所有ID,并重新绑定Submit事件。有点hacky,但是如果您处于绑定状态,它就可以工作。

// only execute if confirmed more than 1 mailchimp form on this page
$(document).ready(function() {

    if ( $('.mc-form-instance').length > 1 ) {

        $('.mc-field-group > .required').on('focus', function() {
            var thisField = $(this);

            // backup all mc-form ids on this page
            $('.mc-form-instance [id]').each(function() {
                var currentID = $(this).attr('id');
                if ( currentID.indexOf('-bak') == -1 ) {
                    $(this).attr('id', currentID + '-bak');
                }
            });
            // change the current form ids back to original state
            var thisForm = thisField.closest('.mc-form-instance');
            thisForm.find('[id]').each(function() {
                var currentID = $(this).attr('id');
                if ( currentID.indexOf('-bak') != -1 ) {
                    $(this).attr('id', currentID.replace('-bak', ''));
                }
            });
        });

        // re-bind
        $.getScript('//s3.amazonaws.com/downloads.mailchimp.com/js/mc-validate.js');
    }
});