我有一个简单的例子,试图找出为什么我的角度局部模板无法加载另一个javascript组件。
我正在使用1个模板(singleArticleView.html)和父页面(blog.html),我正在尝试将run_prettify.js应用到我模板中的简单代码段。如果代码在模板内部则不起作用。如果我从子模板中删除代码和脚本标记并将其包含在父模板中,则它可以正常工作
如何在模板中执行该javascript库?我认为它不起作用,因为DOM元素稍后加载。
如何评估部分模板中的内容是否已经呈现以执行任何外部JavaScript代码来操作DOM?
我感谢任何建议
这是代码:
blog.html(家长)
<script src="~/AngularJS/Controllers/articlesController.js"></script>
<script src="~/AngularJS/Controllers/singleArticleController.js"></script>
<div class="row">
<div class="col-md-8 col-md-offset-1">
<div data-ng-view>
</div>
</div>
</div>
singleArticleView.html(模板)
<script src="~/Scripts/run_prettify.js"></script>
<link href="~/Content/prettify.css" rel="stylesheet" />
<div>
{{article.author }}
<pre class="prettyprint linenums lang-html">
<!DOCTYPE html>
<html>
<head>
<title>Demo | Prettify.JS</title>
</head>
<body>
<h1>Hello, World!</h1>
</body>
</html>
</pre>
</div>
singleArticleControlle.js(控制器)
(function () {
var app = angular.module("dbayonaCode");
var singleArticleController = function ($scope, dataService, $window, $routeParams, $sce) {
$scope.article = {};
$scope.newComment = {};
//Get the article with its comments to show in the template and add a new comment
//It uses ArticlesController.cs
dataService.getArticleById($routeParams.id)
.then(function (data) {
//success
$scope.article = data;
$scope.myContent = $sce.trustAsHtml(data.body);
},
function () {
//error
$windows.location = "#/";
});
}
app.controller("singleArticleController", singleArticleController);
}());
答案 0 :(得分:1)
这是angular的正常行为,它从模板中删除脚本标记。
我找到了几个解决方案,具体取决于您要做的事情。如果它是一个较小的脚本而你可以内联它,我喜欢这个解决方案,它在脚本标记中添加了一个'延迟加载'类型:
/*global angular */
(function (ng) {
'use strict';
var app = ng.module('ngLoadScript', []);
app.directive('script', function() {
return {
restrict: 'E',
scope: false,
link: function(scope, elem, attr) {
if (attr.type === 'text/javascript-lazy') {
var code = elem.text();
var f = new Function(code);
f();
}
}
};
});
}(angular));
以上代码来自这篇文章:AngularJS: How to make angular load script inside ng-include?
问题是它只在脚本标记之间加载文本,不会加载src
属性中指定的文件。
另一个解决方案还修改了脚本指令,允许我们通过src
属性加载外部js文件,或者如果src
未定义则从脚本标记之间加载:
/*global angular */
(function (ng) {
'use strict';
var app = ng.module('ngLoadScript', []);
app.directive('script', function() {
return {
restrict: 'E',
scope: false,
link: function(scope, elem, attr)
{
if (attr.type==='text/javascript-lazy')
{
var s = document.createElement("script");
s.type = "text/javascript";
var src = elem.attr('src');
if(src!==undefined)
{
s.src = src;
}
else
{
var code = elem.text();
s.text = code;
}
document.head.appendChild(s);
elem.remove();
}
}
};
});
}(angular));
上面的代码段来自here。