如何在AngularJS部分模板中包含第三方JavaScript库?

时间:2015-05-24 06:23:49

标签: javascript jquery html angularjs templates

我有一个简单的例子,试图找出为什么我的角度局部模板无法加载另一个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">
                                            &lt;!DOCTYPE html&gt;
                                            &lt;html&gt;
                                              &lt;head&gt;
                                                &lt;title&gt;Demo | Prettify.JS&lt;/title&gt;
                                              &lt;/head&gt;
                                              &lt;body&gt;
                                                &lt;h1&gt;Hello, World!&lt;/h1&gt;
                                              &lt;/body&gt;
                                            &lt;/html&gt;
                                </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);
            }());

1 个答案:

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