我怎样才能在angular指令中绑定模型

时间:2014-12-13 09:19:38

标签: javascript angularjs angular-ui-typeahead

我从这里开始使用角度类型

http://pineconellc.github.io/angular-foundation/#/typeahead

我已经制定了一个模板

的指令
<div>
    <input type="text"
           ng-model="user.selected"
           placeholder="Type to select . . ."
           typeahead="item as item.name for item in getData($viewValue)"
           typeahead-loading="loadingData"
           class="form-control">
    <i ng-show="loadingData" class="glyphicon glyphicon-refresh"></i>
</div>

和指令是

return {
    restrict: 'AE',
    replace: true,
    scope: true,
    templateUrl: 'type.html',
    link: function (scope, elem, attrs) {
        var url = window.location.origin + attrs.url;

        scope.getData = function (val) {
            return $http.get(url, {
                params: {
                    q: val
                }
            }).then(function (response) {
                return response.data.map(function (item) {
                    return item;
                });

            });
        };

    }
};

我正在使用这样的

<my-directivw url="api/user"> </my-directive>

现在而不是在模板中编写ng-model="user.selected"。我想要这样的东西

NG-模型=&#34; somevar&#34;

<my-directivw url="api/user" somevar="user.selected"> </my-directive>

我该怎么做

1 个答案:

答案 0 :(得分:1)

它可能对你有所帮助。

HTML代码如下所示。

<div ng-app="app" ng-controller="Ctrl as ctrl">
    <form name="theform">
        <range ng-model="ctrl.theRange" name="myRange" required="true"></range>
    </form>
    <button ng-click="ctrl.theRange = '10/100'">SET</button>
</div>

JavaScript代码如下所示

var app = angular.module("app",[]);

app.controller("Ctrl", function($scope) {
    this.theRange = "1/7";
});

app.directive("range", function() {
    var ID=0;

    function constructRangeString(from, to) {
        var result;
        if( !from && !to ) {
            result = null;
        }
        else if( from ) {
            result = from + "/" + (to || "");
        }
        else if( to ) {
            result = "/" + to;
        }
        return result;
    }

    return {
        require: "ngModel",
        restrict: "E",
        replace: true,
        scope: {
            name: "@"
        },
        template:
            '<div ng-form="{{ subFormName }}">' +
                '<input type="text" ng-model="from" class="range-from" />' +
                '<input type="text" ng-model="to" class="range-to" />' +
            '</div>',
        link: function(scope,elem,attrs,ngModel) {
            var re = /([0-9]+)\/([0-9]+)/;

            if( scope.name ) {
                scope.subFormName = scope.name;
            }
            else {
                scope.subFormName = "_range" + ID;
                ID++;
            }

            ngModel.$render = function() {
                var result, from, to;
                result = re.exec(ngModel.$viewValue);
                if( result ) {
                    from = parseInt(result[1]);
                    to = parseInt(result[2]);
                }
                scope.from = from;
                scope.to = to;
            };

            scope.$watch("from", function(newval) {
                var result = constructRangeString(newval, scope.to);
                ngModel.$setViewValue(result);
            });
            scope.$watch("to", function(newval) {
                var result = constructRangeString(scope.from, newval);
                ngModel.$setViewValue(result);
            });
        }
    };
});