javascript - 意外请求 : GET

标签 javascript angularjs

出于开发目的,我尝试使用 ngMockE2E 模拟后端,但出现此错误“意外请求:获取 View /home.html”。我还使用路线服务中的 ui-router。谢谢

index.html

<!doctype html>
<html lang="en" ng-app="userApp">
<head>
<meta charset="utf-8">
<title> 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 </p>
                </div>
            </div>
        </footer>
    </div>
</div>
</body>
</html>

app.js

(function(ng){
var userApp =   ng.module("userApp", ["ui.router", "ngMockE2E", "ngResource", "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" }];
    $httpBackend.expect("GET", "/login");
    $httpBackend.when("GET", "/login").respond(users[0]);
}]); 
})(angular);

最佳答案

您需要向 View 目录添加 passThrough,以便 $httpBackend 服务不会捕获请求:

userApp.run([ "$httpBackend", function($httpBackend){
    var users =  [{ "id"    :   "1", "username" :   "user1@test.com", "password"    :   "user1" }];
    $httpBackend.expect("GET", "/login");
    $httpBackend.when("GET", "/login").respond(users[0]);

    $httpBackend.whenGET(/^views\//).passThrough(); // ignore requests to the views directory
}]); 

关于javascript - 意外请求 : GET,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28403445/

相关文章:

javascript - 在提交表单帖子之前获取 URL

javascript - 如何在 Cypress 更新夹具文件

javascript - 使用 Protractor 获取 bool 值的元素可用性状态

javascript - 如何将变量传递给 AngularJs 配置

angularjs - 如何向 AngularUI 日历添加 HTML 元素

javascript - Node : Sending a request once, 但有两个输出?

javascript - jQuery el.each() 返回 HTMLAnchorElement 而不是元素实例

javascript - 构建选择的 Angular Directive(指令)未定义

javascript - 使用 Sinon.js 为 Angular.js 应用程序设置 RESTful 后端模拟

javascript - Angular隐藏上传并显示新上传的图片