真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

淺析Angular2子模塊以及異步加載-創(chuàng)新互聯(lián)

用Angular2開(kāi)發(fā)一個(gè)大型的應(yīng)用,我們通常都需要分模塊進(jìn)行開(kāi)發(fā)。例如將某一個(gè)功能的相關(guān)頁(yè)面和功能放在一個(gè)模塊里面,這樣既可以實(shí)現(xiàn)系統(tǒng)的松耦合,給開(kāi)發(fā)和后期的維護(hù)帶來(lái)很大的便利。同時(shí),對(duì)于子模塊,我們還可以使用延時(shí)加載,這樣可以減少初始加載的文件的大小。在這篇文章中,我們就來(lái)看看在Angular2框架下怎么實(shí)現(xiàn)子模塊及其延時(shí)加載。

為昌邑等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及昌邑網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、外貿(mào)營(yíng)銷(xiāo)網(wǎng)站建設(shè)、昌邑網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專(zhuān)業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!

可以在這里查看本文使用的實(shí)例 。該實(shí)例基于上篇文章Angular2使用Guard和Resolve進(jìn)行驗(yàn)證和權(quán)限控制 所用的實(shí)例,并在它基礎(chǔ)上添加了一個(gè)lazy的模塊,以及將現(xiàn)有的todo模塊配置成延時(shí)加載方式。

為了體現(xiàn)啟用延時(shí)加載前后的包的大小變化,以及啟用壓縮后的變化,在這個(gè)教程里面,使用了angular-cli創(chuàng)建項(xiàng)目腳手架,并用它來(lái)進(jìn)行測(cè)試和打包。有關(guān)angular-cli的使用請(qǐng)查看 官網(wǎng) 。在這篇文章我們使用的angular-cli的版本是1.0.0-beta.21。如果你使用的是別的版本,可能結(jié)果就會(huì)不一樣。甚至有些錯(cuò)誤,我們?cè)谧詈髸?huì)說(shuō)明當(dāng)前版本angular-cli的bug。

模塊設(shè)計(jì)

在開(kāi)發(fā)Angular2應(yīng)用時(shí),像組件設(shè)計(jì)、路由設(shè)計(jì)以外,對(duì)于一個(gè)較大型的應(yīng)用,我們還需要設(shè)計(jì)模塊。例如,將一個(gè)應(yīng)用分成幾個(gè)功能模塊,以及有哪些公用模塊。公用模塊里面應(yīng)該放公用的service類(lèi),例如權(quán)限驗(yàn)證、登錄、獲取用戶信息、全局的錯(cuò)誤處理、工具類(lèi)等,還有封裝的指令或組件。而在某一個(gè)功能模塊里面,只處理這個(gè)模塊里面的業(yè)務(wù),盡量不和其他模塊交互。

拿之前教程中的TodoList應(yīng)用來(lái)說(shuō),只有home頁(yè)面和2個(gè)todo頁(yè)面,我們把todo相關(guān)的功能放在一個(gè)子模塊里面,為了演示,又加了一個(gè)簡(jiǎn)單的名字叫l(wèi)azy的模塊。我們將把todo模塊和lazy模塊配置成延時(shí)加載的模塊。

子模塊開(kāi)發(fā)

接下來(lái)再看看子模塊的開(kāi)發(fā)。其實(shí)在之前的例子中,就把todo相關(guān)的組件放在了一個(gè)模塊里面。但是卻沒(méi)有強(qiáng)調(diào)子模塊開(kāi)發(fā)需要注意的地方,甚至有些配置可能沒(méi)有采用子模塊的方式進(jìn)行配置。這里,我們就主要說(shuō)明一下需要注意的地方,如果要查看完整的代碼,請(qǐng)參考 實(shí)例源代碼 。

子模塊路由

首先需要注意的是路由。在之前的例子中,我們把todo相關(guān)的路由定義在一個(gè)文件中,然后在app的路由定義中把所有路由合并到一起。todo.routes.ts的內(nèi)容如下:

// 省略import
export const TodoRoutes: Route[] = [
  {
    path: 'todo',
    canActivateChild: [MyTodoGuard],
    children: [
      { path: 'list', component: TodoListComponent, resolve: { todos: MyTodoResolver } },
      { path: 'detail/:id', component: TodoDetailComponent, canDeactivate: [ CanLeaveTodoDetailGuard ] }
    ]
  }
];

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。


網(wǎng)頁(yè)標(biāo)題:淺析Angular2子模塊以及異步加載-創(chuàng)新互聯(lián)
當(dāng)前路徑:http://weahome.cn/article/pjsgj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部