Class: Class

LuCI.Class

LuCI.Class is the abstract base class all LuCI classes inherit from.

It provides simple means to create subclasses of given classes and implements prototypal inheritance.

Source:

Methods

(static) extend(properties) → {LuCI.Class}

Extends this base class with the properties described in properties and returns a new subclassed Class instance

Parameters:
Name Type Description
properties Object.<string, *>

An object describing the properties to add to the new subclass.

Source:
Returns:

Returns a new LuCI.Class sublassed from this class, extended by the given properties and with its prototype set to this base class to enable inheritance. The resulting value represents a class constructor and can be instantiated with new.

Type
LuCI.Class

(static) instantiate(params, …new_argsopt) → {LuCI.Class}

Calls the class constructor using new with the given argument array being passed as variadic parameters to the constructor.

Parameters:
Name Type Attributes Description
params Array.<*>

An array of arbitrary values which will be passed as arguments to the constructor function.

new_args * <optional>
<repeatable>

Specifies arguments to be passed to the subclass constructor as-is in order to instantiate the new subclass.

Source:
Returns:

Returns a new LuCI.Class instance extended by the given properties with its prototype set to this base class to enable inheritance.

Type
LuCI.Class

(static) isSubclass(classValue) → {boolean}

Checks whether the given class value is a subclass of this class.

Parameters:
Name Type Description
classValue LuCI.Class

The class object to test.

Source:
Returns:

Returns true when the given classValue is a subclass of this class or false if the given value is not a valid class or not a subclass of this class'.

Type
boolean

(static) singleton(properties, …new_argsopt) → {LuCI.Class}

Extends this base class with the properties described in properties, instantiates the resulting subclass using the additional optional arguments passed to this function and returns the resulting subclassed Class instance.

This function serves as a convenience shortcut for Class.extend() and subsequent new.

Parameters:
Name Type Attributes Description
properties Object.<string, *>

An object describing the properties to add to the new subclass.

new_args * <optional>
<repeatable>

Specifies arguments to be passed to the subclass constructor as-is in order to instantiate the new subclass.

Source:
Returns:

Returns a new LuCI.Class instance extended by the given properties with its prototype set to this base class to enable inheritance.

Type
LuCI.Class

super(key, callArgsopt) → {*|null}

Walks up the parent class chain and looks for a class member called key in any of the parent classes this class inherits from. Returns the member value of the superclass or calls the member as function and returns its return value when the optional callArgs array is given.

This function has two signatures and is sensitive to the amount of arguments passed to it:

  • super('key') - Returns the value of key when found within one of the parent classes.
  • super('key', ['arg1', 'arg2']) - Calls the key() method with parameters arg1 and arg2 when found within one of the parent classes.
Parameters:
Name Type Attributes Description
key string

The name of the superclass member to retrieve.

callArgs Array.<*> <optional>

An optional array of function call parameters to use. When this parameter is specified, the found member value is called as function using the values of this array as arguments.

Source:
Throws:

Throws a ReferenceError when callArgs are specified and the found member named by key is not a function value.

Type
ReferenceError
Returns:

Returns the value of the found member or the return value of the call to the found method. Returns null when no member was found in the parent class chain or when the call to the superclass method returned null.

Type
* | null

varargs(args, offset, …extra_argsopt) → {Array.<*>}

Extract all values from the given argument array beginning from offset and prepend any further given optional parameters to the beginning of the resulting array copy.

Parameters:
Name Type Attributes Description
args Array.<*>

The array to extract the values from.

offset number

The offset from which to extract the values. An offset of 0 would copy all values till the end.

extra_args * <optional>
<repeatable>

Extra arguments to add to prepend to the resultung array.

Source:
Returns:

Returns a new array consisting of the optional extra arguments and the values extracted from the args array beginning with offset.

Type
Array.<*>