6

我有一个用于删除问题的按钮:

<a class="btn-small float-right" data-ng-click="deleteQuestion(question)">
  <i data-ng-class="{true: 'icon-step-backward', false: 'icon-remove'}
  [question.IsDeleted]"></i>
</a>

这是按钮背后的代码:

$scope.deleteQuestion = function (data) {
  if (data.IsDeleted) {
      data.IsDeleted = false;
      for (var i = 0; i < deletedQuestions.length; i++) {
          if (deletedQuestions[i] == data) {
              deletedQuestions.splice(i, 1);
          }
      }  
  } else {
      data.IsDeleted = true;
      if ($.inArray(data, deletedQuestions) === -1) {
          deletedQuestions.push(data);
      }
  }
};

现在,当我按下按钮时,我注意到该功能已被触发两次。第一次删除问题,第二次撤消该操作。

我想要的是一个删除问题的按钮,当您再次单击它时,它会撤消该操作。

我只是想知道我忽略了什么...

编辑这是一个小提琴:http: //jsfiddle.net/rquackenbush/AbWKs/

4

1 回答 1

5

我发现了问题所在。

该链接位于列表中:

<li class="question-item"
   data-app-bind-html="question.template">                        
       <a class="btn-small float-right" data-ng-click="deleteQuestion(question)">
         <i data-ng-class="{true: 'icon-step-backward', false: 'icon-remove'} [question.IsDeleted]">
         </i>
      </a>
<li>

我制作了一个 data-app-bind-html,它在其中绑定了一个 html 部分。这导致链接被绑定两次,这也使它触发了两次。为了解决这个问题,我只是确保指令绑定了 html 部分而不是整个列表项。

于 2013-05-02T07:18:06.603 回答