angular 表单下拉 select 框中的错误

Bug in angular form drop down select box

我正在处理 angular 表单,需要解决一个错误。

这是问题所在:

1)- Select 类型:值-1

2)- Select 数据 1:所有数据 1

3)- Select 数据 2:所有数据 2

4)- 现在将类型更改为:Value-2(而不是 value-1)。

data-1 和 data-2 的字段应该消失。

5)- 现在 select 类型再次变为 value-1。

现在再次点击 data-1 或 data-2...您会看到一个空的 space 再次。

我不想这里空着space...

相反,它应该回到--选择一个-- 再次...

我附上截图和代码...请看一下。

<form class="addAlert settings_form" ng-submit="createAlert(newAlert)">
            <div class="modal-header">
                <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span
                        aria-hidden="true">×</span></button>
                <h4 class="modal-title" id="myModalLabel">Create a New Model</h4>
            </div>
            <div class="modal-body">
                <div class="form_fieldset">

                    <div class="form_item">
                        <label for="title">Name</label>
                        <input name="title" type="text" class="form-input title" required placeholder="Alert Name" ng-model="newAlert.title">
                        <div class="error"></div>
                    </div>


                    <div class="form_item">
                        <label for="alertformat">Type</label>
                        <select class="form-input alertformat"
                                name="alertformat" ng-model="newAlert.alertType"
                                ng-init="newAlert.alertType='Threshold'">
                            <option value="Threshold" selected>Value-1</option>
                            <option value="Pipeline Failure">Value-2</option>
                        </select>
                    </div>

                    <div class="form_item" ng-if="newAlert.alertType !='Pipeline Failure'">
                        <label for="alertformat">Data-1 </label>
                        <select class="form-input alertformat" name="alertformat"
                                ng-model="newAlert.site" required>
                            <option value="" disabled>-- Choose one --</option>
                            <option ng-value="-1">All Data-1</option>
                            <option ng-repeat="item in assetsData" ng-value="{{item.sitename}}">
                                {{item.sitename}}
                            </option>
                        </select>
                    </div>
                    <div class="form_item" ng-show="newAlert.site" ng-if="newAlert.alertType !='Pipeline Failure'">
                        <label for="alertformat">Data-2</label>
                        <select class="form-input alertformat" name="alertformat" ng-model="newAlert.asset" required>
                            <option value="" disabled>-- Choose one --</option>
                            <option ng-value="-1">All Data-2</option>
                            <option ng-repeat="item in assetsData | filter:newAlert.site" ng-value="{{item.sitename}}">
                                {{item.name}}
                            </option>
                        </select>
                    </div>

                    <div class="form_item">
                        <label for="alertformat">Color</label>
                        <div class="severity">
                        <input type="radio" class="radioBtnClass" name="numbers" value="Red"checked required>
                        <span>Red</span>
                        </input>

                        <input type="radio" class="radioBtnClass" name="numbers" value="Ember">
                        <span>Blue</span>
                        </input>
                         </div>
                    </div>

                    <div class="form_item">


                        <label for="users">Users</label>
                        <div class="user_select">
                              <span ng-repeat="user in userList" style="display:block">
                               <input class="alert_user_class" value="{{user.pk}}" type="checkbox">
                                {{user.email}}
                                  </input>
                              </span>
                        </div>


                    </div>

                </div>
            </div>

        </form>

在 'type' 下拉列表的更改事件中,您需要分配 $scope.newAlert.site = '';$scope.newAlert.asset = '',因为 'Choose one' 选项的值为 Empty String("")。