-
Notifications
You must be signed in to change notification settings - Fork 378
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
has="mixin this, mixin that" #663
Comments
If you're interested, just as an example of it in action - I created a proof of concept of essentially this a little while back - using Seems like concept of mixins in general has definitely be discussed before, and also custom-attributes which may also be an alternative here. In general I'm +1 for the mixin concept, but feel there must be some reasons it hasn't been successful so far... |
I think the main problem is that JavaScript itself lacks native support. If it ever got native support we'd want to be compatible with that. So until that point it seems better to experiment in "user space". |
@annevk that sounds completely fair. What if, rather than specifying a particular mixin syntax or anything, we could just open up and generalise the Element Upgrade process - so that we could upgrade new prototypes as we needed? Realise this is touching on #620, which is closed due to existence of |
Well yeah, but at that point you're enshrining a particular variant of mixins that may or may not be what ends up in JavaScript. |
Oh right - as in, replacing the prototype to add extra functionality is one variant of mixins, and not necessarily the one that will become standard, and therefore not something to pursue right now for CEs? Might be better for me to make my comments over on #620 then, as it's more a comment on being able to make further upgrades. |
Right. |
Mixing classes together (in whatever form, class factories, concatenation, etc) is adding much complexity that my idea avoids in the first place (avoiding anything to do with inheritance). Assuming it would be named <any-element has="behavior1 behavior2 behavior3" /> those classes are not associated by inheriatnce at all. They are standalone classes, as I just described here: #509 (comment) They don't inherit from each other, there's no concatenation, prototype mangling, or any form of multiple inheritance; there's nothing about inheritance at all, to keep it simple and clean. They are standalone behaviors, then when instantiated are given the opportunity to act on (or on behalf of) an element. They are behaviors that can run logic based on the life cycle of a given element, and they don't need to extend from each other or operate on the same In most cases, they will probably never actually need to add or remove properties on the target element, and using their own In less common cases, the behavior might want to expose imperative API (rather than just attribute-based API). And in such cases, this idea (though slightly more verbose than accessing properties on an element itself) provides a way for a behavior's public API to be accessed, and encourages developers not to modify properties directly on the target element. However, behavior authors still can modify the target element directly if they want to (just like authors of any jQuery behavior). In the end, this would be more similar to jQuery than multiple inheritance, in the sense that jQuery plugins can have their own F.e., in jQuery, we use behaviors like this: $(someElement).behavior('some-method', 'some-arg') (This pattern is documented here) In this jQuery example, we're passing the element to jQuery and getting back a jQuery context that lets us use a behavior associated with the element (using the aforementioned and widely-adopted pattern), and to then call a method on that behavior (not on the element directly). In this regard, the idea in #662 is similar, in the sense that behaviors are independent of each other. In my example where I wrote audioDiv.components['audio-player'].callWhatever()
// or
audioDiv.behaviors['audio-player'].callWhatever() that is effectively similar to $(audioDiv).audioPlayer('callWhatever') in jQuery, where we get a behavior associated with the target element and call a method on it. This concept has already been proven (jQuery), just that in the current form it is not declarative, only imperative. #662 proposes something that replaces the current The idea in #662 is also better than jQuery's, because each behavior is nicely organized into a class that has its own very clear The pattern is simply a lot cleaner, semantic, and idiomatic than jQuery's, based on modern JS. That said, this idea is its own, jQuery or not. The behaviors associated with an element are independent (there's no inheritance involved, and there should not be, for the sake of simplicity). It allows any number of authors to be able to associate behaviors with any number of elements (that is similar to jQuery). It also solves the problems with |
Yeah this isn't really about mixins as much as it is about declaratively decorating elements with functionality in a way that hooks into the element lifecycle predictably, and simply too. That seems to be the generally desired capability. As to |
@jimmont OP calls it mixins but now you say it's not mixins? I'm not sure I follow. |
I've come to the conclusion that the discussion here isn't focused on practical/pragmatic solutions and am closing this issue. Feel free to discuss or handle further as you wish. |
has="mixin"
Idea for managing mixins without conflicting with existing classes oris=
attribute. A followup to #662 #509 reis=
.Goal: address practical need for mixins with existing and custom elements, hook into element lifecycle, not conflict with various libraries, expectations in the wild.
The text was updated successfully, but these errors were encountered: