我使用下面的代码将模板包含在我的主文件中。
<p ng-include=" 'activity.html' "></p>
我的 activity.html 就是这样,
<script type="text/javascript" src="myjsfile.js"></script>
<p>Activity page contents</p>
但是javascript没有随模板一起加载。
我在SO中发现了一些与此相关的问题,但无法找到可行的解决方案。 其中一个答案是在主文件中将angular js加载到angularjs之上,这样脚本标记就会被接受。但没有发现它有效。
答案 0 :(得分:12)
我在这里找到了这个答案load script inside ng-include,不幸的是,这不是那里接受的答案。所以我在这里提供了一些更新的需求。
图书馆链接here
创建一个包含以下脚本的js文件并将其加载到主文件中。
(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));
并加载 ngLoadScript
模块作为应用依赖:
angular.module('myApp', [
'ngLoadScript'
])
部分(** activity.html )中的 使用text/javascript-lazy
作为type
标记的script
属性值,而不是text/javascript
:**
<script type="text/javascript-lazy">
alert("Yup!");
</script>
为加载外部js做更多的事情:
我使用ddrive下面的代码加载脚本(在 main.html 中)
function loadjscssfile(filename, filetype) {
if (filetype == "js") {
// if filename is a external JavaScript file
var fileref = document.createElement('script');
fileref.setAttribute("type","text/javascript");
fileref.setAttribute("src", filename);
}
else if (filetype == "css") {
//if filename is an external CSS file
var fileref = document.createElement("link");
fileref.setAttribute("rel", "stylesheet");
fileref.setAttribute("type", "text/css")
fileref.setAttribute("href", filename)
}
if (typeof fileref != "undefined") {
document.getElementsByTagName("head")[0].appendChild(fileref)
}
}
和部分(activity.html):
<script type="text/javascript-lazy">
loadjscssfile("myjsfile.js", "js");
</script>