首页 > 解决方案 > 如何将 document.referrer 与两种不同的模式一起使用?

问题描述

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

我的问题是它#parkModal在所有页面(而不是特定页面: 、 等)上触发website.com/parks/park1website.com/acitivies/park1因为它以 domain 开头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
     });
  });
}

标签: javascriptdebuggingmodal-dialogreferrer

解决方案


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

我看到很多代码重复。是否有必要让两个不同的窗口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 函数,然后在load事件处理程序中调用该函数。如果你有多个不同的事情发生在load.


推荐阅读