试图将Facebook像素添加到Heroku Haml网站



我正在尝试将Facebook像素添加到我们的Heroku Haml网站。Google Analytics(分析(正在通过_google_analytics.html.haml中的JavaScript在Home.html.haml文件中列出的同一布局文件夹中列出的JavaScript,以下是以下内容:

    !!!
%html
%head    
= javascript_include_tag "application", "data-turbolinks-track" => true
= csrf_meta_tags    
= render 'layouts/bold_chat'
= render 'layouts/google_analytics'
= render 'layouts/fb_pixel'

不确定我缺少什么,但是当网站以Google Analytics(分析(的方式加载时,Pixel不会加载。谢谢,开发人员离开了组织,我的管理员正在捡起这些碎片。哎哟!我能够将脚本发射,但该站点不会在Heroku中加载,我会收到负载错误。帮助

这是实际的JavaScript

<!-- Facebook Pixel Code -->
<script>
!function(f,b,e,v,n,t,s)
{if(f.fbq)return;n=f.fbq=function(){n.callMethod?
n.callMethod.apply(n,arguments):n.queue.push(arguments)};
if(!f._fbq)f._fbq=n;n.push=n;n.loaded=!0;n.version='2.0';
n.queue=[];t=b.createElement(e);t.async=!0;
t.src=v;s=b.getElementsByTagName(e)[0];
s.parentNode.insertBefore(t,s)}(window,document,'script',
'https://connect.facebook.net/en_US/fbevents.js');
fbq('init', '123123123123123'); 
fbq('track', 'PageView');
</script>
<noscript>
<img height="1" width="1"
src="https://www.facebook.com/tr?id=123123123123&ev=PageView
&noscript=1"/>
</noscript>
<!-- End Facebook Pixel Code -->

好吧,所以我试图根据另一篇文章将其转换为咖啡脚本。代码是

    !((f, b, e, v, n, t, s) ->
      if f.fbq
        return
      n =
      f.fbq = ->
        if n.callMethod then n.callMethod.apply(n, arguments) else 
        n.queue.push(arguments)
        return
  if !f._fbq
    f._fbq = n
  n.push = n
  n.loaded = !0
  n.version = '2.0'
  n.queue = []
  t = b.createElement(e)
  t.async = !0
  t.src = v
  s = b.getElementsByTagName(e)[0]
  s.parentNode.insertBefore t, s
  return
  )(window, document, 'script', 
   'https://connect.facebook.net/en_US/fbevents.js')
  fbq 'init', '252482198497323'
  fbq 'track', 'PageView'

现在,我在尝试部署进行测试时会收到错误
跑步:耙资产:预编译 耙子流产了! nomethoderror:未定义的方法` @'for [" fb_pixels"]:array

更新,问题是加载图像的部分。

<noscript>
<img height="1" width="1"
src="https://www.facebook.com/tr?id=123123123123&ev=PageView
&noscript=1"/>
</noscript>

一旦我从脚本中删除了此代码并将其加载到索引页面上,Pixel工作起来。

当用户在浏览器中禁用脚本或浏览器不支持脚本时,使用NoScript标签。理想情况下,您无需删除代码的这一部分。这是应该起作用的HAML代码。

:javascript
  !function(f,b,e,v,n,t,s)
  {if(f.fbq)return;n=f.fbq=function(){n.callMethod?
  n.callMethod.apply(n,arguments):n.queue.push(arguments)};
  if(!f._fbq)f._fbq=n;n.push=n;n.loaded=!0;n.version='2.0';
  n.queue=[];t=b.createElement(e);t.async=!0;
  t.src=v;s=b.getElementsByTagName(e)[0];
  s.parentNode.insertBefore(t,s)}(window,document,'script',
  'https://connect.facebook.net/en_US/fbevents.js');
  fbq('init', '123123123123'); 
  fbq('track', 'PageView');
%noscript  
  %img{:height => "1", :width => "1", :src => "https://www.facebook.com/tr?id=123123123123&ev=PageView&noscript=1"}

最新更新