Angular?項(xiàng)目路徑添加指定的訪問前綴
前言
開發(fā)多個(gè)項(xiàng)目的時(shí)候,我們希望能通過指定的前綴路徑去訪問不同的項(xiàng)目。比如,通過前綴 /projectA/ 去訪問項(xiàng)目 A;通過前綴 /projectB/ 去訪問項(xiàng)目 B。我們應(yīng)該怎么設(shè)置呢?
這里使用的框架是 Angular,"@angular/core": "~12.1.0"
更改項(xiàng)目前綴
假設(shè)我們添加的前綴為 /jimmy/
1. 更改路由前綴
在 app.module.ts 文件中添加 APP_BASE_HREF:
import { APP_BASE_HREF } from '@angular/common';
@NgModule({
providers: [
{
provide: APP_BASE_HREF,
useValue: "/jimmy/"
}
]
})
2. 更改打包的文件
這一步非必需,我們這里只是統(tǒng)一一下名稱為 jimmy 而已
更改 angular.json 的輸出文件:
{
"projects": {
...
{
"outputPath": "jimmy"
}
}
}
3. 更改掛載文件的 base href
默認(rèn)情況下,掛載的文件 index.html 一般長這樣:
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>Jimmy</title> <base href="/" rel="external nofollow" > <meta name="viewport" content="width=device-width, initial-scale=1"> <link rel="icon" type="image/x-icon" href="logo.png" rel="external nofollow" > </head> <body> <app-root></app-root> </body> </html>
我們是要將 <base href="/"> 變成 <base href="/jimmy/">。但是,我們不能手動(dòng)更改掛載文件。因?yàn)橹灰獦?gòu)建后的文件更改即可,所以我們可以在 package.json 文件中完成這一步。只需要添加 --base-href=/jimmy/ 即可,如下:
"scripts": {
"build": "ng build --base-href=/jimmy/"
}
運(yùn)行 npm run build 打包后得到的文件夾 jimmy 下的 index.html 文件中的 base 標(biāo)簽自然會(huì)更改。
至此,我們已經(jīng)更改完了訪問的項(xiàng)目前綴,那么我們要部署到服務(wù)器上進(jìn)行訪問,是要怎么做呢?
部署項(xiàng)目
這里假設(shè)我已經(jīng)將打包后的 jimmy 資源上傳到了服務(wù)器,并且用 nginx 作為代理。
本項(xiàng)目是個(gè) SPA 項(xiàng)目。MPA 項(xiàng)目的講解會(huì)放在下一篇文章,相關(guān)項(xiàng)目使用技術(shù)是 next.js ,敬請期待
這里,我們需要更改 nginx.config 中的 server 字段:
server {
listen 80 default_server;
root /usr/share/nginx/fe/; // 打包的文件存放的位置
location /jimmy/ {
index index.html index.htm;
try_files $uri $uri/ /jimmy/index.html;
}
}
執(zhí)行 nginx -s reload 使得配置生效。通過 http://domain.com/jimmy/index.html 就可以訪問到項(xiàng)目 jimmy 了。
Thanks for reading.
以上就是Angular 項(xiàng)目路徑添加指定的訪問前綴的詳細(xì)內(nèi)容,更多關(guān)于Angular 路徑訪問前綴的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
在Angular中使用NgTemplateOutlet創(chuàng)建可重用組件的流程步驟
在 Angular 中,使用 NgTemplateOutlet 而不是創(chuàng)建特定組件,可以使組件在不修改組件本身的情況下輕松修改為各種用例,在本文中,您將接受一個(gè)現(xiàn)有組件并重寫它以使用 NgTemplateOutlet,需要的朋友可以參考下2024-03-03
解決Angular.js中使用Swiper插件不能滑動(dòng)的問題
下面小編就為大家分享一篇解決Angular.js中使用Swiper插件不能滑動(dòng)的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02
Angular.JS中的指令引用template與指令當(dāng)做屬性詳解
這篇文章主要介紹了Angular.JS中的指令引用template與指令當(dāng)做屬性的相關(guān)資料,文中介紹的非常詳細(xì),對大家具有一定的參考價(jià)值,需要的朋友們下面來一起看看吧。2017-03-03
angularjs指令中的compile與link函數(shù)詳解
這篇文章主要介紹了angularjs指令中的compile與link函數(shù)詳解,本文同時(shí)訴大家complie,pre-link,post-link的用法與區(qū)別等內(nèi)容,需要的朋友可以參考下2014-12-12
淺談AngularJs 雙向綁定原理(數(shù)據(jù)綁定機(jī)制)
本篇文章主要介紹了淺談AngularJs 雙向綁定原理(數(shù)據(jù)綁定機(jī)制),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-12-12

