我正在使用角度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中显示占位符文本并默认显示。 或者有没有更好的方法来禁用搜索并显示占位符文本?
我已经为此创建了一个包装器指令,并在
下面的链接行内修改 angular.element(angular.element($element[0])).find('span').text($scope.placeholder)
再次在控制器中
angular.element(angular.element($element[0])).find('span').text(scope.name)
答案 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。否则它将被隐藏