- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
默认的 angular-cli 构建生成结构非常扁平的 dist 文件夹 - assets 文件夹和 js、html 文件。有没有办法创建 fe. scripts 文件夹并在构建过程中将所有 js 文件放入其中?
最佳答案
CLI 还不完全支持这一点,但它确实提供了一些有用的工具来帮助您完成大部分工作。我需要它来部署我的 Angular 应用程序和 WAR,同时尽量减少通过 servlet 映射增加的复杂性。这个问题没有具体提到 J2EE,但我认为这个解决方案的原则可以在各种环境中共享。
相关ng build
参数:
--deploy-url
:将应用于资源的路径映射。 这可能是 Angular-CLI 目前最接近您正在寻找的东西。--output-path
: 指定 Angular 构建的输出目录(特别是,我用它来指定不同环境的唯一输出目录,因为应用程序正在部署到具有不同配置的多个目标)。--base-href
:应用程序的根 URI。例如,/angular-app/
对于 http://localhost:4200/angular-app/
.这设置了 <base href="<uri>">
head 标签,对于非哈希路由是必需的。其他事情也可能有必要。对您来说最有趣的可能是 --deploy-url
.如果您将部署 URL 设置为 /dist/
,例如,那么在您构建的应用程序中对 JS 文件的引用将以 /dist/
为前缀.
此方法的两大收获:
--deploy-url
不会更改 JS 文件的输出 路径。它只更改对 JS 文件的引用。文件本身仍将放在根构建目录中。您必须在构建过程中添加一个步骤才能手动修复此问题。--deploy-url
似乎不适用于任何其他 Assets 。我将所有其他 Assets 放在 assets/
中目录,构建的输出仍然通过 assets/<path>
引用 Assets (而不是根据需要 dist/assets/<path>
)。您可以通过提供虚拟目录或重写 URL 来解决此问题。作为引用,这是我为 WAR 生成的目录结构:
app/
dist/ <-- Deployed Angular application
assets/
(images, CSS, etc)
*.js
(other assets pulled into the root path, e.g. *.(svg|eot|woff|woff2|ttf) from Font Awesome)
index.html
WEB-INF/
...
index.jsp
这些是我生成此结构所采取的步骤:
ng build -pr false --prod --output-path build/node-prod --base-href /angular-app/ --deploy-url /angular-app/dist/
.build/node-prod
的内容到 WAR 构建目录的 app/dist
通过 gradle 任务。index.jsp
至 index.html
通过内容<%@include file="dist/index.html"%>
./dist/*
添加默认 servlet(静态 Assets )的 servlet 映射和 /assets/*
.^/assets/(.*)$
至 /dist/assets/$1
(或通过 httpd、nginx 等)。这是必需的,因为上面给出了 --deploy-url
的问题。不为其他 Assets 工作。^/dist/index.html$
添加 301 或 302 重定向到根上下文路径以防止用户通过 dist
访问应用程序网址。在生成的 webapp 中,http://localhost/angular-app/
是我的应用程序的唯一有效端点。此端点指向 index.jsp
, 其中包括 index.html
的内容, 它通过 <script src="/angular-app/dist/<some-file>.js"></script>
加载相关的 JS标签。
当需要一些其他 Assets 时,例如 Logo 图像,页面会向 assets/<file-name>
发出请求,通过 Tuckey 在服务器端重写为 dist/assets/<file-name>
,透明地解析请求的 Assets 。
这个解决方案的好处是我们能够在根上下文中部署 Angular 应用程序,而不必将 所有 ng build
内置到根 WAR 路径中。这特别好,因为我们不想添加可以避免的全局 servlet 映射(例如 *.js
)。
关于Angular-cli 构建文件夹结构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42506450/
我在使用NetBeans 6.8时遇到以下问题。我通过项目属性->库->编译选项卡->添加JAR /文件夹添加带有jar的文件夹。在下一个窗口中,我选择文件夹,然后选择“复制到库文件夹”。但是,我仍然
我的网站有一个域别名。我想知道如何将 domainA.ext 的请求重定向到 https://domainA.ext/folderA和对 domainB.ext 的请求到 http://domainB
我应该在 Eclipse 中构建的 Android 项目中创建自己的自定义菜单文件夹吗?例如,我想创建一种出现在所有 Activity 中的标题。我知道菜单应该在 res/menu 文件夹中的 XML
我正在使用 VS2008 和 .net 3.5。我在我的解决方案中创建了一个类库(Myproject.Controllers)。在这个类下,我添加了一个 Controllers 文件夹。在文件夹中我添
我有一个包含生成后步骤的 Visual Studio 2012 扩展项目,我想在其中将 .dll 和 .AddIn 文件复制到当前用户的 Visual Studio 2012 AddIns 文件夹中。
我在专有的 linux 发行版中有一些自动下载。 他们去临时暂存盘。我想在它们完成后将它们 move 到主 RAID 阵列。我能看到的最好方法是检查磁盘上的文件夹,看看内容是否在最后一分钟发生了变化。
我目前正在使用 SVN 对我的软件项目进行版本控制。在一个正在进行的项目中,我有主干,用于客户的共同功能和规范以及分支,用于客户特定的。 有没有办法在每次执行此类操作时标记一些不应合并到分支中的文
这个问题在这里已经有了答案: How to exclude a directory in find . command (45 个回答) 8 年前关闭。 如何删除文件夹中的所有内容并排除特定文件夹和文
如何在特定目录中创建具有当前日期和时间的文件夹或文件? DateTimeFormatter f = DateTimeFormatter.ofPattern("uuuuMMdd HHmmss") ; L
有没有办法在系统文件资源管理器的左侧“文件夹”栏中打开文件或文件夹?如果没有这个,我必须打开文件资源管理器并一直导航到该文件夹所在的位置才能操作文件,这确实很不方便。对于大多数带有这样导航栏的工具
预期:我使用 go get 安装包,它在 src 文件夹中创建了所有必要的文件夹,但它们只出现在 pkg/mod 文件夹中,我不能使用它们。 现实:它说它正在下载,完成,然后什么都没有。 一切都在 W
说 foo.zip包含: a b c |- c1.exe |- c2.dll |- c3.dll 哪里a, b, c是文件夹。 如果我 Expand-Archive .\foo.zip -Destin
不久前我正在删除 var 文件夹中 Magento 的缓存。我可能是错的,但我认为我犯了一个错误,而不是删除 var/cache 中的所有内容,而是意外删除了 var 中的所有内容。 Magento
我在 svn 存储库的单独文件夹中有一些代码项目。 现在我在删除文件时遇到一些问题:大多数时候一切顺利,但有时当我从磁盘删除文件或文件夹时, checkin 过程会出现各种错误。 所以我想知道:在sv
有没有什么方法可以用很少的R命令行自动删除所有文件或文件夹?我知道 unlink() 或 file.remove() 函数,但对于这些函数,您需要定义一个字符向量,其中包含您想要的文件的所有名称删除。
用于在文件夹中查找不符合Get-Childitem的LastWriteTime过滤器日期范围标准的文件的powershell命令是什么? 因此,请检查目录中是否包含不包含在01/10/2012(十月1
我正在为我工作的公司内部使用的应用程序之一编写 NSIS 安装程序,安装过程工作正常,所有 REG 键都已创建,文件夹和服务也没有问题,该应用程序使用。出于某种我无法理解的原因,卸载过程不起作用。
我有一个 Excel 文件,并且在同一文件夹中还有一个包含我想要包含的 CSV 文件的文件夹。使用“来自文件夹”查询,第一步将给出以下查询: = Folder.Files("D:\OneDrive\D
我在docker中玩ScyllaDB。为了使ScyllaDB在docker生产设置中最有效地运行,它需要一个XFS格式的磁盘。 您知道如何在Linux和MacO中创建XFS容器卷,磁盘文件吗? 谢谢
我应该编写一个函数,其中包含之前每次与该数字相乘的乘积 基本上是这样的: > productFromLeftToRight [2,3,4,5] [120,60,20,5] 我应该使用高阶函数,例如折叠
我是一名优秀的程序员,十分优秀!