5

AngularJS + Ajax 機能を備えた Angular-UI Select2 による双方向データバインディング。

Select2 ドロップダウン Ajax 動作を一般的な方法で実装するためのディレクティブを作成しました:- (formatResult、呼び出す formatSelection メソッド、および url を取得するために必要な属性はほとんどありません)。

私の問題は、「編集モード」で値をロードする方法です。ドロップダウンから選択された値は formatselection メソッドで受信されますが、画面のロード中に、バインドされているのと同じ値からドロップダウンをロードしたいと考えています。例:-

    <input type="hidden" for="part" class="bigdrop" style="width: 250px" formatresult="partFormatResult" formatselection="partFormatSelection" aurl="/api/Part" search-drop-down ui-select2="configPartSelect2" ng-model="product.SalesPart" data-placeholder="Select Part" ng-change="onPartSelect();" />

    Directive Code

    One23SRCApp.directive('searchDropDown', ['$http', function (http) {
        return function (scope, elm, attrs) {
            var raw = elm[0];
            var fetchFuncName = "fetch" + attrs["uiSelect2"];
            console.log("Directive load pat  " + scope[attrs["ngModel"]]);
            scope[fetchFuncName] = function (queryParams) {
                var result = http.get(queryParams.url, queryParams.data).success(queryParams.success);
                result.abort = function () {
                    return null;
                };
                return result;
            };


            scope[attrs["uiSelect2"]] = {
                minimumInputLength: 3,
              initSelection: scope[attrs["initselection"]],
                ajax: {
                    url: attrs["aurl"],
                    data: function (term, page) {
                            return { params: { isStockable: true, query: term, pageNo: page, pageSize: 20 } };
                    },
                    dataType: 'json',
                    quietMillis: 100,
                    transport: scope[fetchFuncName],
                    results: function (data, page) {
                        var more = (page * 20) <= data.length; // whether or not there are more results available
                        return { results: data, more: more };
                    }
                },
                formatResult: scope[attrs["formatresult"]],
                formatSelection: scope[attrs["formatselection"]],
                dropdownCssClass: "bigdrop" // apply css that makes the dropdown taller
            };

            return { bind: attrs["ngModel"] };
        };

    }]);

//inside controller-
after loading of data
   $("#partDD").select2("val", product.SalesPart);
//$scope.partInitSelection definition.
    $scope.partInitSelection = function (element, callback) {
        if (! $scope.PartList) {
            $scope.PartList = [$scope.product.SalesPart];
        } else {
            $scope.PartList.push($scope.product.SalesPart);
        }
        callback($scope.product.SalesPart);
    };

}
4

1 に答える 1

0

最終的に修正しました:-構成オブジェクトをscope [attrs ["uiSelect2"]]に保持したため、データをロードするたびに、上記の構成オブジェクトの.ajax.dataメソッドを呼び出しました。

scope[attrs["uiSelect2"]].ajax.results(product.SalesPart.text, 1);
于 2012-11-08T15:08:29.793 に答える