jangaroo-runtime.2.0.5.source-code.undefined.as Maven / Gradle / Ivy
/**
* API and documentation by Adobe?.
* Licensed under http://creativecommons.org/licenses/by-nc-sa/3.0/
*/
package {
/**
* A special value that applies to untyped variables that have not been initialized or dynamic object properties that are not initialized. In ActionScript 3.0, only variables that are untyped can hold the value undefined
, which is not true in ActionScript 1.0 and ActionScript 2.0. For example, both of the following variables are undefined
because they are untyped and unitialized:
*
* var foo;
* var bar:*;
* The undefined
value also applies to uninitialized or undefined properties of dynamic objects. For example, if an object is an instance of the Object class, the value of any dynamically added property is undefined
until a value is assigned to that property.
* Results vary when undefined
is used with various functions:
*
* - The value returned by
String(undefined)
is "undefined"
(undefined
is converted to a string).
* - The value returned by
Number(undefined)
is NaN
.
* - The value returned by
int(undefined)
and uint(undefined)
is 0.
* - The value returned by
Object(undefined)
is a new Object instance.
* - When the value
undefined
is assigned to a typed variable, the value is converted to the default value of the data type.
* Do not confuse undefined
with null
. When null
and undefined
are compared with the equality (==
) operator, they compare as equal. However, when null
and undefined
are compared with the strict equality (===
) operator, they compare as not equal.
* @see http://help.adobe.com/en_US/FlashPlatform/reference/actionscript/3/statements.html#null null
*
* @example In the following example, an untyped variable, myVar
is declared but not initialized. The value of myVar
is undefined
because the variable is untyped. This is true whether the variable has no type annotation or uses the special (*) untyped annotation (var myVar:*;
).
*
* // trace value of untyped and uninitialized variable
* var myVar;
* trace(myVar); // undefined
*
* The same rule applies to uninitialized properties of a dynamic object. For example, given an instance, obj
, of the dynamic class A
, the value of obj.propName
, which is an uninitialized property of the obj
instance, is undefined
.
*
* dynamic class A {}
* var obj:A = new A()
*
* // trace undefined property of obj
* trace(obj.propName); // undefined
*
*/
[Native]
public const undefined: * = {}['']; // prevent compiler warning
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy