【发布时间】:2015-08-05 21:26:33
【问题描述】:
我有一个简单的例子来尝试找出为什么我的角度部分模板无法加载另一个 javascript 组件。
我正在使用 1 个模板 (singleArticleView.html) 和一个父页面 (blog.html),我正在尝试将 run_prettify.js 应用到我的模板内的一个简单代码 sn-p。如果代码在模板内,则它不起作用。如果我从子模板中删除代码和脚本标签并将它们包含在父模板中,它可以正常工作
如何在我的模板中执行该 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);
}());
【问题讨论】:
标签: javascript jquery html angularjs templates