gpt4 book ai didi

javascript - AngularJS—— View 不会在我的浏览器中呈现?

转载 作者:行者123 更新时间:2023-11-30 12:07:02 25 4
gpt4 key购买 nike

我正在导航到我在 Angular 应用程序中设置的路径“/login”。当我尝试使用 Angular 路由导航到我创建的 View 时,我只能在页面上看到导航栏,在 ng-view 中什么也看不到。在我的 chrome 控制台的网络选项卡中,它显示 View 已成功请求并发送到客户端,但它没有在 View 源中为我呈现。另外我想指出,我的 '/' 路线正在纠正。控制台中没有错误。

我正在为我的网络服务器使用 NodeJS + ExpressJS。这是一个水疗中心。我还使用 RequireJS 进行模块加载。

server.js

var express = require('express'),
app = express(),
path = require('path'),
apiRouter = require('./app/routes/api'),
mongoose = require('mongoose'),
compression = require('compression');

app.use(compression());
app.use(express.static('public'));
app.use('/api', apiRouter);

app.use('*', function(req, res) {
res.sendFile(path.join(__dirname + '/public/index.html'));
});

mongoose.connect('mongodb://localhost/triviaattack');

var db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'));
db.once('open', function() {
//Connected to DB successfully.

});

app.listen(1337);

index.html

<!doctype html>
<html class="no-js" lang="">
<head>
<meta charset="utf-8">
<meta http-equiv="x-ua-compatible" content="ie=edge">
<title></title>
<meta name="description" content="">
<meta name="viewport" content="width=device-width, initial-scale=1">

<link rel="apple-touch-icon" href="apple-touch-icon.png">
<!-- Place favicon.ico in the root directory -->

<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" rel="stylesheet">
<link rel="stylesheet" href="css/normalize.css">
<link rel="stylesheet" href="css/main.css">
<!-- <script src="js/vendor/modernizr-2.8.3.min.js"></script> -->
<script data-main="js/main" src="js/vendor/require.js"></script>
</head>
<body>
<!--[if lt IE 8]>
<p class="browserupgrade">You are using an <strong>outdated</strong> browser. Please <a href="http://browsehappy.com/">upgrade your browser</a> to improve your experience.</p>
<![endif]-->
<nav class="navbar navbar-inverse navbar-fixed-top" ng-controller="navCtrl">
<div class="container">
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar">
<span class="sr-only">Toggle navigation</span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="#">Brand</a>
</div>
<div id="navbar" class="navbar-collapse collapse">
<ul class="nav navbar-nav navbar-right">
<li><button class="btn btn-default navbar-btn" ng-click="login()">Login</button></li>
<li><button class="btn btn-info navbar-btn" ng-click="register()">Register</button></li>
</ul>
</div><!--/.navbar-collapse -->
</div>
</nav>
<div ng-view></div>
</body>
</html>

ma​​in.js

require.config({

paths: {
'angular': 'vendor/angular',
'domReady': 'vendor/domready',
'angularRoute': 'vendor/angular-route',
'bootstrapCss': 'vendor/bootstrap-css'
},

shim: {
'angular': {
exports: 'angular'
},
'angularRoute': {
deps: ['angular'],
exports: 'angularRouter'
}
},

deps: ['./bootstrap']
});

bootstrap.js

require([
'angular',
'angularRoute',
'app',
'services/loginSvc',
'controllers/navCtrl',
'controllers/homeCtrl',
'controllers/loginCtrl',
'routes'
], function (angular, angularRoute, app) {
'use strict';

angular.element(document).ready(function () {
angular.bootstrap(document, ['myApp']);
});

});

app.js

define([
'angular',
'angularRoute'
], function(angular, angularRoute) {

'use strict';

var app = angular.module('myApp', ['ngRoute']);

return app;

});

routes.js

define(['app'], function(app) {
'use strict';

app.config(function($routeProvider) {
$routeProvider
.when('/', {
templateUrl: 'js/views/home.html',
controller: 'homeCtrl'
})
.when('/login', {
templateUrl: 'js/views/login.html',
controller: 'loginCtrl'
});
});
});

最佳答案

我想你正在输入 /login路径直接在您的浏览器中。如果您在浏览器中手动输入路线,当您输入 http://myapp.com/myapp/ 时, ng-route 将遵循 /路线。但是,如果您键入 http://myapp.com/myapp/login , 它不会遵循 login路线。这是因为 ng-route期望路线在 # 之后出现.

尝试输入 http://myapp.com/myapp/#/login ,显然取代了 myapp具有适合您的应用程序路径的部分。

此外,制作 /home 可能会有所帮助路线,然后使用 .otherwise() $routeProvider的功能使它成为它加载的默认路由。这样,如果您尝试访问不存在的路由,它将默认为 /home路线,而不是向您展示一个空白模板。

这是实现该目标的方法:

app.config(function($routeProvider) {
$routeProvider
.when('/home', {
templateUrl: 'js/views/home.html',
controller: 'homeCtrl'
})
.when('/login', {
templateUrl: 'js/views/login.html',
controller: 'loginCtrl'
})
.otherwise({
redirectTo: '/home'
});
});

编辑:

在使用 ng-view 时始终使用浏览器的元素检查器.浏览器中的“查看源代码”选项永远不会显示您加载的模板代码,因为您页面的实际源代码只包含 <div ng-view></div> ,而不是模板代码。

关于javascript - AngularJS—— View 不会在我的浏览器中呈现?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34901551/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com