0

如何URL Encoding避免navigate?目前,我正在导航 url,如下所示,它正在将 url 编码/%2F. 我想避免它,所以无论如何都要这样做吗?

this.router.navigate(['/comp', { type: this.Type }]);

4

1 回答 1

0

Angular2 默认使用 encodeURIComponent() 对 URL 中的 queryParams 进行编码,您可以通过编写自定义 URL 序列化程序并覆盖默认功能来避免它。

就我而言,我想避免使用 Angular2 来避免用 (%2) 替换逗号(,)。我将查询作为 lang=en-us,en-uk 传递,它被转换为 lang=en-us%2en-uk。

这是我如何解决的:

CustomUrlSerializer.ts

import {UrlSerializer, UrlTree, DefaultUrlSerializer} from '@angular/router';

export class CustomUrlSerializer implements UrlSerializer {
    parse(url: any): UrlTree {
        let dus = new DefaultUrlSerializer();
        return dus.parse(url);
    }

    serialize(tree: UrlTree): any {
        let dus = new DefaultUrlSerializer(),
            path = dus.serialize(tree);
        // use your regex to replace as per your requirement.
        return path.replace(/%2/g,',');
    }
}

将以下行添加到您的主 appModule.ts

import {UrlSerializer} from '@angular/router';
import {CustomUrlSerializer} from './CustomUrlSerializer';

@NgModule({
    providers: [{ provide: UrlSerializer, useClass: CustomUrlSerializer }]
})

这不会破坏您的默认功能并根据您的需要处理 URL。

于 2017-02-02T06:25:32.127 回答