The apex.storage
namespace contains all functions related browser storage features such as cookies and session storage.
Parent topic: JavaScript APIs
Local storage and session storage, collectively known as web storage, are a browser feature that securely stores key value pairs associated with an origin (web site). The keys and values are strings. The amount of storage space for web storage is greater than that of cookies but it is not unlimited. Another advantage over cookies is that the key value pars are not transmitted with each request.
Both local storage and session storage use the same API to set, get, and remove name value pairs. The difference is that session storage goes away when the browser session ends and local storage is available even when the browser restarts. Keep in mind that the browser is free to limit or delete data stored in local storage at the user's request. Unlike data stored on the server local storage is not shared between browsers on different machines or even different browsers on the same machine.
Because APEX supports multiple applications, multiple workspaces and even instances of the same application running in multiple workspaces there can arise conflicts with using web storage because all the apps from a single APEX instance (which is a single origin or web site) share the same web storage space. The apex.storage.getScopedLocalStorage
and apex.storage.getScopedSessionStorage
solve this problem buy partitioning the storage into a scope based on application id an optionally additional information such as page id and region id. The scope is crated by using a prefix on all the storage keys. This avoids conflicts when different apps or different instances of the same app use the same keys but it is not a secure partition. Consider this carefully before storing sensitive information in web storage.
Parent topic: apex.storage namespace
Returns the value of cookie name (pName
).
Parameters
Table 38-65 apex.storage.getCookie
Name | Type | Description |
---|---|---|
|
String |
The name of the cookie. |
Returns
The string value of the cookie.
Parent topic: apex.storage namespace
Returns true
if the browser supports the local storage API and false otherwise. Most modern browsers support this feature but some allow the user to turn it off.
Parameter
None.
Returns
true
if the browser supports the local storage API and false
otherwise.
Parent topic: apex.storage namespace
Returns a thin wrapper around the localStorage
object that scopes all keys to a prefix defined by the pOptions
parameter. If localStorage
is not supported the returned object can be used but has no effect so it is not necessary test for support using apex.storage.hasLocalStorageSupport
before calling this function.
Parameter
Table 38-66 apex.storage.getScopedLocalStorage
Name | Type | Description |
---|---|---|
|
Object |
An object that defines the scope of the local storage. This defines the storage key prefix used by the returned |
Table 38-67 pOptions properties
Name | Type | Description |
---|---|---|
|
String |
A static prefix string to add to all keys. The default is an empty string. |
|
Boolean |
If |
|
Boolean |
If |
|
String |
An additional string to identify a region or other part of a page. |
Returns
A localStorage
wrapper object. This object has the same properties and functions as the browser Storage interface.
Table 38-68 localStorage wrapper
Property | Description |
---|---|
|
APEX specific property. The prefix for this scoped storage object. |
|
The number of items in the scoped storage object. |
|
Returns the nth key in the scoped storage object. |
|
Returns the value for the given key. |
|
Sets the value of the given key to data. |
|
Removes the given key. |
|
Removes all keys from the scoped storage object. |
|
APEX specific function. Use to ensure the length property is correct if keys may have been added or removed by means external to this object |
Example
The following example creates a local storage object that scopes all the keys using a prefix “Acme
” and the application id. It then sets and gets an item called “setting1
”.
var myStorage = apex.storage.getScopedLocalStorage( { prefix: "Acme", useAppId: true }); myStorage.setItem( "setting1", "on" ); setting = myStorage.getItem( "setting1" ); // returns "on"
Parent topic: apex.storage namespace
Returns a thin wrapper around the sessionStorage
object that scopes all keys to a prefix defined by the pOptions
parameter. If sessionStorage is not supported the returned object can be used but has no effect so it is not necessary test for support using apex.storage.hasSessionStorageSupport before calling this function.
Parameter
Table 38-69 apex.storage.getScopedSessionStorage
Name | Type | Description |
---|---|---|
|
Object |
An object that defines the scope of the session storage. This defines the storage key prefix used by the returned |
Table 38-70 pOptions properties
Name | Type | Description |
---|---|---|
|
String |
A static prefix string to add to all keys. The default is an empty string. |
|
Boolean |
If |
|
Boolean |
If |
|
String |
An additional string to identify a region or other part of a page. |
Returns
A sessionStorage
wrapper object. This object has the same properties and functions as the browser Storage interface.
Table 38-71 sessionStorage
Property | Description |
---|---|
|
APEX specific property. The prefix for this scoped storage object. |
|
The number of items in the scoped storage object. |
|
Returns the nth key in the scoped storage object. |
|
Returns the value for the given key. |
|
Sets the value of the given key to data. |
|
Removes the given key. |
|
Removes all keys from the scoped storage object. |
|
APEX specific function. Use to ensure the length property is correct if keys may have been added or removed by means external to this object |
Example
The following example creates a session storage object that scopes all the keys using a prefix “Acme
” and the application id. It then sets and gets an item called “setting1
”.
var myStorage = apex.storage.getScopedSessionStorage( { prefix: "Acme", useAppId: true }); myStorage.setItem( "setting1", "on" ); setting = myStorage.getItem( "setting1" ); // returns "on"
Parent topic: apex.storage namespace
Returns true
if the browser supports the session storage API and false otherwise. Most modern browsers support this feature but some allow the user to turn it off.
Parameter
None.
Returns
true
if the browser supports the session storage API and false
otherwise.
Parent topic: apex.storage namespace
Sets a cookie (pName
) to a specified value (pValue
).
Parameters
Table 38-72 apex.storage.setCookie
Name | Type | Description |
---|---|---|
|
String |
The name of the cookie to set. |
|
String |
The value to set the cookie to. |
Parent topic: apex.storage namespace