angularjs – Angular UI-Router ui-sref忽略一些元素

前端之家收集整理的这篇文章主要介绍了angularjs – Angular UI-Router ui-sref忽略一些元素前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我对uiSref指令有一个有趣的问题,我无法在网络上的任何地方找到解决方案(无论如何都是优雅的解决方案).基本上,我要求客户端能够单击资源表中的行并转到该资源的编辑视图.通常,uiSref指令工作得很漂亮,但问题在于我在最后一个< td>中有一个Bootstrap下拉列表.表中包含一堆快速操作. HTML看起来像这样:
<table class="table table-bordedered table-hover">
  <thead>
    <tr>
      <td>Name</td>
      <td>Actions</td>
    </tr>
  </thead>
  <tbody>
    <tr ng-repeat="resource in resources" ui-sref="edit({id: resource.id})">
      <td ng-bind="resource.name"></td>
      <td class="actions-column">
        <div class="btn btn-xs btn-default" data-toggle="dropdown">
          <i class="fa fa-cog"></i>
        </div>
        <ul class="dropdown-menu pull-right">
          <li>
            <a href="javascript:void(0)" ng-click="doSomethingCrazy(resource)">SOMETHING CRAZY</a>
          </li>
        </ul>
      </td>
    </tr>
  </tbody>
</table>

问题是,当我单击actions列中的按钮时,uiSref会覆盖下拉列表的默认操作,并将我带到编辑页面.现在你可能会问自己“这很容易,为什么你不能阻止事件的传播!?”……不起作用.当我将其添加到actions列时:

<td class="actions-column" ng-click="$event.stopPropagation()">

它会杀死下拉菜单功能,但不显示任何内容.现在我有一个解决方法,我在< tr>上定义了ngClick.然后根据点击的元素解密状态应该去的元素,如下所示:

<tr ng-repeat="resource in resources" ng-click="goToEdit(resource,$event)">

JS看起来像这样:

scope.goToEdit = function(resource,event) {
  // if the event.target has parent '.actions-column' or is that column,do nothing else
  // invoke $state.go('edit',{id: resource.id})
}

我讨厌它,我有很多像这样的列表视图.所有我正在寻找的是一个优雅和可移植的解决方案,希望通过UI路由器本身工作,如$event.stopPropagation()(虽然我已经戳穿了UI路由器源,似乎找不到一个可行的替代方案).基本上我想吃蛋糕也吃.无论如何,看到SO社区可以提出什么,或者我要求的东西目前是不可能的,这将是有趣的.谢谢!

我知道了!在查看UI路由器源代码时,如果在uiSref所在的元素上填充了目标属性,则会忽略click事件.它可能不是世界上最美丽的东西,但它肯定比我以前做的更容易.

注意:这仅适用于您使用整个jQuery库,而不是jQLite

所以我写了这个指令:

app.directive('uiSrefIgnore',function() {
  return {
    restrict: 'A',link: function(scope,elem,attrs) {
      elem.on('click',function(e) {
        // Find the ui sref parent
        var uiSref = elem.parents('[ui-sref]').first();
        // Set the target attribute so that the click event is ignored
        uiSref.attr({
          target: 'true'
        });
        // Function to remove the target attribute pushed to the bottom
        // of the event loop. This allows for a digest cycle to be run
        // and the uiSref element will be evaluated while the attribute
        // is populated
        setTimeout(function() {
          uiSref.attr({
            target: null
          });
        },0);
      });
    }
  };
});

这样,每当我想忽略uiSref指令的javascript事件时,我只需将其添加到html:

<tr ui-sref="edit">
  <!-- any other elements -->
  <td ui-sref-ignore>The element I care about</td>
</tr>

繁荣!让我知道你们对这个问题的看法.

猜你在找的Angularjs相关文章