ui选择占位符文本并禁用搜索

时间:2015-03-31 17:42:22

标签: angularjs angular-ui-select

我正在使用角度ui-select Selectize Theme。我想禁用搜索,但希望显示占位符文本,以便用户知道该选择字段的用途。 我尝试将selectize / match.tpl.html修改为

<div ng-hide=\"($select.open || $select.isEmpty())\" class=\"ui-select-match\" ng-transclude=\"\">{{$select.placeholder}}</div>

但这总是以

为借口
<div ng-hide="($select.open || $select.isEmpty())" class="ui-select-match ng-hide" ng-transclude="" placeholder="Select or search a country in the list..."><span class="ng-binding ng-scope"></span></div>

如何修改模板以在Span / Div中显示占位符文本并默认显示。 或者有没有更好的方法来禁用搜索并显示占位符文本?

Example Plunker

我已经为此创建了一个包装器指令,并在

下面的链接行内修改
  angular.element(angular.element($element[0])).find('span').text($scope.placeholder)

再次在控制器中

 angular.element(angular.element($element[0])).find('span').text(scope.name)

2 个答案:

答案 0 :(得分:0)

我围绕这个编写了一个包装器指令,更新了匹配模板,如下所示,并使用search-enable = false

$templateCache.put("selectize/match.tpl.html","<div class=\"ui-select-match\" ng-transclude=\"\"></div>");

在包装器指令中使用“link”我用palceholder文本更新上面的模板

  angular.element(angular.element($element[0])).find('span').text($scope.placeholder)

在包装器指令中使用controller,更新选定的字符串

 angular.element(angular.element($element[0])).find('span').text(scope.name)

答案 1 :(得分:0)

我修改了select.tpl.html,如下所示

$templateCache.put("selectize/select.tpl.html","<div class=\"selectize-control single\"><div class=\"selectize-input\" ng-class=\"{\'focus\': $select.open, \'disabled\': $select.disabled, \'selectize-focus\' : $select.focus}\" ng-click=\"$select.activate()\"><div class=\"ui-select-match\"></div><div class=\"ui-select-placeholder\" ng-hide=\"!$select.isEmpty()\">{{$select.placeholder}}</div><input type=\"text\" autocomplete=\"off\"  tabindex=\"-1\" class=\"ui-select-search ui-select-toggle\" ng-click=\"$select.toggle($event)\" placeholder=\"{{$select.placeholder}}\" readonly ng-model=\"$select.search\" ng-hide=\"!$select.searchEnabled || ($select.selected && !$select.open)\" ng-disabled=\"$select.disabled\"></div><div class=\"ui-select-choices\"></div></div>");}]);

当选择为空时,在占位符中添加div。否则它将被隐藏