Kangax,
Your method indeed appears to be the most suitable option at this
moment. Thanks!
On Sep 26, 11:40 pm, kangax <[EMAIL PROTECTED]> wrote:
> On Sep 26, 9:54 am, Rumith <[EMAIL PROTECTED]> wrote:
>
>
>
> > Hi,
> > I'm trying to implement a method that would allow to use
> > Class.create() inheriting HTML elements like div instead of other
> > classes. That is, the result would be something like this (the syntax
> > is arbitrary and is for demo purposes only):
>
> > var Block = Class.create("div", {
> > initialize: function(bgColor) {
> > this.style.backgroundColor = bgColor;
> > },
>
> > highlight: function() {
> > ....
> > },
>
> > });
>
> > var block = new Block("#aaaaff");
> > document.getElementById("mountPoint").appendChild(block);
> > block.highlight();
>
> > The purpose is to defeat the necessity to maintain two JS objects (the
> > actual DOM element and the object containing the special methods and
> > the DOM element) per entity.
> > Has anybody tried something like this? Can it be done without
> > modifying Prototype itself? Thanks.
>
> A wrapper/decorator pattern would probably be the best option:
>
> var DOMElement = Class.create({
> initialize: function(tagName, options) {
> this.__element = new Element(tagName || 'div', options);
> },
> // invoked when passed to `insert`
> toElement: function() {
> return this.__element;
> },
> setStyle: function(style) {
> this.__element.setStyle(style);
> return this;
> }
>
> });
>
> var Block = Class.create(DOMElement, {
> initialize: function($super, bgColor) {
> // call superclass, create element
> $super('div');
> this.setStyle('backgroundColor', bgColor);
> },
> // add custom methods to a subclass
> highlight: function() {
> this.__element.highlight();
> }
>
> });
>
> var block = new Block("#aaaaff");
> $(document.body).insert(block);
> block.highlight();
>
> --
> kangax
--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups
"Prototype & script.aculo.us" group.
To post to this group, send email to [email protected]
To unsubscribe from this group, send email to [EMAIL PROTECTED]
For more options, visit this group at
http://groups.google.com/group/prototype-scriptaculous?hl=en
-~----------~----~----~----~------~----~------~--~---