繁体   English   中英

如何将 document.referrer 与两种不同的模式一起使用?

[英]How can I use document.referrer with two different modals?

我的网站上有两种不同的模式,一种是针对特定域的,另一种是针对所有具有域website.com的页面。 两种模式都以document.referrer为目标,并且每个模式都有不同的 id( #closureModal#parkModal )。

我的问题是#parkModal在所有页面(而不是特定页面: website.com/parks/park1website.com/acitivies/park1等)上触发,因为它以域website.com开头。

如何允许两种不同的模式以document.referrer为目标,而没有一个出现在它不应该出现的地方? 如何将 document.referrer 与两种不同的模式一起使用?

这是#closureModal的代码:

  const tsp = ["website.com"];
  const closureReferrer = document.referrer;
  const referrer_hostname = closureReferrer !== "" ? new URL(closureReferrer).hostname : "";

  if (tsp.includes(referrer_hostname)) {
    console.log("Don't Show Modal", closureReferrer);
  }  else {
    console.log("Show Modal", closureReferrer);
    $( window ).on('load', function() {
      console.log("closure modal firing");
      $('#closureModal .closure').modal({
        backdrop: 'static',
        keyboard: false,
        show: true
      });
    });

  }

#parkModal是类似的代码:

const domains = ["https://website.com/parks/park1", "https://website.com/parks/events/park1", "https://website.com/parks/events/park1", "https://website.com/parks/promotions/park1", "https://website.com/parks/go-green/park1", "https://website.com/parks/info/park1", "https://website.com/parks/activities/park1", "https://website.com/parks/events/park1/#/?park=park1"];
const parkReferrer = document.referrer;

if (domains.includes(parkReferrer)) {
  console.log("Don't Show Modal - from Cummins page", parkReferrer);
} else {
  console.log("Show Modal - From other Page", parkReferrer);
  $( window ).on('load', function() {
     console.log("park modal firing");
     $('#parkModal').modal({
     backdrop: 'static',
     keyboard: false,
     show: true
     });
  });
}

我没有立即看到这个问题,但我确实有一些建议可以帮助您更接近更好的代码和更容易诊断的东西。

我看到很多代码重复。 是否有必要有两个不同的 window onload事件,它们都查看引用者,然后决定显示哪个模式? 我的建议是在一个onload处理程序中完成所有操作,该处理程序只查看一次document.referrer ,然后确定要显示的模式(如果有的话)。

有点像:

$( window ).on('load', function() {
   console.log("park modal firing");

   // define your parkReferrers and closureReferrers here
   const referrer = document.referrer;

   const displayParkReferrerModal = parkReferrers.includes(referrer);
   const displayClosureModal = closureReferrers.includes(referrer);

   let modalToDisplay;
   if (displayParkReferrerModal) {
     modalToDisplay = '#parkModal';
   } else if (displayClosureModal) {
     modalToDisplay = '#closureModal .closure';
   }

   if (modalToDisplay) {
     console.log(modalToDisplay);
     $(modalToDisplay).modal({
       backdrop: 'static',
       keyboard: false,
       show: true    
     });
     return;
   }

   console.log('no matching modal to display');
   return;     
});

希望这会有所帮助。 您还可以将其抽象为一个 handleReferrerModal function,然后在load事件处理程序中调用它。 如果您在load上发生了多种不同的事情,那可能会更干净。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM