你可以用ui-sref使用ng-click吗?

Ada*_*ner 19 angularjs angular-ui-router

我可以这样做吗?

<button ng-click='vm.foo()' ui-sref='state'>test</button>
Run Code Online (Sandbox Code Playgroud)

Ada*_*ner 25

是.ngClick将运行,然后你将过渡到你的州.

演示(由于marioosh更新和工作)

但是,如果你有一个$event.preventDefault()in ngClick,它将不会转换到你的状态.

完整的代码示例

<!DOCTYPE html>
<html ng-app='app'>

  <head>
    <script data-require="angular.js@1.4.3" data-semver="1.4.3" src="https://code.angularjs.org/1.4.3/angular.js"></script>
    <script data-require="ui-router@*" data-semver="0.2.15" src="//rawgit.com/angular-ui/ui-router/0.2.15/release/angular-ui-router.js"></script>
    <link rel="stylesheet" href="style.css" />
    <script src="script.js"></script>
  </head>

  <body ng-controller='MainController as vm'>
    <ul>
      <li><a ui-sref='home'>home</a></li>
      <li><a ui-sref='one' ng-click='vm.test()'>one</a></li>
      <li><a ui-sref='two'>two</a></li>
    </ul>
    <div ui-view></div>
  </body>

</html>

angular
  .module('app', ['ui.router'])
  .config(config)
  .controller('MainController', MainController)
;

function config($locationProvider, $urlRouterProvider, $stateProvider) {
  $urlRouterProvider.otherwise('/');
  $stateProvider
    .state('home', {
      url: '/',
      templateUrl: 'home.html'
    })
    .state('one', {
      url: '/one',
      templateUrl: 'one.html'
    })
    .state('two', {
      url: '/two',
      templateUrl: 'two.html'
    })
  ;
}

function MainController($scope) {
  var vm = this;
  vm.test = function() {
    alert('test');
    console.log('test');
  }
}
Run Code Online (Sandbox Code Playgroud)

  • 但你的例子不起作用......? (12认同)
  • @AndrewTobilko `$event.preventDefault()` 对我来说似乎是 [working](http://plnkr.co/edit/H0mQycIWYacObnJ3woOd?p=preview)。 (2认同)