0

这是指令:

<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'"部分。

这里有什么问题?

谢谢。

4

0 回答 0