Angular为不同的静态页面设置基础href
创始人
2024-10-29 22:30:49
0

要为不同的静态页面设置基础href,可以使用Angular的APP_INITIALIZER提供一个初始化函数来动态设置基础href。

首先,在app.module.ts文件中导入APP_INITIALIZER,并在providers数组中添加一个新的提供者:

import { NgModule, APP_INITIALIZER } from '@angular/core';

@NgModule({
  declarations: [
    // ...
  ],
  imports: [
    // ...
  ],
  providers: [
    {
      provide: APP_INITIALIZER,
      useFactory: initializeApp,
      multi: true,
      deps: []
    }
  ],
  bootstrap: [AppComponent]
})
export class AppModule { }

export function initializeApp() {
  return () => {
    const baseHref = determineBaseHref();
    document.querySelector('base').setAttribute('href', baseHref);
  };
}

function determineBaseHref(): string {
  // 根据不同的静态页面,返回相应的基础href
  const pageUrl = window.location.pathname;
  if (pageUrl.includes('page1')) {
    return '/page1/';
  } else if (pageUrl.includes('page2')) {
    return '/page2/';
  } else {
    return '/';
  }
}

在上面的代码中,通过使用APP_INITIALIZER提供的initializeApp函数来初始化应用程序。该函数会在应用程序启动之前运行,并在页面加载时动态设置基础href。

在determineBaseHref函数中,根据当前页面的URL来确定适当的基础href。在示例中,假设对于名为'page1'和'page2'的静态页面,基础href分别为'/page1/'和'/page2/'。其他页面的基础href被设置为默认的根路径'/'。

然后,通过使用document.querySelector('base')来获取页面中的元素,并使用setAttribute方法来设置基础href。

这样,在应用程序启动时,初始化函数会被调用,根据当前页面的URL来设置基础href。

相关内容

热门资讯

透视软件"cloud... 1、透视软件"cloudpoker怎么开挂"详细辅助2025教程(果然存在有挂)(UU poker、...
一分钟了解!hhpoker辅助... 一分钟了解!hhpoker辅助,竞技联盟透视,微扑克教程(有挂攻略)1、不需要AI权限,帮助你快速的...
透视挂透视"wepo... 透视挂透视"wepoker免费辅助器"详细辅助科技教程(本然是真的有挂);大神普及一款德州ai内幕,...
教程辅助!wepoker辅助是... 教程辅助!wepoker辅助是真的吗,wpk辅助,高科技教程(有挂技巧)1、点击下载安装,微扑克wp...
透视科技"智星菠萝有... 透视科技"智星菠萝有挂吗"详细辅助规律教程(起初真的是有挂);支持2-10人实时对战,虚拟庄家发牌,...
专业讨论!wepoker辅助透... 专业讨论!wepoker辅助透视,拱趴大菠萝万能挂图解,2025新版教程(有挂方法)1、玩家可以在拱...
透视好友"佛手在线大... 1、透视好友"佛手在线大菠萝技巧"详细辅助解密教程(一向真的有挂)。2、佛手在线大菠萝技巧透视辅助简...
玩家必备攻略!佛手在线大菠萝智... 玩家必备攻略!佛手在线大菠萝智能辅助器,佛手在线有挂吗,扑克教程(有挂神器)1、不需要AI权限,帮助...
透视黑科技"wpk安... 透视黑科技"wpk安卓下载辅助"详细辅助专业教程(切实存在有挂);支持多人共享记分板与复盘,通过邀请...
避坑细节!we-poker辅助... 避坑细节!we-poker辅助器,wepoker一直输的号能继续打吗,介绍教程(有挂技巧);大神普及...