How do you change the placeholder color on an angular/material input placeholder?
<mat-form-field>
<input matInput placeholder="Name">
</mat-form-field>
How do you change the placeholder color on an angular/material input placeholder?
<mat-form-field>
<input matInput placeholder="Name">
</mat-form-field>
To change the color of placeholder, override the color property of .mat-form-field-placeholder like:
::ng-deep .mat-form-field-placeholder{
color:red;
}
::ng-deep .mat-focused .mat-form-field-placeholder{
color:red;
}
To change the color of underline:
::ng-deep .mat-form-field-underline .mat-form-field-ripple{
background-color:red;
}
::ng-deep .mat-form-field-underline{
background-color:red;
}
This works perfect. Demo: https://plnkr.co/edit/yF4kXJ500YzefLOnLKNe?p=preview
In the last version of angular you can remove the placeholder in the input and add a mat-placeholder in the mat-form-field and custom the css with a class
html :
<mat-form-field>
<input matInput type="text">
<mat-placeholder class="placeholder">Search</mat-placeholder>
</mat-form-field>
css:
.mat-focused .placeholder {
color: #00D318;
}
I am using angular material 8.2.3 and None of the above solutions worked for me and having the following in theme.scss(material theme file) worked for me
.mat-input-element::placeholder{
color: red;
}
conversely with piercing the following should work in component styles
::ng-deep .mat-input-element::placeholder{
color: red;
}
, .mat-select-placeholder
since selects dont have the mat-input-element but use that instead. –
Functionary !important
–
Somatic To change the color of placeholder, override the color property of .mat-form-field-placeholder like:
::ng-deep .mat-form-field-placeholder{
color:red;
}
::ng-deep .mat-focused .mat-form-field-placeholder{
color:red;
}
To change the color of underline:
::ng-deep .mat-form-field-underline .mat-form-field-ripple{
background-color:red;
}
::ng-deep .mat-form-field-underline{
background-color:red;
}
This works perfect. Demo: https://plnkr.co/edit/yF4kXJ500YzefLOnLKNe?p=preview
Non of the above answers worked for me in latest versions.
Here is working solution
::ng-deep .mat-form-field-label{
color:#000 !important;
}
::ng-deep .mat-form-field-underline{ background-color: seashell !important; }
and ::ng-deep.mat-form-field-ripple { background-color: seashell !important;; }
to change the underline color. –
Analyze For angular material 5.x.x or above there is amat-placeholder
element you can use. You don't need to override material css classes. This aproach -I think- is the best:
<mat-form-field class="full-width">
<input matInput type="text" name="name" formControlName="name" >
<mat-placeholder style="color:brown">Enter your name here</mat-placeholder>
<mat-icon matSuffix class="material-icons">perm_identity</mat-icon>
</mat-form-field>
Note: You can not use placeholder attribute in input tag at the same time with mat-placeholder element in the same mat-form-field tag.
For further information: https://material.angular.io/components/input/overview#floating-placeholder
What options we have?
<mat-placeholder>
tag is deprecated: https://material.angular.io/components/form-field/api#MatPlaceholder
/deep/
selector will be deprecated soon. ::placeholder
selector is still experimental feature: https://developer.mozilla.org/en-US/docs/Web/CSS/::placeholder
So I would recommend to use input placeholder as an attribute only if your clients have modern browsers.
One solution provided by material 2 itself found in example code. I have done a sample here:
<mat-form-field>
<mat-label>Input</mat-label>
<input matInput >
</mat-form-field>
As @mohit uprim suggested in the answer above, We can use the shadow piercing descendant combinators i.e. /deep/ or ::ng-deep or >>> Below is an example
/deep/ .mat-form-field-placeholder {
color: #fff; // choose the color you want
}
OR
>>> .mat-form-field-placeholder {
color:red;
}
Although this method is specified in the angular docs as of now, they have mentioned that this method will soon be deprecated. read more: https://angular.io/guide/component-styles#!#-deep-
According to Angular.io documentation, the proper way of doing this is to change the view encapsulation to none on your component and then writing your custom styles in the css file respective to this component. Please be advised that by doing so, you are moving away from shadow dom and emulated techniques(default in an angular project) which means the styles you specify in this component may propagate to the parent/child components and may mess up the styling there too
Angular material in itself doesn't provide any directives for setting styles.For this, you need to go old school. Just give an id/class to your input element then use pseudo class (::placeholder). For reference : https://css-tricks.com/almanac/selectors/p/placeholder/
© 2022 - 2024 — McMap. All rights reserved.