私はいくつかの複数選択フィールドを使用しており、次のようなクライアント側の検証ui-select
を実装したいと考えています:<form>
<form name="newProjectForm" ng-submit="p.addProject()" class="inputsContainer" novalidate>
<div class="form-group" ng-class="{ 'has-error' : newProjectForm.frameworks.$invalid &&
!newProjectForm.frameworks.$pristine }">
<label>Frameworks</label>
<ui-select name="frameworks" multiple ng-model="p.newProject.frameworks" sortable="true"
close-on-select="false" required>
<ui-select-match placeholder="Select framework...">{{$item.name}}</ui-select-match>
<ui-select-choices repeat="framework.id as framework in p.frameworksList
| propsFilter: {name: $select.search, language: $select.search}">
<div ng-bind-html="framework.name | highlight: $select.search"></div>
<small>
language : <span ng-bind-html="''+framework.language | highlight: $select.search"></span>
</small>
</ui-select-choices>
</ui-select>
<div ng-messages="newProjectForm.frameworks.$error">
<p ng-messages="required">THIS IS REQUIRED</p>
</div>
<p ng-show="newProjectForm.frameworks.$invalid && !newProjectForm.frameworks.$pristine"
class="help-block">Project frameworks is required.</p>
</div>
<!-- ... -->
したがって、問題は、私が試した条件が機能していないことです:
newProjectForm.frameworks.$invalid && !newProjectForm.frameworks.$pristine">
常に偽のようです。
<div ng-messages="newProjectForm.frameworks.$error">
同様に機能しないようです。
ただし、代わりにこの行を使用してテストしました:
<div class="form-group" ng-class="{ 'has-error' : true }">
そしてそれは機能したので、それが機能していない条件だと思います。