如何防止在表单提交中传递空白 UTM 值?

How can I prevent a blank UTM value from being passed in a form submission?

我在 Pardot 工作,如果它重要的话,但是有一些 javascript 可以将 GA utm 参数写入隐藏字段。

不幸的是,如果任何值是空白的,它将传递该空白值,并覆盖任何现有值。 重要的是我能够覆盖现有值,但前提是查询字符串中有数据。

是否可以改为写入默认值?因此,例如,提交一个没有 utm_source 的表单,然后我们写 Source="Organic",或类似的东西。

这是我的代码:

    <script type="text/javascript">
// Parse the URL
function getParameterByName(name) {
    name = name.replace(/[\[]/, "\[").replace(/[\]]/, "\]");
    var regex = new RegExp("[\?&]" + name + "=([^&#]*)"),
    results = regex.exec(location.search);
    return results === null ? "" : decodeURIComponent(results[1].replace(/\+/g, " "));
}
// Give the URL parameters variable names
var source = getParameterByName('utm_source');
var medium = getParameterByName('utm_medium');
var campaign = getParameterByName('utm_campaign');
var campaign = getParameterByName('utm_content');

// Put the variable names into the hidden fields in the form. selector should be "p.YOURFIELDNAME input"
document.querySelector("p.source input").value = source;
document.querySelector("p.utm_medium input").value = medium;
document.querySelector("p.utm_campaign input").value = campaign;
document.querySelector("p.utm_content input").value = content;



</script>

非常感谢您的见解!

由于您使值 "" if 为空,并且由于 javascript 中的 falsey,只需在 4 个值语句中的每一个之前放置一个 if 语句:

if (source) document.querySelector("p.source input").value = source;

在长格式中,您是说如果该值存在,则用该值填充元素。否则,什么都不做:

if (source) {
  document.querySelector("p.source input").value = source;
}