Reputation: 4130
First, I've looked through other questions and not found an answer.
I have a custom directive with a two attributes: multiValue
and ngModel
. Both of these values are represented in the controller as $scope.multiValue
and $scope.ngModel
.
The behavior of the directive changes based on the value of $scope.ngModel
. In both cases, the directive creates an input and an image:
<input id="{{controlId}}" name="{{controlId}}" placeholder="Select Value(s)"
class="k-textbox" type="text" ng-model="ngModel" />
<img ng-src="/img/X.png" ng-click="clear()"
ng-show="multiValue == false && ngModel === ''" />
The purpose of the image is to show an "X" icon to clear the value represented by $scope.ngModel
. However, when $scope.multiValue
is true, the X icon does not need to display. When $scope.multiValue
is false and a value has been selected, the X icon needs to display.
I have tried multiple means to get the X to disappear when multiValue is false or a value has not yet been selected:
Help would be greatly appreciated.
Upvotes: 0
Views: 43
Reputation: 1539
You have not mentioned about which version of Angular you are using.
However, in Angular 6 or 7 you can use
*ngIf="multiValue == false && ngModel === ''"
Hope this will help you
Upvotes: 0
Reputation: 11
Could you please use <ng-if="">
Instead of <ng-show="">
.
I am not sure of is this helpful. But I have faced similar issues that time I used <ng-if="">
Upvotes: 1