- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在开发一个 Angular JS 网站,它从 webservice/api 获取数据。一个 API 返回 html 和 Angular JS 代码,以动态添加 Controller 或我们想要添加的任何新的 Angular 组件。该字符串将出现在 api 响应中
<div id="homecontainer" class="flex-center p-page" loader style="overflow:hidden;">
<div class="column-1">
<div class="grid m-0 col-xs-12">
<div ng-repeat="Widget in V3Widgets track by $index" class="grid-item">
<div class="grid-sizer"></div>
{{Widget}}
</div>
</div>
<div ng-controller="WelcomeController">
{{greeting}}
</div>
<script>
var app = angular.module('demo', [])
//RestService is Other Module Which is Already Working fine
.controller('WelcomeController', function ($scope,RestService) {
$scope.greeting = 'Welcome!';
});
angular.bootstrap(document, ['demo']);
</script>
</div>
</div>
现在我有一个指令将此字符串绑定(bind)到页面
<renderdynamicwidgethtml ng-if="Widget.Id==null && Widget.Html!=null" html="Widget.Html"/>
指令的js
.directive('renderdynamicwidgethtml', ['$compile', function ($compile) {
return function (scope, element, attrs) {
scope.$watch(
function (scope) {
return scope.$eval(attrs.html);
},
function (value) {
element.html(value);
$compile(element.contents())(scope);
}
);
};
}])
scope.$eval
应该将字符串转换为 Angular 分量,但由于此错误而失败。
[ng:btstrpd] http://errors.angularjs.org/1.3.17/ng/btstrpd?p0=document
最佳答案
Since Angular 1.5, there's a new
angular.component
tool. This answer uses the word Component to make a reference to all the possible tools Angular provides (such as directives, filters, etc), includingangular.component
.
首先让我从 AngularJS 设置一切的方式开始:
加载 javascript 文件后,您可以看到所有以 angular.module
、angular.controller
、angular.directive 开头的 Angular 代码
等。所有这些都接收一个函数作为参数(除了 angular.module
,它接收名称和依赖项列表)。此时,这些组件还没有被创建,只是注册了。
一旦 Angular 注册了所有模块和组件,就可以成为 bootstrapped ,可以使用 ng-app
指令,也可以使用 angular.bootstrap
手动进行。两种方法都接收一个字符串作为参数,它是根模块的名称。使用该根模块,Angular 深入查看其依赖项(可以将其视为依赖项树),并开始从其叶子(没有依赖项的模块)加载组件,直到根模块的组件。
对于每个模块,Angular 按照一定的顺序构建它们,从常量开始,然后是提供者,然后按照注册的顺序运行配置 block ,然后加载值,然后是工厂/服务,然后是指令,最后运行 block 按照注册的顺序排列(我不完全确定顺序,我建议您仔细检查)
最后,一切设置完毕后,它会“密封”应用程序,因此无法注册其他任何内容。
该错误意味着您正在引导应用程序两次。当使用 ng-app
指令并调用 angular.bootstrap
,或者只是多次调用 angular.bootstrap
时,可能会发生这种情况。
正如文档中手动初始化部分所述:
You should call
angular.bootstrap()
after you've loaded or defined your modules. You cannot add controllers, services, directives, etc after an application bootstraps.
因此,为了动态加载新 Controller ,您应该在引导过程之前注册它们。您可以通过从 API 检索所需的数据(由于尚未设置 Angular,因此需要任何其他工具,如 JQuery),使用 JavaScript 的标准 eval
函数执行代码(执行这在请求的 promise 中),然后使用 angular.bootstrap 手动引导 AngularJS。
为此,您使用 eval
执行的代码应该是纯 JavaScript,我建议通过更改 API 的响应(如果可能)或在获取后以编程方式将其与 HTML 分离。响应。
此外,如果您需要多次执行此操作,请确保使用 eval
执行的代码在注册您需要的所有组件之前不会引导 Angular。
关于javascript - 页面加载后动态注入(inject)新的 Angular JS Controller 和 html,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38895034/
我正在尝试在项目中学习和添加 Angular 国际化。我只能理解 Angular 文档 (https://angular.io/guide/i18n-overview) 的编译时翻译。 我需要这样的东
在我的 Angular 应用程序中,基于登录用户,我想通过显示/隐藏不同的菜单项或允许/禁止某些路由来授予或限制功能。 目前成功登录后,我的 .NET Core API 会返回一个 JWT token
我是 Angular 的新手,目前我已经看过 angular.io 网站提供的一些示例。但是在component decorator在文档中的解释,它指出 Angular components are
这里是service employee-service.service.ts的代码 import { Injectable } from '@angular/core'; import { HttpC
我目前正在使用@angular/http URLSearchParams 类来检索 URL 参数。在 Angular 5 中,注意到这已被弃用,但我没有看到以我当前使用的方式替换 URLSearchP
我目前正在使用@angular/http URLSearchParams 类来检索 URL 参数。在 Angular 5 中,注意到这已被弃用,但我没有看到以我当前使用的方式替换 URLSearchP
如何正确安装 PUG/JADE 到 Angular 2 或更高版本 这样在工作和 AOT 和 JiT 的同时 工作单元和集成测试 并且在创建每个新组件时不会受到太多影响 最佳答案 我看到了很多解决方案
我的 Angular 12 应用程序中有一些通用组件,我计划将其创建为一个 Angular 库,以便其他应用程序也可以使用它。我们有一些应用程序在较低版本的 angular(例如 angular 8/
tl;dr; ng build 删除了包含我编译的自定义库的/dist 文件夹。这会使我项目代码中对该库的所有引用无效,从而导致 ng build 最终失败。我做错了什么? 我关注了documenta
我正在将一些“遗留”(非 typescript )js 库导入到我的 Angular SPA 中。 通常我只是从 cdn 添加一个负载到 index.html 就像: 在 Angular 分量中我只
我有这个 angular 应用程序,它基本上使用了库的概念。 我有 2 个名为 的库Lib1 和 lib2 根据他们所服务的微服务分组。 现在我将这些库导入主应用程序,即 应用1 事情一直到现在。 现
我在我的项目中启用了 angular Universal。我现在想完全删除它。我试图删除以下文件 /server.ts /webpack.server.config.js /src/tsconfig.
我已经有一个 AuthService 在登录时对用户进行身份验证,并且 AuthGuard 在未登录的情况下阻止访问。 某些页面我通过 UserProfile/Role 限制访问,但现在我需要阻止页面
我正在尝试使用 angular、TypeORM、SQLite 和其他组件作为 webpack 构建 Electron 应用程序。 我从在 GitHub 上找到的示例开始我的开发:https://git
我在从 Angular 8 更新到 9 并运行时遇到以下错误 ng 更新@angular/material: Package "@angular/flex-layout" has an incompa
我正在尝试使用 Angular 9,我想创建一个项目,然后创建一个库项目并开始向其中添加我想稍后在 GitHub 上发布的通用模块,并在我的本地使用这些库项目。 相关依赖如下: Angular CLI
我正在尝试使用 Angular 9,我想创建一个项目,然后创建一个库项目并开始向其中添加我想稍后在 GitHub 上发布的通用模块,并在我的本地使用这些库项目。 相关依赖如下: Angular CLI
我正在我的 h1 元素“之前”创建一个小的程式化三 Angular 形图案,但我无法正确地圆 Angular 。右上角没问题,但其他两个有剪裁问题。 这是输出以及形状的放大图像: 使用的代码如下: h
我有一个 Angular 元素,带有自定义标记名 - fancy-button。如何将 fancy-button 嵌入 Angular 应用程序? 我已经尝试了以下方法,但都没有用 - 在 index
我已将我的项目从 angular 5.2.9 升级到 angular 6.0.0-rc.5。 除了包路径中的几个快速 RxJS 修复外,一切看起来都不错。(此链接非常有用:Want to upgrad
我是一名优秀的程序员,十分优秀!