使用PhantomJS预渲染AngualrJS网站时“无法实例化模块ngSanitize”

时间:2014-06-07 01:14:10

标签: javascript angularjs phantomjs

我正在尝试使用PhantomJS预呈现我的AngularJS网站。 (使用来自http://www.yearofmoo.com/2012/11/angularjs-and-seo.html的phantomjs-runner.js)我无法通过PhantomJS加载页面,因为下面的错误发生了。 IE / Chrome / Firefox中不会出现此错误。

如何修复此错误?

错误:

Error: [$injector:modulerr] Failed to instantiate module SpaceForAfrica due to:
Error: [$injector:modulerr] Failed to instantiate module dialogs due to:
Error: [$injector:modulerr] Failed to instantiate module ngSanitize due to:
Error: [$injector:nomod] Module 'ngSanitize' is not available! You either misspelled the module name or forgot to load it. If registering a
module ensure that you specify the dependencies as the second argument.
http://errors.angularjs.org/1.2.1/$injector/nomod?p0=ngSanitize
    at http://ajax.googleapis.com/ajax/libs/angularjs/1.2.1/angular.js:1507
    at ensure (http://ajax.googleapis.com/ajax/libs/angularjs/1.2.1/angular.js:1435)
    at module (http://ajax.googleapis.com/ajax/libs/angularjs/1.2.1/angular.js:1717)
    at http://ajax.googleapis.com/ajax/libs/angularjs/1.2.1/angular.js:3527

模块配置

var SpaceForAfrica = angular.module('SpaceForAfrica', ['ngRoute', 'HashBangURLs', 'ui.bootstrap', 'ui.bootstrap.tpls', 'google-maps', 'ui.growl', 'dialogs', 'ngSanitize', 'angularSpinner','angulartics', 'angulartics.google.analytics']).config(spaceForAfricaConfig);

1 个答案:

答案 0 :(得分:17)

看起来您可能缺少对ngSanitize代码的引用。 ngSanitize是AngularJS框架(https://docs.angularjs.org/api/ngSanitize)的一部分,但是,您必须在PhantomJS参考之前包含单独的参考才能使用它。

看来你正在使用AngularJS的1.2.1版本,所以你可以轻松地添加其中一个标签(或者抓住代码包含在你自己的应用程序中。)

非精缩:

<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.2.1/angular-sanitize.js"></script>

缩小的:

<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.2.1/angular-sanitize.min.js"></script>