繁体   English   中英

如果$ invalid禁用按钮角度

[英]disable button angular if $invalid

我无法弄清楚为什么以下代码无法正常工作。 我正在关注此处的答案以及其他各种教程/答案,但是当字段为空时,该按钮不会处于禁用状态。

<h3>Add address</h3>
<div ng-include="'app/views/partials/form.html'"></div>
<button ng-click="ctrl.cancelAddress()">Cancel</button>
<button ng-disabled="addressForm.$invalid" class="save-btn" ng-click="ctrl.saveAddress(ctrl.name, ctrl.address, ctrl.country)">Save</button>

app / views / partials / form.html

<form name="addressForm" novalidate>
    <input ng-model="ctrl.name" type="text" name="RecipientName" required>
    <p ng-show="addressForm.RecipientName.$error.required">Username is required</p>

    <input ng-model="ctrl.address" type="text" name="AddressLineOne" placeholder="Address" required>
    <p ng-show="addressForm.RecipientName.$error.required">Address is required</p>

    <select ng-model="ctrl.country">
       <option ng-repeat="country in ctrl.countries" value="{{country.name}}">{{country.name}}</option>
       <p ng-show="addressForm.addressCountry.$error.required">Username is required</p>
    </select>
</form>

我将它们作为更方便访问的答案。

addressForm在您引用它的(外部)范围中不存在。 它只能在存在的<form>元素内引用。 您需要将这些控件放在<form>内的任何位置,以使其起作用。

您的表单是否知道您是否正在编辑? 因为这样的话,您可以将这些按钮移到表单中,然后使用ng-if="ctrl.isEditing" 当然, ctrl.isEditing将替换为您知道的任何可用编辑方法。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM