这不是一件很难的事,但我无法弄清楚如何做到最好。
我有一个父指令,像这样:
directive('editableFieldset', function () { return { restrict: 'E', scope: { model: '=' }, replace: true, transclude: true, template: ' <div class="editable-fieldset" ng-click="edit()"> <div ng-transclude></div> ... </div>', controller: ['$scope', function ($scope) { $scope.edit = -> $scope.editing = true // ... ] }; });
和一个子指令:
.directive('editableString', function () { return { restrict: 'E', replace: true, template: function (element, attrs) { '<div> <label>' + attrs.label + '</label> <p>{{ model.' + attrs.field + ' }}</p> ... </div>' }, require: '^editableFieldset' }; });
如何从子指令轻松访问父指令的model和editing属性?在我的链接函数中,我可以访问父级作用域-我应该$watch用来观察这些属性吗?
model
editing
$watch
放在一起,我想拥有的是:
<editable-fieldset model="myModel"> <editable-string label="Some Property" field="property"></editable-string> <editable-string label="Some Property" field="property"></editable-string> </editable-fieldset>
这个想法是默认情况下显示一组字段。如果单击,它们将成为输入并可进行编辑。
从这篇SO帖子中汲取灵感,我在这个笨拙的人中有一个可行的解决方案。
我不得不改变很多。我还选择了一个独立的作用域,editableString因为将正确的值绑定到模板更容易。否则,您将不得不使用compile或其他方法(例如$transclude服务)。
editableString
compile
$transclude
结果如下:
JS:
var myApp = angular.module('myApp', []); myApp.controller('Ctrl', function($scope) { $scope.myModel = { property1: 'hello1', property2: 'hello2' } }); myApp.directive('editableFieldset', function () { return { restrict: 'E', scope: { model: '=' }, transclude: true, replace: true, template: '<div class="editable-fieldset" ng-click="edit()"><div ng-transclude></div></div>', link: function(scope, element) { scope.edit = function() { scope.editing = true; } }, controller: ['$scope', function($scope) { this.getModel = function() { return $scope.model; } }] }; }); myApp.directive('editableString', function () { return { restrict: 'E', replace: true, scope: { label: '@', field: '@' }, template: '<div><label>{{ label }}</label><p>{{ model[field] }}</p></div>', require: '^editableFieldset', link: function(scope, element, attrs, ctrl) { scope.model = ctrl.getModel(); } }; });
HTML:
<body ng-controller="Ctrl"> <h1>Hello Plunker!</h1> <editable-fieldset model="myModel"> <editable-string label="Some Property1:" field="property1"></editable-string> <editable-string label="Some Property2:" field="property2"></editable-string> </editable-fieldset> </body>