ui 路由未使用 Rails 呈现

ui routing not rendering with Rails

我一直为这个问题发疯。我正在开发一个应用程序,它有 rails 后端和 angularjs 前端。本教程告诉我使用 ui 路由来呈现部分模板。正如我所做的一些测试,除了路由之外,一切似乎都工作正常。如果有人可以找到此代码中的错误,请告诉我。我对 javascript 很陌生,正在努力寻找问题所在。

我正在学习的教程就是这个。 https://thinkster.io/angular-rails/

application.html.erb

 <!DOCTYPE html>
<html>
<head>
  <title>FlapperNews</title>
  <!--<link href="//maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css" rel="stylesheet">-->

  <!--<script src="//ajax.googleapis.com/ajax/libs/angularjs/1.2.19/angular.min.js"></script>-->
  <!--<script src="//cdnjs.cloudflare.com/ajax/libs/angular-ui-router/0.2.10/angular-ui-router.js"></script>-->
  <%= stylesheet_link_tag    'application', media: 'all' %>
  <%= javascript_include_tag 'application' %>
  <%= csrf_meta_tags %>
</head>
<body ng-app="flapperNews">
<div class="row">


    <ui-view></ui-view>
  </div>
</div>





</body>
</html>

app.js

// templateUrl: '/assets/templates/_home.html',

angular.module('flapperNews', ['ui.router', 'templates'])
    //Provider
    .config([
        '$stateProvider',
        '$urlRouterProvider',
        function($stateProvider, $urlRouterProvider) {
            $stateProvider
                .state('home', {
                    url: '/home',
                    templateUrl: '_home.html',
                    controller: 'MainCtrl',
                    resolve: {
                        postPromise: ['posts', function(posts){
                            return posts.getAll();
                        }]
                    }
                })
                .state('posts', {
                    url: '/posts/{id}',
                    templateUrl: '_posts.html',
                    controller: 'PostsCtrl',
                    resolve: {
                        postPromise: ['posts', function(posts){
                            return posts.getAll();
                        }]
                    }
                })

            $urlRouterProvider.otherwise('home');
        }])

_home.html

<script type="text/ng-template" id="/home.html">
    <div class="page-header">
        <h1>Flapper News</h1>
    </div>

    <div ng-repeat="post in posts | orderBy:'-upvotes'">
      <span class="glyphicon glyphicon-thumbs-up"
            ng-click="incrementUpvotes(post)"></span>
        {{post.upvotes}}
      <span style="font-size:20px; margin-left:10px;">
        <a ng-show="post.link" href="{{post.link}}">
            {{post.title}}
        </a>
        <span ng-hide="post.link">
          {{post.title}}
        </span>
      </span>
      <span>
        <a href="#/posts/{{$index}}">Comments</a>
      </span>
    </div>

    <form ng-submit="addPost()"
          style="margin-top:30px;">
        <h3>Add a new post</h3>

        <div class="form-group">
            <input type="text"
                   class="form-control"
                   placeholder="Title"
                   ng-model="title">
        </div>
        <div class="form-group">
            <input type="text"
                   class="form-control"
                   placeholder="Link"
                   ng-model="link">
        </div>
        <button type="submit" class="btn btn-primary">Post</button>
    </form>
</script>

mainCtrl.js

angular.module('flapperNews')
    //Main Controller
    .controller('MainCtrl', [
        '$scope',
        'posts',

        function($scope, posts){
            $scope.posts = posts.posts;
            $scope.addPost = function(){
                if(!$scope.title  || $scope.title == '') { return; }
                posts.create({
                    title: $scope.title,
                    link: $scope.link
                });
                $scope.title = '';
                $scope.link = '';
            };
            $scope.incrementUpvotes = function(post) {
                post.upvotes += 1;
            };

        }])

如果您需要更多信息,请告诉我。谢谢

不确定这是否是您的问题,但在您发布的教程 link 中,他们将模板定义为:

templateUrl: 'home/_home.html',

templateUrl: 'posts/_posts.html',

这可能无济于事,但您可以尝试将 href="#/posts/{{$index}}" 更改为 ui-sref="posts({ id: $index })"" http://angular-ui.github.io/ui-router/site/#/api/ui.router.state.directive:ui-sref

另外,这里有一个模板,您可以用 ui-router 和 Rails 以便宜的价格购买 https://wrapbootstrap.com/theme/angle-bootstrap-admin-app-angularjs-WB04HF123

我遇到了同样的问题。只需从您的模板中删除脚本标签。

检查牙套,解决后没有正确闭合。它应该是 resolve: { postPromise: ['posts', function(posts){ return posts.getAll(); ]}