如何在指令之外传递'范围'参数?我需要在其他一些组件中使用它。
我的代码:
(function () {
angular.module('dmv.shared.components').
directive('doImportPackage', ['Package', function (Package) {
return {
restrict: 'A',
scope: {
onStart: '<',
onFinish: '<',
onError: '<'},
link: function (scope, element, attributes) {
}
tnx !!
您可以通过控制器执行此操作。由于AngularJS在2向数据绑定原理中起作用,因此您分配的这些变量已经从您引用的位置进行更新,并且您也可以将其与其他指令一起使用。例如,我认为您使用您的指令如下:
<do-import-package
on-start="myCtrl.onStart"
on-finish="myCtrl.onFinish"
on-error="myCtrl.onError">
</do-import-package>
您在myctrl控制器中具有以下相应变量:
this.onStart = some value;
this.onFinish = some value;
this.onErrod = some value;
在正常条件下,您可以将其他指令的属性绑定到这些值,它们将在2向上更新。例如,如果您使用以下指令,则两个指令均应使用相同的值更新。
<other-directive
on-start="myCtrl.onStart"
on-finish="myCtrl.onFinish"
on-error="myCtrl.onError">
</other-directive>