How do you change the placeholder colour on a angular/material input placeholder?
<mat-form-field>
<input matInput placeholder="Name">
</mat-form-field>
How do you change the placeholder colour on a angular/material input placeholder?
<mat-form-field>
<input matInput placeholder="Name">
</mat-form-field>
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 :
css:
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/
I found no answer from above from Working with latest angular material with angular 6.
Here is working solution
For angular material 5.x.x or above there is a
mat-placeholder
element you can use. You don't need to override material css classes. This aproach -I think- is the best: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
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
OR
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
To change the color of placeholder, override the color property of .mat-form-field-placeholder like:
To change the color of underline:
This works perfect. Demo: https://plnkr.co/edit/yF4kXJ500YzefLOnLKNe?p=preview