java.lang.Object
netscape.javascript.JSObject
public abstract class JSObject extends Object
Allows Java code to manipulate JavaScript objects.
When a JavaScript object is passed or returned to Java code, it
is wrapped in an instance of JSObject
. When a
JSObject
instance is passed to the JavaScript engine,
it is unwrapped back to its original JavaScript object. The
JSObject
class provides a way to invoke JavaScript
methods and examine JavaScript properties.
Any data returned from the JavaScript engine to Java is converted to Java data types. Certain data passed to the JavaScript engine is converted to JavaScript data types.
-
Constructor Summary
Constructors Modifier Constructor Description protected
JSObject()
Constructs a new JSObject. -
Method Summary
Modifier and Type Method Description abstract Object
call(String methodName, Object... args)
Calls a JavaScript method.abstract Object
eval(String s)
Evaluates a JavaScript expression.abstract Object
getMember(String name)
Retrieves a named member of a JavaScript object.abstract Object
getSlot(int index)
Retrieves an indexed member of a JavaScript object.static JSObject
getWindow(Applet applet)
Deprecated, for removal: This API element is subject to removal in a future version.The Applet API is deprecated, no replacement.abstract void
removeMember(String name)
Removes a named member of a JavaScript object.abstract void
setMember(String name, Object value)
Sets a named member of a JavaScript object.abstract void
setSlot(int index, Object value)
Sets an indexed member of a JavaScript object.
-
Constructor Details
-
JSObject
protected JSObject()Constructs a new JSObject. Users should neither call this method nor subclass JSObject.
-
-
Method Details
-
call
Calls a JavaScript method. Equivalent to "this.methodName(args[0], args[1], ...)" in JavaScript.- Parameters:
methodName
- The name of the JavaScript method to be invoked.args
- the Java objects passed as arguments to the method.- Returns:
- Result of the method.
- Throws:
JSException
- when an error is reported from the browser or JavaScript engine.
-
eval
Evaluates a JavaScript expression. The expression is a string of JavaScript source code which will be evaluated in the context given by "this".- Parameters:
s
- The JavaScript expression.- Returns:
- Result of the JavaScript evaluation.
- Throws:
JSException
- when an error is reported from the browser or JavaScript engine.
-
getMember
Retrieves a named member of a JavaScript object. Equivalent to "this.name" in JavaScript.- Parameters:
name
- The name of the JavaScript property to be accessed.- Returns:
- The value of the propery.
- Throws:
JSException
- when an error is reported from the browser or JavaScript engine.
-
setMember
Sets a named member of a JavaScript object. Equivalent to "this.name = value" in JavaScript.- Parameters:
name
- The name of the JavaScript property to be accessed.value
- The value of the propery.- Throws:
JSException
- when an error is reported from the browser or JavaScript engine.
-
removeMember
Removes a named member of a JavaScript object. Equivalent to "delete this.name" in JavaScript.- Parameters:
name
- The name of the JavaScript property to be removed.- Throws:
JSException
- when an error is reported from the browser or JavaScript engine.
-
getSlot
Retrieves an indexed member of a JavaScript object. Equivalent to "this[index]" in JavaScript.- Parameters:
index
- The index of the array to be accessed.- Returns:
- The value of the indexed member.
- Throws:
JSException
- when an error is reported from the browser or JavaScript engine.
-
setSlot
Sets an indexed member of a JavaScript object. Equivalent to "this[index] = value" in JavaScript.- Parameters:
index
- The index of the array to be accessed.value
- The value to set- Throws:
JSException
- when an error is reported from the browser or JavaScript engine.
-
getWindow
@Deprecated(since="9", forRemoval=true) public static JSObject getWindow(Applet applet) throws JSExceptionDeprecated, for removal: This API element is subject to removal in a future version.The Applet API is deprecated, no replacement. See the java.applet package documentation for further information.Returns a JSObject for the window containing the given applet. This method only works when the Java code is running in a browser as an applet. The object returned may be used to access the HTML DOM directly.- Parameters:
applet
- The applet.- Returns:
- JSObject representing the window containing the given applet or
null
if we are not connected to a browser. - Throws:
JSException
- when an error is reported from the browser or JavaScript engine or if applet isnull
-