public interface ClientOnlyDataSources
The client-side interface to a client-only DataSource is identical to a server-based DataSource, including asynchronous responses, so that a client-only DataSource can be replaced by a server-based DataSource without code changes. The only difference is that changes to records belonging to the DataSource persist only until the page is reloaded.
Client-only DataSources allow you to create a complete prototype application in an .html file that does not require a server.
The setClientOnly method is specified to create a client-only DataSource. For example:
DataSource dataSource = new DataSource(); dataSource.setID("stockQuotesDS"); DataSourceField idField = new DataSourceField("id", FieldType.INTEGER, "Id"); ........ dataSource.setFields(idField,.....); dataSource.setClientOnly(true);If you have existing test data in XML (see the Admin Console for expected format), you can load it into a client-only DataSource using setDataURL method, like so:
DataSource dataSource = new DataSource(); dataSource.setID("stockQuotesDS"); dataSource.setRecordXPath("/List/stockQuotes"); DataSourceField idField = new DataSourceField("id", FieldType.INTEGER, "Id"); ........ dataSource.setFields(idField,.....); dataSource.setDataURL("ds/test_data/stockQuotes.data.xml"); dataSource.setClientOnly(true);The DataSource will lazily make a one-time fetch against the specified data file the first time an operation is called on it. From then on, the DataSource will work against the local cache created from this initial request. This is a quick way to prototype against some test data that may eventually be returned from an arbitrary back-end.
Finally, it is possible to have a DataSource which initially fetches the entire dataset and
performs all subsequent fetching locally, while still visiting the server to perform all
other operations. See DataSource.cacheAllData
.
DataSource.getClientOnly()