モデル値に基づいてリンクを無効にしようとしているディレクティブを次に示します。
app.directive('disableable', function($parse){
return {
restrict: 'C',
require: '?ngClick',
link: function (scope, elem, attrs, ngClick) {
if (attrs.disable){
var disable = $parse(attrs.disable);
elem.bind('click', function (e) {
if (disable(scope)){
e.preventDefault();
return false;
}
return true;
});
scope.$watch(disable, function (val) {
if (val){
elem.addClass('disabled');
elem.css('cursor', 'default');
}
else {
elem.removeClass('disabled');
elem.css('cursor', 'pointer');
}
});
}
}
};
});
単純な hrefs または ngClick アクションを使用するかどうかに関係なく、すべてのリンク アクションを無効にできるようにしたいと考えています。preventDefault 呼び出しにより、Href は正常に動作しますが、ngClick を掘り下げて発火を防ぐ方法がわかりません。ngClick が制御できない独自のハンドラーをバインドしているように見えるため、クリックイベントで実行しているバインドが機能していません。何か私にできることはありますか?
jsFiddle: http://jsfiddle.net/KQQD2/2/