使用基于js/ajax的表单实现Adwords转换跟踪

Implementing Adwords conversion tracking with js/ajax based form

本文关键字:实现 表单 Adwords 转换 跟踪 ajax js      更新时间:2023-09-26

我正试图弄清楚如何在我们购买的这个web模板中实现广告词转换跟踪。我对javascript或ajax不是很熟悉,但我认为它是如何工作的:当有人点击提交按钮时,一个文件(forms.js)会处理表单是否填写正确。如果填写正确,.js文件会将表单信息发送到mailhandler.php文件(该文件通过电子邮件通知我们表单提交),并向网站发回一些信息,告诉它显示成功提交的消息(位于隐藏标签中)。因此,没有一个真正的感谢页面可以包含任何转换跟踪代码。

我刚开始使用谷歌的标签管理器,所以我相信有一种方法可以在成功提交表单时使用它来触发转换代码,我自己就是想不出来。

有什么想法吗?

提前感谢!!

联系表格如下:http://www.unitedsupportllc.com/#/页面_邮件

forms.js代码在这里:

//forms
;(function($){
$.fn.forms=function(o){
    return this.each(function(){
        var th=$(this)
            ,_=th.data('forms')||{
                errorCl:'error',
                emptyCl:'empty',
                invalidCl:'invalid',
                notRequiredCl:'notRequired',
                successCl:'success',
                successShow:'4000',
                mailHandlerURL:'bat/MailHandler.php',
                ownerEmail:'myemail@address.com',
                stripHTML:true,
                smtpMailServer:'localhost',
                targets:'input,textarea',
                controls:'a[data-type=reset],a[data-type=submit]',
                validate:true,
                rx:{
                    ".name":{rx:/^[a-zA-Z'][a-zA-Z-' ]+[a-zA-        Z']?$/,target:'input'},
                    ".state":{rx:/^[a-zA-Z'][a-zA-Z-' ]+[a-zA-   Z']?$/,target:'input'},
                    ".email":{rx:/^(("['w-'s]+")|(['w-]+(?:'.  ['w-]+)*)|("['w-'s]+")(['w-]+(?:'.['w-]+)*))(@((?:['w-]+'.)*'w['w-]{0,66})'.([a-z]{2,6}(?:'.[a-z]{2})?)$)|(@'[?((25[0-5]'.|2[0-4][0-9]'.|1[0-9]{2}'.|[0-9]{1,2}'.))((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})'.){2}(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})']?$)/i,target:'input'},
                    ".phone":{rx:/^'+?('d['d'-'+'(') ]{5,}'d$)/,target:'input'},
                    ".fax":{rx:/^'+?('d['d'-'+'(') ]{5,}'d$)/,target:'input'},
                    ".message":{rx:/.{20}/,target:'textarea'}
                },
                preFu:function(){
                    _.labels.each(function(){
                        var label=$(this),
                            inp=$(_.targets,this),
                            defVal=inp.val(),
                            trueVal=(function(){
                                        var tmp=inp.is('input')?(tmp=label.html().match(/value=['"](.+?)['"].+/),!!tmp&&!!tmp[1]&&tmp[1]):inp.html()
                                        return defVal==''?defVal:tmp
                                    })()
                        trueVal!=defVal
                            &&inp.val(defVal=trueVal||defVal)
                        label.data({defVal:defVal})                             
                        inp
                            .bind('focus',function(){
                                inp.val()==defVal
                                    &&(inp.val(''),_.hideEmptyFu(label),label.removeClass(_.invalidCl))
                            })
                            .bind('blur',function(){
                                _.validateFu(label)
                                if(_.isEmpty(label))
                                    inp.val(defVal)
                                    ,_.hideErrorFu(label.removeClass(_.invalidCl))                                          
                            })
                            .bind('keyup',function(){
                                label.hasClass(_.invalidCl)
                                    &&_.validateFu(label)
                            })
                        label.find('.'+_.errorCl+',.'+_.emptyCl).css({display:'block'}).hide()
                    })
                    _.success=$('.'+_.successCl,_.form).hide()
                },
                isRequired:function(el){                            
                    return !el.hasClass(_.notRequiredCl)
                },
                isValid:function(el){                           
                    var ret=true
                    $.each(_.rx,function(k,d){
                        if(el.is(k))
                            ret=d.rx.test(el.find(d.target).val())                                      
                    })
                    return ret                          
                },
                isEmpty:function(el){
                    var tmp
                    return (tmp=el.find(_.targets).val())==''||tmp==el.data('defVal')
                },
                validateFu:function(el){                            
                    el.each(function(){
                        var th=$(this)
                            ,req=_.isRequired(th)
                            ,empty=_.isEmpty(th)
                            ,valid=_.isValid(th)                                
                        if(empty&&req)
                            _.showEmptyFu(th.addClass(_.invalidCl))
                        else
                            _.hideEmptyFu(th.removeClass(_.invalidCl))
                        if(!empty)
                            if(valid)
                                _.hideErrorFu(th.removeClass(_.invalidCl))
                            else
                                _.showErrorFu(th.addClass(_.invalidCl))                             
                    })
                },
                getValFromLabel:function(label){
                    var val=$('input,textarea',label).val()
                        ,defVal=label.data('defVal')                                
                    return label.length?val==defVal?'nope':val:'nope'
                }
                ,submitFu:function(){
                    _.validateFu(_.labels)                          
                    if(!_.form.has('.'+_.invalidCl).length)
                        $.ajax({
                            type: "POST",
                            url:_.mailHandlerURL,
                            data:{
                                name:_.getValFromLabel($('.name',_.form)),
                                email:_.getValFromLabel($('.email',_.form)),
                                phone:_.getValFromLabel($('.phone',_.form)),
                                fax:_.getValFromLabel($('.fax',_.form)),
                                state:_.getValFromLabel($('.state',_.form)),
                                message:_.getValFromLabel($('.message',_.form)),
                                owner_email:_.ownerEmail,
                                stripHTML:_.stripHTML
                            },
                            success: function(){
                                _.showFu()
                            }
                        })          
                },
                showFu:function(){
                    _.success.slideDown(function(){
                        setTimeout(function(){
                            _.success.slideUp()
                            _.form.trigger('reset')
                        },_.successShow)
                    })
                },
                controlsFu:function(){
                    $(_.controls,_.form).each(function(){
                        var th=$(this)
                        th
                            .bind('click',function(){
                                _.form.trigger(th.data('type'))
                                return false
                            })
                    })
                },
                showErrorFu:function(label){
                    label.find('.'+_.errorCl).slideDown()
                },
                hideErrorFu:function(label){
                    label.find('.'+_.errorCl).slideUp()
                },
                showEmptyFu:function(label){
                    label.find('.'+_.emptyCl).slideDown()
                    _.hideErrorFu(label)
                },
                hideEmptyFu:function(label){
                    label.find('.'+_.emptyCl).slideUp()
                },
                init:function(){
                    _.form=_.me                     
                    _.labels=$('label',_.form)
                    _.preFu()
                    _.controlsFu()
                    _.form
                        .bind('submit',function(){
                            if(_.validate)
                                _.submitFu()
                            else
                                _.form[0].submit()
                            return false
                        })
                        .bind('reset',function(){
                            _.labels.removeClass(_.invalidCl)                                   
                            _.labels.each(function(){
                                var th=$(this)
                                _.hideErrorFu(th)
                                _.hideEmptyFu(th)
                            })
                        })
                    _.form.trigger('reset')
                }
            }
        _.me||_.init(_.me=th.data({forms:_}))
        typeof o=='object'
            &&$.extend(_,o)
    })
}
})(jQuery)
$(window).load(function(){
$('#form1').forms({
    ownerEmail:'#'
})

最简单(或最不容易出错)的方法可能是使用GTM的dataLayer在表单提交时推送事件:

dataLayer.push({'event': 'form_submisssion'});

然后进入谷歌标签管理器:

  1. 定义一个新的规则捕获上述事件
  2. 创建一个新的Adwords Conversion Tracking标记,该标记在规则匹配时激发