我做了一些指令以使表單字段爲無效。我遇到的唯一障礙是試圖將屬性值「評估」爲真或假,因此我可以打開或關閉彈出窗口。我是一個角色新手(只是學習),但做了一些研究,似乎使用$ scope.watch是使用的東西(也從看ng-show和ng-hide代碼)。所以,一切工作都是親愛的,直到我試圖從$ scope.watch中調用element.triggerHandler()並使用bootstrap.ui。
這裏是我的指令:
app.directive('tooltipTriggerOn', ['$log', function($log) {
function link(scope, element, attrs) {
scope.$watch(attrs.tooltipShow, function(val) {
if (val) {
$log.info('trigger openPopup');
} else {
$log.info('trigger closePopup');
}
//if (val) element.triggerHandler('openPopup');
//else element.triggerHandler('closePopup');
});
}
return {
restrict: 'A',
link: link
};
}]);
的if/else語句註釋掉,使沒有問題的應用程序運行。如果我啓用這些行,我會收到javascript錯誤:
Error: [$rootScope:inprog] $digest already in progress
Error: a.$apply(...) is not a function
但是爲什麼?當我不使用ui.bootstrap時,這個小方案工作正常。所以:
- 是否有一個使用範圍的技巧$ watch在我的指令並沒有得到錯誤?
- 是否有不同的方式來'評估'指令屬性而不使用範圍$ watch?
- 這個錯誤爲什麼會發生?
這裏是plunkrs:
這一個展示與bootstrap.ui問題,只是取消註釋if語句作爲問題描述的犯罪。
這一個演示$ scope.watch沒有bootstrap.ui
任何幫助表示讚賞工作!
邁克 -
謝謝,我也讀了SO問題,但它似乎並不相關。我現在看到,雖然我仍然有點困惑,爲什麼錯誤甚至發生,爲什麼$超時修復它(除了只是說它延遲到下一個摘要週期 - 無論是什麼事情的宏偉計劃)。希望事情變得更清晰,因爲我繼續使用角度。謝謝! – mikew
我並不完全理解這些細節,但正如我在摘要循環中所瞭解的那樣,角度檢查模型中已更改的所有值,並相應地更新視圖/ DOM。如果在那段時間內對模型做了進一步的修改(因爲它可能會影響部分視圖尚未更新並使事情不一致),所以它們必須推遲到棱角消解了所有內容。 – towr