javascript - angularjs [ng :areq] Argument 'fn' is not a function, 在控制台错误中得到字符串

标签 javascript angularjs

当我尝试使用 ngmockE2E 模拟后端时出现错误。

“angularjs [ng:areq] 参数 'fn' 不是函数,得到字符串”

当我删除 ngMock 服务时,它工作正常。

索引.html

<!doctype html>
<html lang="en" ng-app="userApp">
<head>
<meta charset="utf-8">
<title>IT Beams Angular App</title>
<link rel="stylesheet" type="text/css" href="css/bootstrap.css">
<link rel="stylesheet" type="text/css" href="css/all.css">
<script type="text/javascript" src="js/jquery.min.js"></script>
<script type="text/javascript" src="js/angular.min.js"></script>
<script type="text/javascript" src="js/angular-cookies.js"></script>
<script type="text/javascript" src="js/ui-router.js"></script>
<script type="text/javascript" src="js/angular-resource.js"></script>
<script type="text/javascript" src="js/angular-mocks.js"></script>
<script type="text/javascript" src="js/app.js"></script>
<script type="text/javascript" src="js/controllers.js"></script>
<script type="text/javascript" src="js/services.js"></script>
</head>
<body>
<div class="container">
    <div class="row">
        <header id="header">
            <div class="logo col-sm-12 col-lg-4">
                <h1>logo</h1>
                <ul class="nav nav-pills pull-right">
                    <li><a ui-sref="home" class="btn btn-success" ui-sref-active="btn-warning">Home</a></li>
                    <li><a ui-sref="login" class="btn btn-success" ui-sref-active="btn-warning">Login</a></li>
                    <li><a ui-sref="register" class="btn btn-success" ui-sref-active="btn-warning">Register</a></li>
                </ul>
            </div>
            <div class="text-area col-sm-12 col-lg-8">
                <h2>Test</h2>
            </div>
        </header>
        <section id="main">
            <div class="container">
                <div class="row">
                    <div ui-view></div>
                </div>
            </div>
        </section>
        <footer id="footer">
            <div class="container">
                <div class="row">
                    <p class="text-center">Copyright IT Beams 2015</p>
                </div>
            </div>
        </footer>
    </div>
</div>
</body>
</html>    

app.js

(function(ng){
var userApp =   ng.module("userApp", ["ui.router", "ngResource", "ngMockE2E", "ngCookies", "mainCtrl"]);
userApp.config(["$stateProvider", "$urlRouterProvider", "$provide", function($stateProvider, $urlRouterProvider, $provide){
    $urlRouterProvider.otherwise( "/" );
    $provide.decorator("$httpBackend", ng.mock.e2e.$httpBackendDecorator);
    $stateProvider
        .state("login", {
            url         :   "/login",
            templateUrl :   "views/login.html",
            controller  :   "loginCtrl"
        })
        .state("register", {
            url         :   "/register",
            templateUrl :   "views/register.html",
            controller  :   "registerCtrl"
        })
        .state("home", {
            url         :   "/",
            templateUrl :   "views/home.html",
            controller  :   "homeCtrl"
        })
}]);

userApp.run("$httpBackend", function($httpBackend){
    var users = [
        { "id"  :   "1", "username" :   "user1@test.com", "password"    :   "user1" },
        { "id"  :   "2", "username" :   "user2@test.com", "password"    :   "user2" },
        { "id"  :   "3", "username" :   "user3@test.com", "password"    :   "user3" },
        { "id"  :   "4", "username" :   "user4@test.com", "password"    :   "user4" }
    ];
    $httpBackend.whenGET("/login").respond(users);

    console.log(testing);
}); 
})(angular);   

感谢帮助。谢谢

最佳答案

run block 设置不正确。

您传递一个字符串作为第一个参数而不是函数:

userApp.run("$httpBackend", function($httpBackend) {
  ...
});

因此出现错误。

它应该是:

userApp.run(function($httpBackend) {
  ...
});

或者如果使用像 config block 那样的内联数组表示法:

userApp.run(["$httpBackend", function($httpBackend) {
  ...
}]);

关于javascript - angularjs [ng :areq] Argument 'fn' is not a function, 在控制台错误中得到字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28391289/

相关文章:

javascript - 如何在 JavaScript 中实现 "add new item"功能?

javascript - 过滤一系列控件并操作它们

javascript - 如何将JS中的数组转换成这种格式

javascript - Jest 在所有测试之前运行一次异步函数

angularjs - Angular:req.handle.writev 不是函数,运行 Angular 旧应用程序时出错

javascript - angularjs如何通过多个选择删除重复项

angularjs - 在 Protractor 中拉动 ng-repeat 数组

angularjs - 如何使用angularjs自动更新json的连接部分

php - 混合javascript和php

javascript - 输入 radio 和号码的 ng-model 相同