这是指令:
<a ng-if="field.bindingType == 'options'">
<select ng-model="field.value" {{html}} >
<option ng-repeat="(k,v) in field.options" value="{{k}}">{{v}}</option>
</select>
</a>
<a ng-if="field.bindingType != 'options'">
<a ng-if="['text','ntext','nvarchar','varchar'].indexOf(field.type) > -1">
<textarea ng-model="field.value" {{html}} ></textarea>
</a>
<a ng-if="['double','float','int'].indexOf(field.type) > -1">
<input type="number" ng-model="field.value" {{html}} />
</a>
<a ng-if="field.type == 'bit'">
<input type="checkbox" ng-model="field.value" {{html}} />
</a>
<a ng-if="field.type == 'date'">
<input type="date" ng-model="field.value" {{html}} />
</a>
<a ng-if="field.type == 'time'">
<input type="time" ng-model="field.value" {{html}} />
</a>
<a ng-if="field.type == 'datetime'">
<input type="datetime-local" ng-model="field.value" {{html}} />
</a>
</a>
出于某种原因,当field.bindingType是 'options' 并因此通过第一个ng-if 时,它仍然可以通过第二个ng-if(bindingType 不是 'options')。显然,这是不可能的,但它一直在发生。
这仅在字段时发生。但是,type 匹配内部 ng-if 条件之一。就好像它忽略了指令的ng-if="field.bindingType != 'options'"部分。
这里有什么问题?
谢谢。