Skip to content
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

Error parsing {token}s #125

Open
snuggs opened this issue Jul 30, 2017 · 9 comments
Open

Error parsing {token}s #125

snuggs opened this issue Jul 30, 2017 · 9 comments

Comments

@snuggs
Copy link
Member

snuggs commented Jul 30, 2017

Currently if a {token} is found within a component we search for a property of the same name on the claas definition. However if the token is not available we return undefined this is printing to the DOM. We can do the following:

  1. silently fail (empty string. possibly confusing)
  2. keep undefined as a hed nod to change.
  3. leave the token in place. (which in my case i need because i want {fields} to actually display not get parsed.

This brings up another question. Do we have to escape? {{token}} would render {token} << TO BE CLEAR I DON'T LIKE THAT. I just want to know the best way to "Escape" a token.

Please advise
capture d ecran 2017-07-30 a 17 28 07

@brandondees
Copy link
Collaborator

interesting options.... have you looked at how say handlebars does this? might be safest to stick with something familiar. on the other hand, i kind of find interesting the possibility of having the option as a developer. In some cases, I may want to opt out of handlebars {} syntax altogether and treat it as literal content characters. in other cases i may want the interpolation always, even when undefined and maybe still in other cases it might be preferable to be able to mix and match, having some {} escaped as output, others interpolated with property values, others failing over to a safe default like empty string, etc.

does \{ backslash escaping make any sense? that'd probably be the most obvious/familiar for most devs, I should think.

as for failure defaults, i'd say undefined by default helps me find problems with my code and fix them. if i want to explicitly use an empty string or a safe default value, i can either design the property getter to work that way, or maybe {prop || 'default'} i would presume, which isn't horribly verbose and should get the job done (i'm assuming).

@snuggs
Copy link
Member Author

snuggs commented Jul 31, 2017

{prop || 'default'} i would presume, which isn't horribly verbose and should get the job done (i'm assuming). - @brandondees

VERY modern JS pattern right there my man. Ancient ruby pattern tho. #ISeeWhatYouDidThere #NowYouGetIt

However you'd do that within the computed getter property instead. Remember ZERO logic views ;-). Tokens are merely symbolic references. At least that's what Webster's says hehe

<foo-bar> {message} </foo-bar>

<script>
Element `foo-bar`

(class extends HTMLElement {
  get message ()
    { return undefined || 'default message' }
})

</script>

That would be ok @brandondees however the undefined is coming due to there not even being the property on the class. That's what is "bug" like Imagine if get message () didn't exist on previous class. Please advise.

#CATAT /cc @tmornini @kurtcagle @rianby64

@tmornini
Copy link
Collaborator

I'd suggest HTML escaping the {token} if there's no match.

@brandondees
Copy link
Collaborator

great idea @tmornini

@snuggs so then yeah, let it fail to undefined, or something configurable as the default failure value if there's a way to hook that in.

@brandondees
Copy link
Collaborator

or @tmornini 's suggestion, which probably makes the most sense

@snuggs
Copy link
Member Author

snuggs commented Dec 23, 2018

@brandondees @tmornini @Robertchristopher @btakita formal discussion over @ WHATWG

whatwg/html#4219

@snuggs
Copy link
Member Author

snuggs commented Dec 23, 2018

I actually noticed a bug in our code that breaks parser when value is undefined property. Will write test and close out this issue.
capture d ecran 2018-12-23 a 11 46 52

@antman3351
Copy link

Hello, this isn't really an issue so as it's related to the token parsing I'll add it here 🙃.
I've just started looking at Snuggsi to use in an existing PHP application. Unfortunately the { } conflicts with the PHP template engine, the engine can be told to ignore parts of the HTML but it would be simpler and clearer if I could set the opening and closing token to a different character(s), would this be possible?

Thanks!

@rianby64
Copy link
Collaborator

rianby64 commented Aug 18, 2021

This question leads to the possibility to customize the token... and, by default it could be {}. However, what about if two instances of the framework are loaded?

And what about the compatibility with the standard?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment