簡體   English   中英

角度ui路由器,使用不同的控制器和模板滾動到狀態更改的下一步

[英]Angular ui-router, scroll to next step on state change with different controller and template

我在應用程序中使用UI-router,並且當URL /狀態更改時,我想將一個簡單的“ scrollTo”作為錨點。 我想在狀態更改時加載新的控制器和模板。 我正在使用ng-boilerplate。

索引文件

  <div class="collapse navbar-collapse" collapse="menuCollapsed" ng-click="collapse()">
            <ul class="nav navbar-nav navbar-right nav-link">
              <li ui-sref-active="active">
                <a href ui-sref="home">
                  <i class="fa fa-home"></i>
                  Home
                </a>
              </li>
              <li ui-sref-active="active">
                <a href ui-sref="service">
                  <i class="fa fa-info-circle"></i>
                  Service
                </a>
              </li>
              <li ui-sref-active="active">
                <a href ui-sref="portfolio">
                  <i class="fa fa-briefcase"></i>
                  Portfolio
                </a>
              </li>
              <li ui-sref-active="active">
                <a href ui-sref="team">
                  <i class="fa fa-users"></i>
                  Team
                </a>
              </li>
              <li ui-sref-active="active">
                <a href ui-sref="testimonial">
                  <i class="fa fa-comments"></i>
                  Testimonial
                </a>
              </li>
              <li ui-sref-active="active">
                <a href ui-sref="contact">
                  <i class="fa fa-envelope"></i>
                  Contact
                </a>
              </li>
            </ul>
          </div>
        </div>
      </div>
    <div ui-view="main">
    </div>

主頁模板和js

<div class="banner">
    <div class="intro-body">
        <h1>CREATIVE DIGITAL<br> SOLOUTIONS</h1>
        <p>Proin iaculis consequat sem cure.</p>
        <a href ui-sref="portfolio" class="btn btn-success">VIEW PORTFOLIO</a>
    </div>
</div>


angular.module( 'ngBoilerplate.home', [
  'ui.router',
  'plusOne'
])

/**
 * Each section or module of the site can also have its own routes. AngularJS
 * will handle ensuring they are all available at run-time, but splitting it
 * this way makes each module more "self-contained".
 */
.config(function config( $stateProvider ) {
  $stateProvider.state( 'home', {
    url: '/home',
    views: {
      "main": {
        controller: 'HomeCtrl',
        templateUrl: 'home/home.tpl.html'
      }
    },
    data:{ pageTitle: 'Home' }
  });
})

/**
 * And of course we define a controller for our route.
 */
.controller( 'HomeCtrl', function HomeController( $scope ) {
})

;

服務模板和Js

<div class="container" id="service">
    <div class="service-intro">
        <h2>Why to choose company?</h2>
</div>
</div>

angular.module( 'service', [
    'ui.router'
])
.config(function config( $stateProvider ) {
    $stateProvider.state( 'service', {
        url: '/service',
        views: {
            "main": {
                controller: 'ServiceCtrl',
                templateUrl: 'service/service.tpl.html'
            }
        },
        data:{ pageTitle: 'service' }
    });
})
.controller( 'ServiceCtrl', function HomeController( $scope ) {
})

;

APP JS

angular.module( 'ngBoilerplate', [
  'templates-app',
  'templates-common',
  'ngBoilerplate.home',
  'ngBoilerplate.about',
  'service',
  'portfolio',
  'team',
  'testimonial',
  'contact-us',
  'ui.router',
  'ngAnimate'
])

.config( function myAppConfig ( $stateProvider, $urlRouterProvider ) {
  $urlRouterProvider.otherwise( '/home' );
})

.run( function run () {
})

.controller( 'AppCtrl', function AppCtrl ( $scope, $location,$rootScope ) {
      $rootScope.$on('$stateChangeStart', function () {
        $scope.slide = $scope.slide || 'slide-left';
      });
      $scope.collapse = function() {
        $scope.menuCollapsed = true;
      };
  $scope.$on('$stateChangeSuccess', function(event, toState, toParams, fromState, fromParams){
    if ( angular.isDefined( toState.data.pageTitle ) ) {
      $scope.pageTitle = toState.data.pageTitle + ' | Teknuk' ;
    }
  });
})

;

因此,當您輸入頁面時,URL為domain.com/home

當您單擊第一個按鈕時,我希望我的控制器代碼將URL更改為domain.com/#/service並向下滾動到“服務” div,並且控制器+模板已更新。

理想情況下,當用戶單擊“后退”按鈕時,它將恢復為第一個URL並滾動回到首頁。

有人知道該怎么做嗎?

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM