3

いくつかの動的プロパティを持つテンプレートに基づいて、フォームを動的に生成しようとしています。

近づいてきましたが、コンテナ要素の取得に問題があります。

これはディレクティブです:

myApp.directive('myDirective', function () {
    return {
    template: "<div> <label>{{Field.Name}} <div id='{{Field.Name}}_Container'></div> </label></div>",
    replace: true,
    restrict: 'AE',
    scope: {
        Field: "=fieldInfo",
        FieldData:"="
    },
    link: function (scope, element, attr) {
        var input = "<input type='" + scope.Field.Type + "' data-ng-model='FieldData[" + scope.Field.Name + "]' />";
        var inputEl = angular.element(input);
        var container = angular.element("#" + scope.Field.Name + "_Container"); // Doesn't work
        container.append(inputEl);
    }
}

});

コントローラ:

function MyCtrl($scope) {
    $scope.Fields = [
      { Name: "field1", Type: "text", Data:null },
      { Name: "field2", Type: "number", Data:null }
    ];

     $scope.FieldData = {}; //{fieldname: fielddata}
}

HTML:

<div ng-controller="MyCtrl">
      <my-directive data-ng-repeat="field in Fields" data-field-info="field">
    </my-directive>
</div>

基本的に、フィールド記述子オブジェクトがあり、それに基づいてフォームを生成する必要があります。コンテナー オブジェクトを参照する方法がよくわかりません。リンクする前にテンプレートをコンパイルする必要がありますか?

また、問題があれば、実際に templateUrl を使用しています。

そして、ここにフィドルがあります。

4

1 に答える 1

5

compiletohtmlテンプレートを$compileを使用する必要があります。また、関数で使用elementして、テンプレートlinkの外部にアクセスすることもできます。div

var myApp = angular.module('myApp', []);

myApp.directive('myDirective', function ($compile) {
    return {
        template: "<div> <label>{{Field.Name}} <div id='{{Field.Name}}_Container'></div> </label></div>",
        replace: true,
        restrict: 'AE',
        scope: {
            Field: "=fieldInfo",
            FieldData:"="
        },
        link: function (scope, element, attr) {
            var input = "<input type='" + scope.Field.Type + "' data-ng-model='FieldData[" + scope.Field.Name + "]' />";
            var html = $compile(input)(scope);
            element.find('div').append(html);
        }
    }
});

jsfiddleを参照してください。

于 2013-01-09T05:48:55.793 に答える