如何加载javascript文件和ng-include模板

时间:2013-11-20 04:20:50

标签: javascript jquery angularjs

我使用下面的代码将模板包含在我的主文件中。

<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之上,这样脚本标记就会被接受。但没有发现它有效。

1 个答案:

答案 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>