javascript - AngularJS $location 目录

标签 javascript html angularjs

主页网址:http://localhost:3000/

当前第二页网址:http://localhost:3000/#/titleDetails.html

预计第二页网址:http://localhost:3000/titleDetails.html

目前,当我单击主页中的标题时,URL 包含额外的 /#,这会导致页面重定向到 titleDetails.html

titleDetails.html目录和index.html目录在同一目录下。

我可以知道如何解决这个问题吗?

Original Post: AngularJS Display 1 Post in New Page

app.js

(function () {
    angular
    .module("BlogApp", [])
    .config(function($locationProvider) {
        $locationProvider.html5Mode(true).hashPrefix('!');
    })
    .controller("BlogController", BlogController);

    function BlogController($scope, $http, $rootScope, $location) {
        $scope.createPost = createPost;
        $scope.deletePost = deletePost;
        $scope.editPost = editPost;
        $scope.updatePost = updatePost;
        $scope.titleDetails = titleDetails;
        $scope.postDetail = null;

    function init() {
        getAllPosts();
    }
    init();

    function titleDetails(post)
    { 
        $scope.postDetail = post; 
        $location.path('/titleDetails.html'); 
    }

    function updatePost(post){
        console.log(post);
        $http
        .put("/api/blogpost/"+post._id, post)
        .success(getAllPosts);
    }

    function editPost(postId){
        $http
        .get("/api/blogpost/"+postId)
        .success(function(post){
            $scope.post = post;
        });
    }

        function deletePost(postId){
            $http
            .delete("/api/blogpost/"+postId)
            .success(getAllPosts);
        }

        function getAllPosts(){
            $http
            .get("/api/blogpost")
            .success(function(posts) {
                $scope.posts = posts;
            });
        }

        function createPost(post) {
            console.log(post);
            $http
            .post("/api/blogpost",post)
            .success(getAllPosts);
        }
    }
})();

index.html

<!DOCTYPE html>
<html lang="en" ng-app="BlogApp">
<head>
    <link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet"/>
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.7/angular.min.js"></script>
    <script src="app.js"></script>
    <title>Title</title>
</head>
<body>
    <div class="container" ng-controller="BlogController">
        <h1>Blog</h1>
            <input ng-model="post.title" class="form-control" placeholder="title"/>
            <textarea ng-model="post.body" class="form-control" placeholder="body"></textarea>
            <button ng-click="createPost(post)" class="btn btn-primary btn-block">Post</button>
            <button ng-click="updatePost(post)" class="btn btn-success btn-block">Update</button>

            <div ng-repeat="post in posts">
                <h2>
                    <a ng-click="titleDetails(post)">{{ post.title }} </a>
                    <a ng-click="editPost(post._id)" class="pull-right"><span class="glyphicon glyphicon-pencil"></span></a>
                    <a ng-click="deletePost(post._id)" class="pull-right"><span class = "glyphicon glyphicon-remove"></span></a>
                </h2>
                <em>{{post.posted}}</em>
                <p>{{post.body}}</p>
            </div>
    </div>
</body>
</html>

titleDetails.html:

<!DOCTYPE html>
<html lang="en" ng-app="BlogApp">
<head>
    <link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet"/>
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.7/angular.min.js"></script>
    <script src="app.js"></script>
    <title>Title</title>
</head>
<body> 
    <div class="container" ng-controller="BlogController">
        <h1>Blog</h1>
            <div>
                <h2>
                    <a>{{ postDetail.title }} </a>
                </h2>
                    <em>{{postDetail.posted}}</em>
                    <p>{{postDetail.body}}</p>
            </div>
    </div> 
</body>
</html>

index.html 中的控制台错误:

angular.js:13708 Error: [$location:nobase] http://errors.angularjs.org/1.5.7/$location/nobase
    at angular.js:38
    at sf.$get (angular.js:13384)
    at Object.invoke (angular.js:4709)
    at angular.js:4508
    at d (angular.js:4655)
    at e (angular.js:4679)
    at Object.invoke (angular.js:4701)
    at R.instance (angular.js:10234)
    at m (angular.js:9147)
    at g (angular.js:8510)

最佳答案

Angular 有 3 个路由操作:

  • Hashbang 模式
  • HTML5 模式
  • HTML5 模式下的 Hashbang

您可以配置:$locationProvider.html5Mode(true).hashPrefix('!');

检查documentation

关于javascript - AngularJS $location 目录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42872162/

相关文章:

javascript - 当另一个事件更改我的输入值时的事件监听器

javascript - 如何在不触及 index.html 的情况下将外部 javascript 标签添加到 Ember JS 应用程序?

html - 表格列宽拉伸(stretch)

jquery - 在 AngularJS 中有条件地调用函数

angularjs - 在 AngularJS 中加载图像目录

javascript - 如何从 window.selection() 获取文本样式?

javascript - 准确跟踪由 $q.defer 调用的 Angular 的事件/完成 promise

angularjs - 是否有更紧凑的方法在函数内使用 AngularJS 返回延迟?

javascript - Backbone.js 全局错误处理

html - 动画背景效果