javascript - GoogleTagManager似乎不接受base64编码的图片

标签 javascript image base64 google-tag-manager

是我还是GoogleTagManager似乎不接受base64编码的图片? 以下面非常基本的代码和非常基本的图像为例。

我收到以下错误: - 类型:JavaScript 太长” - 描述 : “任意 HTML 标记中的 JavaScript 有太多连续的非空白字符(例如,数组文字 '[1,2,..]' 太长)。尝试在语句之间插入空格以允许编译(例如,更改 '[ 1,2,...]' 到 '[1, 2, ...]')。”

除了将js直接放入GTM之外,是否没有办法在GTM中实现这一点?

最好, J.

<script type="text/javascript">
        var myurl = "http://wwww.toto.com";
        var myimg = "";
        $("#beta-ad").empty();
        $('<div/>', { id: "1" }).insertBefore($("#beta-ad"));
        $("#1").append('<a href=" ' + myurl + ' " target="_blank"><img src="' + myimg + '" style="display:inline; width: auto;" ></img></a>')
</script>

最佳答案

我认为这是设计使然。但@Matus 提出的解决方法有效。

为了解决必须为很长的 Base 64 编码字符串生成 JS 的问题,我编写了一个实用函数,将字符串拆分为 150 个 block (GTM 接受),并生成 JS 连接代码。

然后,您可以将此代码放入 GTM 标记中,并引用 base64 变量。

function splitString(string, size, multiline) {
  var matchAllToken = (multiline == true) ? '[^]' : '.';
  var re = new RegExp(matchAllToken + '{1,' + size + '}', 'g');
  var responses = string.match(re);
  var value = "var base64='';";
  responses.forEach(response => {
    value += "base64+='" + response + "';";

  });
  return value;
}

var base64 = 'eyJ3aWRnZXRfc2.... etc';

var gtmString = splitString(base64, 150, true);

console.log(gtmString);

http://jsfiddle.net/azqpdwxg/2/

关于javascript - GoogleTagManager似乎不接受base64编码的图片,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44114884/

相关文章:

css - 代码点火器 : base_url() at CSS file doesn't work

CSS:列表样式图像的定位

javascript - 如何在 JavaScript 中对表情符号进行 base64 编码?

javascript - 如何将 node.js 模块/源合并到一个 .js 文件中,以在 Node 内执行

javascript - 如何在 Angular JS 中检索它定义的函数之外的 $scope 值

javascript - 在最新的 iOS 更新到 12.2 后,如何修复 iOS 主屏幕 Chrome 快捷方式中的 "whatsapp://"协议(protocol)点击中断?

c# - 将 Base64 字符串转换为位图或图像 Xamarin 或 Android

javascript - 如何使用 jquery 突出显示与数字匹配的所有列

java - Android - 在移动存储上保存位图图像而不压缩

java - 使用 HttpPost 发送文件后文件被损坏