angular6.0使用教程之父組件通過url傳遞id給子組件的方法
在angular6.0使用教程:angular主從組件章節(jié)我們介紹了父組件向子組件傳遞數(shù)據(jù),當(dāng)時(shí)是在同一個(gè)頁面?zhèn)鬟f數(shù)據(jù)的。而本章的angular數(shù)據(jù)傳遞將是在不同頁面間的傳遞,即list組件頁面向post組件頁面?zhèn)鬟f數(shù)據(jù)。
第一步:配置post組件的路由:
在上一章angular6.0使用教程:angular6.0的路由使用中我們?yōu)閍ngular6.0項(xiàng)目設(shè)置了路由,我們只設(shè)置了home組件和list組件的路由。我們還要設(shè)置post組件的路由,因?yàn)閜ost是產(chǎn)品組件,而不同的產(chǎn)品會(huì)有不同的id,顯示不同的產(chǎn)品內(nèi)容,所以,我們要為每一個(gè)id要設(shè)置對應(yīng)的路由。app-routing.module.ts文件代碼如下:
import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import {HomeComponent} from "./home/home.component"; //引入home組件
import {ListComponent} from "./list/list.component";//引入list組件
import {PostComponent} from "./post/post.component";//引入post組件
const routes: Routes = [
{ path:'home', component:HomeComponent },
{ path:'list', component:ListComponent },
//post組件路由
{ path:'post/:id', component:PostComponent },
{ path:'**', redirectTo:'/home' }
];
@NgModule({
imports: [RouterModule.forRoot(routes)],
exports: [RouterModule]
})
export class AppRoutingModule { }
第二步:修改db.service.ts服務(wù)代碼:
在angular6.0使用教程:創(chuàng)建和使得angular服務(wù)章節(jié)中,我們能過angular6.0的服務(wù)向遠(yuǎn)程服務(wù)器接口請求數(shù)據(jù),并在list組件中接收獲取到angular請求到的數(shù)據(jù)。具體,可參閱這一章節(jié)。
本章我們要實(shí)現(xiàn)的功能是:點(diǎn)擊list組件頁面上的一個(gè)列表鏈接,就向post組件頁面?zhèn)鬟f一個(gè)產(chǎn)品id,post組件會(huì)向db.service.ts服務(wù)獲取這個(gè)產(chǎn)品id對應(yīng)的產(chǎn)品信息。所以,我們要在db.service.ts服務(wù)中再添加一個(gè)方法——用來向遠(yuǎn)程服務(wù)器請求這個(gè)產(chǎn)品id的信息。代碼如下:
getPost(id:number):Observable<any>{
return this.http.get("/api/dream/index.php/home/index/post_detail/id/"+id);
}
第三步:在post.component.ts組件文件中添加獲取數(shù)據(jù)方法:
1:引入db.service.ts服務(wù):
import {DbService} from "../db.service";
2:引入ActivatedRoute模塊【當(dāng)前被激活的路由,即當(dāng)前post,可以獲取當(dāng)前post的id】:
import {ActivatedRoute} from "@angular/router";
3:在post組件的構(gòu)造函數(shù)中實(shí)例化DbService服務(wù)和ActivatedRoute模塊對象:
constructor(private db:DbService,private route:ActivatedRoute) { }
4:聲明一個(gè)接收變量:
post:any;
5:添加獲取DbService服務(wù)數(shù)據(jù)的方法:
getPost():void{
var id = +this.route.snapshot.paramMap.get('id'); //獲取當(dāng)前Post的產(chǎn)品id
this.db.getPost(id).subscribe( //通過db:DbService的getPost()方法獲取數(shù)據(jù)
data=>{ this.post = data; //把產(chǎn)品全部的信息賦值給post變量 }
);
}
6:在初始化ngOnInit中調(diào)用這個(gè)方法:
ngOnInit() {
this.getPost();
}
7:在post.component.html前臺(tái)代碼中調(diào)用數(shù)據(jù):
<div class="post_detail" *ngIf="post">
<h1>{{ post.name }}</h1>
<h3>{{ post.addtime }}</h3>
<ul [innerHTML]="post.content"></ul>
</div>
這時(shí),在前臺(tái)調(diào)用可能會(huì)有“調(diào)用HTML字符串”出現(xiàn)的問題,這個(gè)可以參閱angular6.0使用教程:angular如何調(diào)用HTML字符串章節(jié)。
這樣,我們就實(shí)現(xiàn)了angular6.0的子組件通過url獲取父組件傳遞過來的id,再通過服務(wù)請求遠(yuǎn)程數(shù)據(jù)。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
ionic使用angularjs表單驗(yàn)證(模板驗(yàn)證)
能夠驗(yàn)證用戶在表單中輸入的內(nèi)容是否合理與正確是十分重要的,這篇文章主要介紹了ionic使用angularjs表單驗(yàn)證(模板驗(yàn)證),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12
Angular中使用ui router實(shí)現(xiàn)系統(tǒng)權(quán)限控制及開發(fā)遇到問題
這篇文章主要介紹了Angular中使用ui router實(shí)現(xiàn)系統(tǒng)權(quán)限控制及開發(fā)遇到問題的相關(guān)資料,本文分步驟介紹的非常詳細(xì),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09
AngularJS應(yīng)用開發(fā)思維之依賴注入3
這篇文章主要為大家詳細(xì)介紹了AngularJS應(yīng)用開發(fā)思維之依賴注入第三篇,感興趣的小伙伴們可以參考一下2016-08-08
利用VS Code開發(fā)你的第一個(gè)AngularJS 2應(yīng)用程序
這篇文章主要給大家介紹了關(guān)于利用VS Code如何開發(fā)你的第一個(gè)AngularJS 2應(yīng)用程序的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友下面來一起看看吧。2017-12-12
Angularjs的Controller間通信機(jī)制實(shí)例分析
這篇文章主要介紹了Angularjs的Controller間通信機(jī)制,結(jié)合實(shí)例形式分析了Controller通信機(jī)制的原理、實(shí)現(xiàn)技巧與相關(guān)操作技巧,需要的朋友可以參考下2016-11-11
Angularjs使用ng-repeat中$even和$odd屬性的注意事項(xiàng)
無可否認(rèn)angularjs的崛起成為前端很大的福利,最近接到項(xiàng)目,框架便選中了angularjs。angularjs最吸引人的地方就是數(shù)據(jù)的雙向綁定和指令了,這篇文章主要介紹了Angularjs中使用ng-repeat的$even和$odd屬性的注意事項(xiàng),需要的朋友可以參考下2016-12-12
淺談Angular4實(shí)現(xiàn)熱加載開發(fā)旅程
本篇文章主要介紹了淺談Angular4實(shí)現(xiàn)熱加載開發(fā)旅程,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09

