![](/img/trans.png)
[英]Drupal 8 Multiple Custom Modules Using Same External JS Lib (e.g. Angular)
[英]Angular 9 - js scripts not working (e.g. foundations or bootstrap)
Angular(做在线课程)的第一步,我一直认为我的 JS 不工作。 因为当我为下面的项目服务时,会看到基础样式(css),但是当我单击它时,汉堡包图标没有打开/关闭。 该代码是来自基金会网站的示例。
app.component.html 看起来像这样
<h1>This is the app</h1>
<div class="title-bar" data-responsive-toggle="main-nav" data-hide-for="medium">
<button class="menu-icon" type="button" data-toggle="main-nav"></button>
<div class="title-bar-title">Menu</div>
</div>
<div class="top-bar" id="main-nav">
<div class="top-bar-left">
<ul class="dropdown vertical medium-horizontal menu" data-dropdown-menu>
<li class="menu-text">Site title</li>
<li><a href="#">One</a></li>
<li><a href="#">Two</a></li>
<li><a href="#">Two</a></li>
</ul>
</div>
</div>
通过众多主题最终得出以下结论:
在 styles.css 我添加
@import "../node_modules/foundation-sites/dist/css/foundation.min.css";
在 angular.json 我添加
"styles": [
"src/styles.css",
"node_modules/foundation-sites/dist/css/foundation.min.css"
],
"scripts": [
"node_modules/jquery/dist/jquery.min.js",
"node_modules/foundation-sites/dist/js/foundation.min.js"
]
我个人对此的看法:
这可能是可行的,但普通的 Bootstrap 使用 jQuery 来操作 DOM(例如,当您单击汉堡菜单图标时打开/关闭您的工具栏)。
jQuery 真的不应该与 Angular 一起使用,因为它可能会干扰 Angular 对 DOM 的维护。 (jQuery 会改变 DOM,而 Angular 不会知道)。
出于这个原因,还有一些其他项目,包括 ngx-bootstrap,它们要么使用 Bootstrap 的 css,但根据 Angular 指令实现 js 功能,或者看起来和操作类似于 Bootstrap 并重新实现(至少部分地) css 和 js。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.