angular 4 router传递数据三种方法
1.在查询参数中传递数据
- <a [routerLink]="['/product']" [queryParams]="{id:1,name:'dongian'}">product</a>
然后在app-routing.module.ts中配置
- const routes: Routes = [
- {path: 'product', component: ProductComponent}
- ];
最后在product.component.ts中接收参数
- private productShop: any = {};
- constructor(private routeInfo: ActivatedRoute ) { }
- ngOnInit() {
- this.routeInfo.queryParams.subscribe(queryParams => {
- this.productShop.id = queryParams.id;
- this.productShop.name = queryParams.name;
- });
- }
当然记得 ActivatedRoute是需要注入。。。在页面就可以打印出来了
2.路由路径中传递参数 (在这里我会将2种参数接收方式)
- <a [routerLink]="['/product',1]">product</a>
然后在app-routing.module.ts中配置
- const routes: Routes = [
- {path: 'product/:id', component: ProductComponent}
- ];
最后在product.component.ts中接收参数
第一种 也称作 参数快照
- private productShop: number;
- constructor(private routeInfo: ActivatedRoute ) { }
- ngOnInit() {
- this.productShop = this.routeInfo.snapshot.params['id'];
- }
第二种 也称作 参数订阅
- private productShop: any;
- constructor(private routeInfo: ActivatedRoute ) { }
- ngOnInit() {
- this.routeInfo.params.subscribe(params => this.productShop = params['id']);
- }
区别也就在于url地址相同,传递参数不同时(比如说,一个是a标签方式跳转,一个是点击事件的方式跳转,2种情况同时存在时),使用第二种方法,
不存在这种情况的时候使用可以使用第一种
3.路由配置中传递参数(当然也要2中写法)
- onProduct() {
- this.router.navigate(['product', 2]);
- }
这里主要讲第二种
- <button (click)="onProduct()">商品详情</button>
- onProduct() {
- this.router.navigate(['product'], {queryParams: {id: 2, name: 'dongtian'}});
- }
- private productShop: any = {};
- constructor(private routeInfo: ActivatedRoute ) { }
- ngOnInit() {
- this.routeInfo.queryParams.subscribe( queryParams => {
- this.productShop.id = queryParams.id;
- this.productShop.name = queryParams.name;
- });
- }
angular 4 router传递数据三种方法的更多相关文章
- Android传递数据5种方法
Android开发中,在不同模块(如Activity)间经常会有各种各样的数据需要相互传递,我把常用的几种 方法都收集到了一起.它们各有利弊,有各自的应用场景. 我现在把它们集中到一个例子中展示 ...
- Struts2中表单与Action传递数据三种方式
1. Action中的属性与表单中的属性一致就可以 JSP中的表单 <form action="login.action" method="post&q ...
- ASP.NET MVC 中将数据从View传递到控制器中的三种方法(表单数据绑定)
http://www.cnblogs.com/zyqgold/archive/2010/11/22/1884779.html 在ASP.NET MVC框架中,将视图中的数据传递到控制器中,主要通过发送 ...
- React Router v4 页面传值的三种方法
传值方法 1.props.params 使用React router定义路由时,我们可以给指定一个path,然后指定通配符可以携带参数到指定的path: <Route path='/user/: ...
- DataTable数据批量写入数据库三种方法比较
DataTable数据批量写入数据库三种方法比较 标签: it 分类: C#1) insert循环插入:2) sqldataadapter.update(dataset,tablename); ...
- mfc 在VC的两个对话框类中传递参数的三种方法
弄了好久,今天终于把在VC中的对话框类之间传递参数的问题解决了,很开心,记录如下: 1. 我所建立的工程是一个基于MFC对话框的应用程序,一共有三个对话框,第一个对话框为主对话框,所对应的类为CTMD ...
- 去除DataTable重复数据的三种方法
业务需求 最近做一个把源数据库的数据批次导出到目标数据库.源数据库是采集程序采集而来的原始数据库,所以需要对其进行一些处理(过滤一些为空,长度太短或太长,非法字符,重复数据)然后在进行入库. 其中要避 ...
- 【转】asp.net导出数据到Excel的三种方法
来源:http://www.cnblogs.com/lishengpeng1982/archive/2008/04/03/1135490.html 原文出处:http://blog.csdn.net/ ...
- JAVA写JSON的三种方法,java对象转json数据
JAVA写JSON的三种方法,java对象转json数据 转自:http://www.xdx97.com/#/single?bid=5afe2ff9-8cd1-67cf-e7bc-437b74c07a ...
随机推荐
- Java中的锁——锁的分类
Java中有各种各样的锁,例如公平锁.乐观锁等等,这篇文章主要介绍一下各种锁的分类. 按照其性质分类 公平锁/非公平锁 公平锁是指多个线程按照申请锁的顺序来获取锁. 非公平锁是指多个线程获取锁的顺序并 ...
- 环境搭建 - Tomcat(Windows)
Tomcat环境搭建 本文以Windows7下搭建tomcat-8.5.15为示例 下载tomcat压缩包 网址:Tomcat 非C盘根目录新建文件夹:Tomcat D:\tomcat 将tomcat ...
- Css实现手机端页面强制横屏的方法示例
样式 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 @media screen ...
- 【20190407】JavaScript-indexOf方法解析
在JavaScript中,字符串类型String和数组类型Array都有indexOf()方法,虽然他们的作用都是返回传入元素在指定字符串或数组中的位置,但他们之间还是存在着一点点不同. Str.in ...
- iPad----------教你如何查询ipad型号
1.首先进入苹果官网 找到support https://support.apple.com 2.找到查询ipad型号的地方 点击Check coverage for your produc ...
- Ehcache入门经典:第二篇ehcache.xml的参数
继续第一篇 diskStorepath:指定在硬盘上存储对象的路径path属性可以配置的目录有: user.home(用户的家目录) user.dir(用户当前的工作目录) java.io.tmpdi ...
- echarts中legend如何换行
lengend data数据中若存在'',则表示换行,用''切割.
- c/c++ 多线程 绕过mutex的保护
多线程 绕过mutex的保护 mutex,能够解决线程安全的问题,但它不是万能的.下面的例子虽然使用了mutex,但是恶意注入了一个外部函数,导致把被mutex保护的双向链表,让一个外部的指针指向了, ...
- c/c++ linux 进程 fork wait函数
linux 进程 fork wait函数 fork:创建子进程 wait:父进程等待子进程结束,并销毁子进程,如果父进程不调用wait函数,子进程就会一直留在linux内核中,变成了僵尸进程. for ...
- Linux 系统进程相关命令
1.pstree :可以使用pstree命令来查看系统中进程的分布结构. 2.ps: 常用于查看系统进程的命令是ps(process status)命令,可通过它来查看系统进程的最基本信息. ●-A ...