Angular Material的md-nav-bar与ui-router

时间:2016-10-30 04:05:09

标签: javascript html angularjs angular-ui-router angular-material

我正在玩角度材料 ui-router
这是 pen

HTML

<md-nav-bar md-selected-nav-item="'browse'" nav-bar-aria-label="navigation links">
  <md-nav-item md-nav-sref="projects.browse" name="browse">Browse</md-nav-item>
  <md-nav-item md-nav-sref="projects.settings" name="settings">Settings</md-nav-item>
</md-nav-bar>

问题是,尽管md-selected-nav-item="'browse'"允许应用默认激活browse标签,但它未显示ui-router状态:projects.browse
但是,当我们点击它显示的browse标签时。问题是当页面加载时路由功能无效。

js

$stateProvider
  .state({
            name: "projects",
            url: "/projects",
            template: "<h4>this is project page:</h4> <ui-view></ui-view>"
  })
  .state({
            name: "projects.browse",
            url: "/browse",
            template: "<h3>Browse</h4>"
  })
  .state({
            name: "projects.settings",
            url: "/settings",
            template: "<h3>Settings</h4>"
  });

显然我错过了一些东西。
pen

1 个答案:

答案 0 :(得分:4)

阅读docs似乎md-nav-sref已激活点击标签:

enter image description here

这是一个解决方法 - CodePen

标记

<div ng-cloak ng-app="MyApp" ng-controller="MyController">
  <!-- Navbar -->
  <md-content class="md-padding">
    <md-nav-bar md-selected-nav-item="selectedItem" nav-bar-aria-label="navigation links">
      <md-nav-item md-nav-sref="projects.browse" name="browse">Browse</md-nav-item>
      <md-nav-item md-nav-sref="projects.settings" name="settings">Settings</md-nav-item>
    </md-nav-bar>

    <ui-view></ui-view>
  </md-content>
</div>

JS

angular.module('MyApp', ['ui.router', 'ngMaterial', 'ngMessages']);

angular.module('MyApp')

.config(function($stateProvider, $urlRouterProvider, $urlMatcherFactoryProvider) {

    // for handling trailing slashes
    $urlMatcherFactoryProvider.strictMode(false);

    // for any unmatched url, redirect to the default.
  // NOTE: I can't adjust this value to fix this issue.
  //       setting this to "/projects/browse" may fix this issue,
  //       but I cant go with that.
    $urlRouterProvider.otherwise("/projects");

  $stateProvider
  .state({
            name: "projects",
            url: "/projects",
      template: "<h1>this is project page:</h1> Eventhough the browse tab is selected, content of it isn't showing when the page reloads. <ui-view></ui-view>"
  })
  .state({
            name: "projects.browse",
            url: "/browse",
      template: "<h3>Browse</h4>"
  })
  .state({
            name: "projects.settings",
            url: "/settings",
      template: "<h3>Settings</h4>"
  });

})

.controller("MyController", function ($scope, $state) {
  var initTab = "browse";
  $scope.selectedItem = initTab;
  $state.go("projects." + initTab);
})