【发布时间】:2019-09-24 01:28:15
【问题描述】:
如何在不使用 window.location.href 的情况下以 Angular 7 获取完整的当前 URL?
例如,假设我当前的 URL 是http://localhost:8080/p/drinks?q=cold&price=200
我怎样才能获得完整的 URL 而不仅仅是/p/drinks?q=cold&price=200?
我已尝试使用this.router.url,这仅提供/p/drinks?q=cold&price=200,而不是完整的主机名。
我不想使用window.location.href 的原因是它会导致ng-toolkit/universal 中的渲染出现问题
我尝试遵循这个似乎与我相同的问题并且也更新了的解决方案
How to get domain name for service in Angular2
这是我的代码
windowProvider.js
import { InjectionToken, FactoryProvider } from '@angular/core';
export const WINDOW = new InjectionToken<Window>('window');
const windowProvider: FactoryProvider = {
provide: WINDOW,
useFactory: () => window
};
export const WINDOW_PROVIDERS = [
windowProvider
];
在 app.module.ts
中@NgModule({
.......
providers:[
.......
windowProvider
]
})
在我需要的页面中:
import {WINDOW as WindowFactory} from '../../factory/windowProvider';
......
constructor(private router: Router, private helper: Helpers,
@Inject(WindowFactory) private windowFactory: any,
) {
console.warn('HELLO I M WINDOW FACTORY', this.windowFactory.location.hostname);
}
购买这个会在编译时出错
./src/app/factory/windowProvider.js 中的错误 5:20 模块解析失败: Unexpected token (5:20) 你可能需要一个合适的加载器来处理 这种文件类型。 |导出常量窗口 = 新 InjectionToken('窗口'); |
const windowProvider: FactoryProvider = { |提供:窗口,| useFactory: () => window ℹ 「wdm」: 编译失败。
谁能告诉我如何解决这个问题。谢谢,
我关注的更多链接:
【问题讨论】:
-
看看这里是否有帮助stackoverflow.com/a/47205502/1160794
-
@David,我检查了链接似乎可以工作,但我无法让它工作。我已经评论了你的答案,你可以看看。
标签: javascript angular angular7 angular-universal