问题描述

我使用angular2.0.0-beta.7。当组件在像”/path?query=value1″这样的路径上加载时,它被重定向到”/path”。为什么删除了GET参数?如何保留参数?

路由器出现错误。如果我有一条主路线

@RouteConfig([
{
path: '/todos/...',
name: 'TodoMain',
component: TodoMainComponent
}
])

和我的孩子路线一样

@RouteConfig([
{ path: '/', component: TodoListComponent, name: 'TodoList', useAsDefault:true },
{ path: '/:id', component: TodoDetailComponent, name:'TodoDetail' }
])

我不能在TodoListComponent中获取参数。

我可以得到矩阵

params("/my/path;param1=value1;param2=value2")

但我想要经典

query params("/my/path?param1=value1&param2=value2")

最佳解决方案

角2.0最终解决方案。看来RouteParams已被弃用。改为:

import {Router, ActivatedRoute, Params} from '@angular/router';
import {OnInit, OnDestroy, Component} from '@angular/core'; @Component({...})
export class MyComponent implements OnInit, OnDestroy { constructor(private activatedRoute: ActivatedRoute) {} ngOnInit() {
// subscribe to router event
this.activatedRoute.params.subscribe((params: Params) => {
let userId = params['userId'];
console.log(userId);
});
} }

如果要获取查询参数,请将this.activatedRoute.params替换为this.activatedRoute.queryParams

关于不支持的说明

@Reto和@ codef0rmer非常正确地指出,根据官方文档,unsubscribe()内部的组件onDestroy()方法在这种情况下是不必要的。这已从我的代码示例中删除。 (请参阅我需要取消订阅this教程的部分)

次佳解决方案

即使这个问题指定版本beta 7,这个问题也是谷歌搜索结果的最佳搜索结果。为此,这里是最新的路由器的答案(目前在alpha.7)。

读取参数的方式发生了巨大变化。首先你需要在你的构造函数中注入一个叫做Router的依赖关系,比如:

constructor(private router: Router) { }

之后,我们可以在ngOnInit方法上订阅查询参数(构造函数也可以,但ngOnInit应该用于可测试性)

this.router
.routerState
.queryParams
.subscribe(params => {
this.selectedId = +params['id'];
});

在本例中,我们从URL读取查询参数,如example.com?id=41

还有一些事情要注意:

  1. 访问params的属性,如params['id']总是返回一个字符串,可以通过+前缀将其转换为数字。

  2. 查询参数被observable提取的原因是它允许re-using是相同的组件实例,而不是加载一个新的实例。每次查询参数更改时,都会导致我们订阅的新事件,因此我们可以对相应的更改做出反应。

第三种解决方案

我非常喜欢@史蒂夫·保罗的回答,但我们可以做同样的事情,无需额外的订阅/取消订阅电话。

import { ActivatedRoute } from '@angular/router';
constructor(private activatedRoute: ActivatedRoute) {
let params: any = this.activatedRoute.snapshot.params;
console.log(params.id);
// or shortcut Type Casting
// (<any> this.activatedRoute.snapshot.params).id
}

第四种方案

当一个这样的URL这样的http://stackoverflow.com?param1=value

您可以通过以下代码获取param1:

import { Component, OnInit } from '@angular/core';
import { Router, ActivatedRoute, Params } from '@angular/router'; @Component({
selector: '',
templateUrl: './abc.html',
styleUrls: ['./abc.less']
})
export class AbcComponent implements OnInit {
constructor(private route: ActivatedRoute) { } ngOnInit() {
// get param
let param1 = this.route.snapshot.queryParams["param1"];
}
}

第五种方案

首先,我发现使用Angular2的是具有查询字符串的url将是/path;query=value1

要使用您使用的组件访问它是这样的,但现在遵循代码块:

    constructor(params: RouteParams){
var val = params.get("query");
}

至于为什么在加载组件时会被删除,这不是默认行为。我特别检查了一个干净的测试项目,没有被重定向或更改。它是默认路由还是其他特殊的路由?

请阅读https://angular.io/docs/ts/latest/guide/router.html#!#query-parameters中Angular2教程中的查询字符串和参数的路由

第六种方案

您可以使用ActivatedRoute在URL中传递查询参数,如下所示:

url: – http:/domain.com?test = abc

import { Component } from '@angular/core';
import { ActivatedRoute } from '@angular/router'; @Component({
selector: 'my-home'
})
export class HomeComponent { constructor(private sharedServices : SharedService,private route: ActivatedRoute) {
route.queryParams.subscribe(
data => console.log('queryParams', data['test']));
} }

第七种方案

嗨,你可以使用URLSearchParams,你可以阅读更多关于它的here

进口:

import {URLSearchParams} from "@angular/http";

功能:

getParam(){
let params = new URLSearchParams(window.location.search);
let someParam = params.get('someParam');
return someParam;
}

注意:它不受所有平台的支持,似乎在”EXPERIMENTAL”状态由角度文档

阅读原文

angular2 学习资料

How to Build Nested Model-driven Forms in Angular 2

如何从angular2中的url获取查询参数?的更多相关文章

  1. Structs2 中拦截器获取请求参数

    前言 环境:window 10,JDK 1.7,Tomcat 7 测试代码 package com.szxy.interceptor; import java.util.Map; import jav ...

  2. MVC中使用UpdateModel获取接口参数

    废话少说,直接上代码: 模型类定义: public class RequestModel { public string Name { get; set; } public float Age { g ...

  3. Thinkphp中路由Url获取的使用方法

    Thinkphp是一个体系较为完整的框架,很多地方比国外的框架功能都全,唯一不喜之处是性能,和传说中的.NET有点像. Thinkphp提供较全url处理体系,通过同一规则实现Url的路由和Url生成 ...

  4. Objective-C中把URL请求的参数转换为字典

    上一篇博客中是把URL转换为字典,那么我们如何把URL请求中的参数封装成字典,然后再封装成数组呢?对OC中字符串操作熟练的小伙伴们应该觉得这是一个a+b的问题,没错把URL中的参数转换为字典主要是对字 ...

  5. 将url的查询参数解析成字典对象

    1, 这个题目不约而同的出现在了多家公司的面试题中,当然也是因为太过于典型,解决方案无非就是拆字符或者用正则匹配来解决,我个人强烈建议用正则匹配,因为url允许用户随意输入,如果用拆字符的方式,有任何 ...

  6. android中使用DisplayMetrics获取屏幕参数

    --关于Density int android.graphics.Bitmap.getDensity(),返回bitmap-density(密度).默认的density就是当前display-dens ...

  7. angular中通过$location获取路径(参数)的写法

    以下获取与修改的 URL 以  ( http://172.16.0.88:8100/#/homePage?id=10&a=100  ) 为例 [一]获取 (不修改URL) //1.获取当前完整 ...

  8. laravel 中的 toSql 获取带参数的 sql 语句

    默认情况下,toSql 获取到的 sql 里面的参数使用 "?" 代替的,如下: DB::table('user')->where('id', 1)->toSql(); ...

  9. gin的url查询参数解析

    gin作为go语言最知名的网络库,在这里我简要介绍一下url的查询参数解析.主要是这里面存在一些需要注意的地方.这里,直接给出代码,和运行结果,在必要的地方进行分析. 代码1: type Struct ...

随机推荐

  1. 转 linux Crontab 使用

    cron用法说明 cron的用法老是记不住,索性写下来备忘.下文内容大部分是根据<Cron Help Guide>翻译而来,有些部分是自己加上的. 全文如下: cron来源于希腊单词chr ...

  2. windows7下安装apache+PHP5.3

    Apache+PHP 安装与配置 最近在学习PHP,所以就在windows7下安装了PHP的开发环境.之所以没有选择集成的软件,如WAMP.AppServ等套件,是为了单独安装这些软件,有助于更加深入 ...

  3. public static List SmaDataManager.getThreads(Context context)

    public static List<TxrjThreads> getThreads(Context context) 解析获取Threads列表之要点: 1. 得到带有fail信息的th ...

  4. web安全之渗透测试

    本次渗透测试使用工具列表如下: 漏洞扫描器 (主机/Web) 绿盟RAS漏洞扫描器 商用 端口扫描器 NMAP 开源 网络抓包 Fiddler 开源 暴力破解工具 Hydra 开源 数据库注入工具 S ...

  5. dx11的一些数据结构

    功能是什么创建一个设备(device)来代表显示适配器(display adapter)并且创建一个交换链(swap chain)用于渲染 设备device在dx11里是用来干什么的从ID3DX11D ...

  6. java struts2入门学习---常用标签学习总结

    jsp页面中引入标签: <%@ taglib uri="/struts-tags" prefix="s"%> 常用标签知识点总结: <s:fi ...

  7. xfsdump命令使用

    一:使用xfsdump备份和恢复xfs文件系统 首先了解一下xfsdump的备份级别有以下两种,默认为0(即完全备份) 0                                    完全备 ...

  8. “医疗信息化行业之中的联发科”- 我们在医疗行业中的定位及目标 想做一个面对中小企业的专业上游软件供应商 台湾联发科技颠覆掉的是一个封闭的手机产业系统 解决方案,即AgileHIS.NET数字化医院基础方案

    “医疗信息化行业之中的联发科”- 我们在医疗行业中的定位及目标   我们做中国医疗信息化行业之中的联发科 ---我们在医疗行业中的定位及目标 从我个人来讲,我从2001年到现在这10年之间基本上一直在 ...

  9. 【Android】Android六种布局详解

    这篇就对LinearLayout.RelativeLayout.自定义ViewGroup.FrameLayout.TableLayout.AbsoluteLayout六种布局进行详细的讲解. 1.Li ...

  10. iOS UILabel设置居上对齐,居中对齐,居下对齐

    在iOS中默认的UILabel中的文字在竖直方向上仅仅能居中对齐,博主參考国外站点.从UILabel继承了一个新类,实现了居上对齐,居中对齐,居下对齐.详细例如以下: // //  myUILabel ...