-
Notifications
You must be signed in to change notification settings - Fork 10.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Make component binding case-sensitive #9860
Comments
Does this also imply that a |
Yes |
I'm a traditional Xaml developer and can say that most Xaml developers are turned off by HTML syntax. Pascal-case brings a lot of authority and elegance to symbols, IMO. Plus it's consistent with C# and VB.NET, of course. That said, Blazor's syntax has a lot going for it. I think the more Pascal-case you bring to the table, the more adoption -- and perhaps, less complaining 😆 -- you're going to see from Xaml developers as there won't be so much Frankenstein inconsistency between .NET and HTML symbols. Forcing Pascal-case for .NET symbols is a major win, IMO. It will make it easier to know what is HTML and what is .NET, especially for the newbs such as myself who are onboarding and are learning the terrain. FWIW, it would be ideal to take it a step further and allow (read: not require) the directives themselves to be Pascal-cased as well, e.g. In any case, thank you for all your efforts here. Very impressed with and excited for Blazor. 👍 |
@ajaybhargavb - one of the first considerations here is to make sure the the WTE editor is updated to align with this behavior. So, we need to do gap analysis - are there places where WTE would complete or colorize things differently from what we expect. |
<3 @ajaybhargavb - make sure you blast out an email update when we have a build of VS 👍 |
@ajaybhargavb Really glad to see this go in! This is a huge improvement 😄 |
Summary
We've going to change component binding to be case-sensitive and add warnings for cases where you made an obvious mistake. We've treated all of these issues as conventions or recommendations thus far, but having components fail to bind usually results is really vexing compiler errors from C#
The problem
Suppose that you rename a component without renaming all of the usages (or suppose you change the namespace). If you were using event handlers with that component:
You now get a compile error that says something like
Cannot convert method group Clicked to type System.Object.
. This is because method-group-to-delegate-conversion doesn't support object, but it's fairly common with components.You now miss the forest for the trees. You're distracted from the root cause, which is that the
MyButton
tag didn't resolve to a component.Solution
We've had on the roadmap for a while to make binding case-sensitive. So this is not really a surprise.
The additional goal is to detect and warn in the case where a developer tries to reference a component, but no such component is found. Currently the behavior is to treat it as an HTML element, which is potentially very confusing.
To fix this, we want to turn the PascalCasing of component names into a stronger, built-in convention:
If you try to compile a component whose name starts with a lowercase character in
a-z
, fail the compilation with an error (Component names cannot start with lowercase characters
).Each time something in your
.razor
source resolves as an element (not a component), check that its name starts with a lowercase character ina-z
. If we find an element whose first char isn't ina-z
case sensitively, emit a warning (Found markup element with unexpected name '{0}'. If this is intended to be a component, add a @using directive for its namespace.
).a-z
(case-insensitively), and will do probably forever.Allow the warning from (2) to be suppressed. See Blazor compiler reports misleading error #9786 (comment)
The text was updated successfully, but these errors were encountered: