[英]How to fetch a list of all svg files from an angular application directory?
我想在Angular 4應用程序的特定文件夾中獲取所有.svg
文件的列表。 因此,我已經通過以下方式在我的angular-cli.json
文件中聲明了該文件夾
"apps": [
{
"root": "src",
"outDir": "dist",
"assets": [
"favicon.ico",
"assets",
{
"glob": "**/*.svg",
"input": "../node_modules/..../assets/images",
"output": "./assets/images"
}
],
"index": "index.html",
"main": "ma...
現在如何讀取./assets/images
目錄中所有.png
文件的列表?
該列表應加載到標准角度組件內。 之后,我想使用簡單的for循環遍歷列表。 如果你們中的某些人可以告訴我如何獲取列表,我可以自己完成最后一部分。
編輯
目錄的內容看起來像這樣
images
|--file_1.svg
|--file_2.svg
|--file_3.svg
└--file_4.svg
如果我嘗試訪問URL HOST:PORT / assets / images / file_1.svg,則圖像顯示正確,但是如果我嘗試使用HOST:PORT / assets / images列出目錄的所有文件,則會出現HTTP 404
。
這是我組件的構造函數:
constructor(private http: Http) {
this.http.get('./assets/images').subscribe(res => console.log(res));
}
我已盡力找到解決方案,但是由於Javascript無法訪問文件結構,因此似乎無法實現。 我能找到的最佳解決方案是在json中創建圖標列表,請求文件,然后將內容存儲給以后的用戶。
由於從assets
文件夾訪問文件很容易,因此我們可以利用它
我們可以在圖標icons.json
文件中存儲圖標文件名稱的數組。
1.在assets
文件夾中創建以下icons.json
:
{ // ---------- icons.json---------
"icons-array" : ["icon-name1", "icon-name2", "icon-name3"]
}
2.將icon-name1.svg
, icon-name2.svg
, icon-name3.svg
文件icon-name3.svg
在assets/icons
文件夾中。
3.在angular應用程序啟動時讀取icons-json
文件。
如何在Angular應用程序啟動時讀取文件
4.讀取icons.json
內容后,將icons-array
屬性的值存儲到全局可訪問數組中,例如globalAccessibleIconsArray
。
5.並將數組用作-
for (const icon of globalAccessibleIconsArray) {
this.matIconRegistry.addSvgIconInNamespace(
'my-namespace',
icon,
domSanitizer.bypassSecurityTrustResourceUrl(`./assets/icons/${icon}.svg`)
);
}
因此,對於添加新圖標
assets/icon
文件夾中,然后 assets
文件夾中存在的icons.json
文件中添加新文件名。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.