-
Notifications
You must be signed in to change notification settings - Fork 0
0.2.8 usage extend
ivansglazunov edited this page Feb 2, 2015
·
2 revisions
Prototype.extend(injector?: TInjector) => Function;
All elements are extensions of Prototype.
Each element has the option .constructor, which you can override when inheritance. It contains the build process makes the element element.
Each element has the option .returner, which specifies what will be returned by the constructor.
The extension is with the argument of the TInjector or without.
Without TInjector
var myTag = div('.myTag')().extend();
myTag()().render(console.log);
<div class="myTag"></div>
With TInjector
Here we simply disable return constructor method .content.
var injector = function() {
var parent = this._parent;
this.constructor = function() {
parent.constructor.apply(this, arguments);
this.append(' after');
};
this.returner = function() { return this; };
};
var myTag = div('.myTag')('content').extend(injector);
myTag().render(console.log);
<div class="myTag">content after</div>
- TData: Renderer|sync|async|Mixin
- TCallback: (error, result) => void
- TSelector: string
- TInjector: () => void
- TAttributes: [name: string]: TData
- TContext: TData
Node.js:
var T = require('oswst');
Require.js:
define(['oswst'], function(T) {});
window
:
var T = window.oswst(_, async);
-
Templates
- .compile
- .include
- .render
- .renderContext
- .renderAttributes
- .renderSelector
- .sync
- .isSyncFunction
- .async
- .isAsyncFunction
- .Prototype()
- .Renderer > .Prototype
- .Data > .Renderer
- .data > .Data
- .Tag > .data
- .Single > .Tag
- .singles[string]
- .Double > .Tag
- .doubles[string]
- .Doctype > .Tag
- .doctypes[string]
- .xml > .Tag
- .Mixin > .Data
- .mixin > .Mixin
- .mixins[string]
- .Module > .Renderer
- .with