Components: md-select does not display default (null) option text in mat-select-value

Created on 15 Aug 2017  路  16Comments  路  Source: angular/components

Bug, feature request, or proposal:

Bug

What is the expected behavior?

Select should display text associated with null/undefined value when provided

What is the current behavior?

Select displays nothing

What are the steps to reproduce?

http://plnkr.co/edit/i919jzNOoXhlPeN4hxxE?p=preview

What is the use-case or motivation for changing an existing behavior?

Adding a default option with text for a null value should result in displaying the text when the current model value is null.

For example, adding a default option with text "None"
<md-option>None<md-option>

should show "None" when the select list is closed.

Which versions of Angular, Material, OS, TypeScript, browsers are affected?

Angular: 4.3.4
Material: Beta 8

Most helpful comment

If providing a <md-option [value]="undefined">None</md-option> or <md-option [value]="null">None</md-option> then I would think the intent is clear, even for untouched selects. Without those options, it's clear that there is no associated text and the select should display a blank.

It just seems unexpected when <md-option [value]="someValue">Text</md-option> would display the text while <md-option [value]="null">None</md-option> does not.

All 16 comments

https://github.com/angular/material2/pull/3341 allows you to define the trigger value

Thanks for the quick response.

I can see how that would help work around the issue but...

Are we saying that the md-select-trigger will be required on the md-select or that there will be some default behavior if the md-select-trigger is omitted?

If there will be some default behavior and it is to display the text between the selected md-option, then it's natural to expect that to happen even when the value is null.

It'll only be required if you want to customize the display value.

I can't answer your question, but to put it another way:

If the control value is null or undefined, and one of the MdOptions' value is null or undefined, should the trigger display that option's viewValue? Currently it does not.

cc @crisbeto

md-select used to take the null option's label in the older versions, but it was changed deliberately to the current behavior. The problem with showing the null value label is that it makes it look as if the select has a value, even though it doesn't. If we went back to the old behavior it would mean that we'd have to show the empty option's label for untouched selects as well (assuming that they start at undefined).

If providing a <md-option [value]="undefined">None</md-option> or <md-option [value]="null">None</md-option> then I would think the intent is clear, even for untouched selects. Without those options, it's clear that there is no associated text and the select should display a blank.

It just seems unexpected when <md-option [value]="someValue">Text</md-option> would display the text while <md-option [value]="null">None</md-option> does not.

Closing as working as intended. As noted above, this was a deliberate choice made in the mat-select

@willshowell
md-select-trigger is invisible if value is undefined or null
i cant show 'All' or 'Please Select ... ' on the md-select
(MD_PLACEHOLDER_GLOBAL_OPTIONS float: 'always')

@dynameis open a new issue about it. It seems like a reasonable request and is different from the one here.

So what's the recommendation when an item in your list has a 'value' that truly is null and you want it selected?

For example I have a list of dates for a search filter :

'Today', 'Yesterday', 'Last 7 days', 'All'

The type of [value] is Date (could equally be number). I really want 'All' to have a value of null, because:

(a) The alternative would be DateTime.MinValue or 9999999
(b) a null clearly means 'no filter'
(c) that's what gets passed to my service so it's just easier

But I run into this issue.

I just don't understand why IF an item with an explicit value of null exists (and the developer clearly added one with a null value) that they shouldn't expect it to be auto selected.

You said "If we went back to the old behavior it would mean that we'd have to show the empty option's label for untouched selects" - but so what! - this would ONLY be a problem if someone had added an option with a null value that wasn't intended to be the default - and if that were really the case what were they expecting it to do - just give that item a non null value.

I really don't see how the 'old behavior' leads to undesirable behavior because if you really don't like it you can just give everything a value? Perhaps more to the point is I feel the 'old' way is a much more common situation (filtering being the prime example) - and also the expected behavior.

Maybe I have to make the type Date|string and just put "All" for the value? I really wish I could put null and I've used many other dropdowns in the past which allowed null as a value without issue.


Edit: For me the solution that worked was to use '' for the value which allows it to be selected by default with reactive forms. Fortunately the code generated service I use does the following, so the falsy empty string automatically gets converted to undefined without any more work.

 data["startDate"] = this.startDate ? this.startDate.toISOString() : <any>undefined;

This is a major disappointment for us. We're migrating material1 to material2 and relied heavily on null options in selects to represent 'Any' for filtering. The problem is that now an 'Any' selection with an already bound null value will trigger an unnecessary change event. The best solution I see is from @simeyla which is to set the value to '', but of course now our typing is hacky, e.g. boolean|string etc. so this hopefully something that will be addressed. For reference:

<mat-select formControlName="isActive" > <mat-option value="">Any Status</mat-option> <mat-option *ngFor="let i of lookup.status" [value]="i.value">{{i.text}}</mat-option> </mat-select>

I also think this is a poor design choice. I'm having the same issue in that the selection of the value 'null' actually is a valid option in itself and presented to the user as "Inactive" instead of just a blank field. Right now, I'm working around this by having the "placeholder" attribute being "Inactive". But semantically that doesn't feel right, more like a workaround than a deliberate choice. Also this doesn't allow me to force the user to actively pick "Inactive" as an option, it's always the default when nothing else is selected.

I have to do all kind of hacks to work around this issue.
This is simply not consistent behavior - You show the mat-option with null value, you allow it to be selected but then you don't show it as selected.
As others suggested just threat it as a normal select option as long as it is defined otherwise if not defined then keep the current behavior.

I also find this extremely frustrating and a prime example of when an opinionated framework takes things too far. NULL IS A VALID OPTION and an option with that exact value should absolutely appear rendered in the control and not just silently discarded. For that matter any exact equality should work, why impose this falsey / discard approach? It's absurd. I've lost half a day trying to get this working and my solution has been hacky at best, since EVEN IF you use a <mat-label>, the control will take that over as well. This is seriously maddening and surprising at the same time, my experiences otherwise have not been like this. I hope this issue gets addressed because this most certainly is a concern.

Definitely frustrating and a lots of extra-work needed for a completely weird behaviour. As the others here said, we're also facing a situation when we WANT to have null to be selected as our default value, instead of that now we are using a constant that we need to convert to null everywhere we need it. This is ridiculous.

I wonder if it couldn't work like it currently does UNLESS there is a mat-option with null value specified. Is it not possible to do?

This issue has been automatically locked due to inactivity.
Please file a new issue if you are encountering a similar or related problem.

Read more about our automatic conversation locking policy.

_This action has been performed automatically by a bot._

Was this page helpful?
0 / 5 - 0 ratings

Related issues

michaelb-01 picture michaelb-01  路  3Comments

shlomiassaf picture shlomiassaf  路  3Comments

LoganDupont picture LoganDupont  路  3Comments

3mp3ri0r picture 3mp3ri0r  路  3Comments

Hiblton picture Hiblton  路  3Comments