使用基于js/ajax的表单实现Adwords转换跟踪
Implementing Adwords conversion tracking with js/ajax based form
我正试图弄清楚如何在我们购买的这个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'});
然后进入谷歌标签管理器:
- 定义一个新的规则捕获上述事件
- 创建一个新的
Adwords Conversion Tracking
标记,该标记在规则匹配时激发
相关文章:
- 如何在js中实现树结构类型的表单动态填充
- 如何通过JavaScript实现自动提交表单进行搜索
- 在联系人表单中实现jQueryAJAX
- html表单,它有文本和表,现在我想在一个简单的文本文件中保存和检索数据,如何实现它
- 表单提交前客户端地理编码的实现;不起作用
- 模拟隐藏表单提交&使用JavaScript重定向以实现安全支付
- 如何使用ajax和JQuery实现Dependent下拉zend框架1.12表单
- 如何在表单中实现回车键操作
- 如何在RoR嵌套表单中实现链式选择
- 如何实现自定义 Auth0 登录表单的服务器端代码
- 实现动态表单验证 Rails 的最佳方式
- 如何在 YII 中使用 ajaxvalidation 实现弹出式登录表单
- 提交多个表单并实现分页
- 尝试使用 php/ajax 实现表单但没有成功
- 我如何实现根据点击按钮提交此表单的 JavaScript
- 尝试实现 ng-repeate 和表单之间的双向绑定
- 提交表单后如何在URL中实现#
- 使用基于js/ajax的表单实现Adwords转换跟踪
- 在服务器端用AngularJS和Django REST实现一个表单验证插件
- 如何用Angular JS和Bootstrap实现表单验证