From a0135373e4f80a61b4424ce079dce6fc18ff4a4b Mon Sep 17 00:00:00 2001 From: Joe Catera Date: Mon, 15 Oct 2012 10:57:16 -0700 Subject: [PATCH] Fixed the FAQ regarding passing data from the controller to the binder. --- docs/dev_guide/faq/index.rst | 423 ++++++++++++++++++++--------------- 1 file changed, 240 insertions(+), 183 deletions(-) diff --git a/docs/dev_guide/faq/index.rst b/docs/dev_guide/faq/index.rst index 9a70622f5..1b4eb4b02 100644 --- a/docs/dev_guide/faq/index.rst +++ b/docs/dev_guide/faq/index.rst @@ -2,8 +2,9 @@ Mojito: FAQ ########### -This page answers some of the most common questions we get about Mojito. For troubleshooting issues, -see `Mojito: Troubleshooting <../reference/mojito_troubleshooting.html>`_. +This page answers some of the most common questions we get about Mojito. For +troubleshooting issues, see +`Mojito: Troubleshooting <../reference/mojito_troubleshooting.html>`_. Questions ========= @@ -116,17 +117,19 @@ General The tools used in developing mojit modules (mojits) work offline, without requiring access to networked resources. When networked (cloud) resources are required due to the moduleâ™s own nature, e.g., retrieving data from a back-end service, Cocktails provides - facilities to mock these resources and simulate their behavior with dummy (local) implementations. + facilities to mock these resources and simulate their behavior with dummy (local) + implementations. ------------ .. _moj_nodemon: .. topic:: **Do I have to restart Mojito to see updates that I've made to my application?** - No, you can use ``nodemon`` or ``supervisor`` to start Mojito, which will automatically update any changes - that you've made to your application. + No, you can use ``nodemon`` or ``supervisor`` to start Mojito, which will automatically + update any changes that you've made to your application. - You will need ``npm`` to install ``nodemon`` or ``supervisor``. To use ``nodemon``, you will need a script to start the server. + You will need ``npm`` to install ``nodemon`` or ``supervisor``. To use ``nodemon``, + you will need a script to start the server. Follow the steps below to use ``nodemon``: @@ -158,31 +161,32 @@ General #. In a separate terminal window, make changes to the source code of the application. #. Refresh the page to view the modified application. - .. note:: ``supervisor`` will only update files with extensions ``node`` or ``js`` by default. - To have ``supervisor`` watch files with other extensions, use the option ``-e`` or - ``--extensions``: ``$ supervisor -e js,json,html -x path/to/mojito start`` + .. note:: ``supervisor`` will only update files with extensions ``node`` or ``js`` by + default. To have ``supervisor`` watch files with other extensions, use the + option ``-e`` or ``--extensions``: ``$ supervisor -e js,json,html -x path/to/mojito start`` ------------ .. _moj_req_persistent: .. topic:: **Is the Mojito Y instance persistent across requests?** - Yes, each mojit will have a Y instance that is persistent (by default) for every successive - request. Computing YUI dependencies for every request negatively affects performance. You can - change this behavior through the settings or you can deal with it at the mojit level, recreating - the object. + Yes, each mojit will have a Y instance that is persistent (by default) for every + successive request. Computing YUI dependencies for every request negatively affects + performance. You can change this behavior through the settings or you can deal with it + at the mojit level, recreating the object. ------------ .. _moj_lazyloading: .. topic:: **Does Mojito support lazy loading?** - Yes, the Mojito framework comes with the framework mojit ``LazyLoadMojit`` specifically for lazy - loading. The ``LazyLoadMojit`` allows you to defer the loading of a mojit instance by first - dispatching the ``LazyLoadMojit`` as a proxy to the client. From the client, ``LazyLoadMojit`` - can then request Mojito to load the proxied mojit. This allows your Mojito application to load - the page quickly and then lazily load parts of the page. See - `LazyLoadMojit <../topics/mojito_framework_mojits.html#lazyloadmojit>`_ to learn more. + Yes, the Mojito framework comes with the framework mojit ``LazyLoadMojit`` specifically + for lazy loading. The ``LazyLoadMojit`` allows you to defer the loading of a mojit + instance by first dispatching the ``LazyLoadMojit`` as a proxy to the client. From the + client, ``LazyLoadMojit`` can then request Mojito to load the proxied mojit. This + allows your Mojito application to load the page quickly and then lazily load parts of + the page. See `LazyLoadMojit <../topics/mojito_framework_mojits.html#lazyloadmojit>`_ + to learn more. ------------ @@ -196,14 +200,15 @@ General - **Client-Side Caching** - - `Create an HTML5 application <../reference/mojito_cmdline.html#html5app>`_ and use the ` - `manifest.cache`` file. + - `Create an HTML5 application <../reference/mojito_cmdline.html#html5app>`_ and + use the ``manifest.cache`` file. - Leverage the HTML5 ``localStorage`` object. - - Use the `Storage Lite `_ YUI module that - selects the best available local storage API supported by the browser it's running in. - - `Create an addon <../topics/mojito_extensions.html#creating-new-addons>`_ that uses a - singleton or attaches data to the YUI instance. See the ``shareYUIInstance`` property in - the `configuration object <../intro/mojito_configuring.html#configuration-object>`_. + - Use the `Storage Lite `_ YUI + module that selects the best available local storage API supported by the browser + it's running in. + - `Create an addon <../topics/mojito_extensions.html#creating-new-addons>`_ that + uses a singleton or attaches data to the YUI instance. See the ``shareYUIInstance`` + property in the `configuration object <../intro/mojito_configuring.html#configuration-object>`_. - **Server-Side Caching (implementation depends on server)** @@ -218,32 +223,33 @@ General .. _moj_run_client_server: .. topic:: **Can Mojito make runtime decisions to run client-side or server-side code?** - Yes, but it's up to the programmer to configure the application to be deployed to the client. - Also, your application should have client and server versions, indicated by an - `affinity <../reference/glossary.html#affinity>`_, of the controller, models, addons, etc., - that you want to run on both the client and the server. To configure Mojito to deploy application - code to the client, you set the ``deploy`` property of the application configuration to ``true``. - See `Configuring Applications to Be Deployed to Client <../intro/mojito_configuring.html#configuring-applications-to-be-deployed-to-client>`_ + Yes, but it's up to the programmer to configure the application to be deployed to the + client. Also, your application should have client and server versions, indicated by an + `affinity <../reference/glossary.html#affinity>`_, of the controller, models, addons, + etc., that you want to run on both the client and the server. To configure Mojito to + deploy application code to the client, you set the ``deploy`` property of the + application configuration to ``true``. See `Configuring Applications to Be Deployed to Client <../intro/mojito_configuring.html#configuring-applications-to-be-deployed-to-client>`_ for more information. - Mojito determines the client device based on the HTTP header ``User-Agent`` or the value of the - query string parameter ``device`` and then will render the appropriate view if it exists--it's up - to the developer to create the views. For example, if an iPhone is making a request, Mojito will - render the view ``index.iphone.hb.html`` if it has been created. - See `Views: Naming Conventions <../intro/mojito_mvc.html#naming-convention>`_ for more - information. + Mojito determines the client device based on the HTTP header ``User-Agent`` or the + value of the query string parameter ``device`` and then will render the appropriate + view if it exists--it's up to the developer to create the views. For example, if an + iPhone is making a request, Mojito will render the view ``index.iphone.hb.html`` if it + has been created. See `Views: Naming Conventions <../intro/mojito_mvc.html#naming-convention>`_ + for more information. ------------ .. _moj_req_res_instances: -.. topic:: **Can Mojito applications access the 'request' or 'response' instances of the Node.js - classes 'http.ServerRequest' and 'http.ServerResponse'?** - - Yes, the Mojito API has the ``ActionContext`` addon ``Http.server`` that has methods for getting - the ``request`` and ``response`` instances of the Node.js classes ``http.ServerRequest`` and - ``http.ServerResponse``. From the ``ActionContext`` object ``ac`` shown below, you call - ``http.getRequest`` and ``http.getResponse`` to get the ``request`` and ``response`` instances. - See `Class Http.server <../../api/classes/Http.server.html>`_ for more information. +.. topic:: **Can Mojito applications access the 'request' or 'response' instances of the + Node.js classes 'http.ServerRequest' and 'http.ServerResponse'?** + + Yes, the Mojito API has the ``ActionContext`` addon ``Http.server`` that has methods + for getting the ``request`` and ``response`` instances of the Node.js classes + ``http.ServerRequest`` and ``http.ServerResponse``. From the ``ActionContext`` object + ``ac`` shown below, you call ``http.getRequest`` and ``http.getResponse`` to get the + ``request`` and ``response`` instances. See `Class Http.server <../../api/classes/Http.server.html>`_ + for more information. .. code-block:: javascript @@ -256,17 +262,17 @@ General .. _moj_access_headers: .. topic:: **Is it possible to access HTTP headers from a Mojito application?** - Yes, the Mojito API has the ``ActionContext`` addon ``Http.server`` that allows you to get, set, - and add HTTP headers. See `Class Http.server <../../api/classes/Http.server.html>`_ for the - available methods. + Yes, the Mojito API has the ``ActionContext`` addon ``Http.server`` that allows you to + get, set, and add HTTP headers. See `Class Http.server <../../api/classes/Http.server.html>`_ + for the available methods. ------------ .. _moj_node_start: .. topic:: **Can Mojito be started with Node.js instead of using "mojito start"?** - Yes. Although there is not a standard way for starting Mojito with Node.js, you could do the - following:: + Yes. Although there is not a standard way for starting Mojito with Node.js, you could + do the following:: $ node --debug `which mojito` start @@ -284,35 +290,38 @@ General The following sections offer some ideas about how to improve the performance of your Mojito application, but are by no means exhaustive. You should also review online articles - about improving Node.js performance, such as `Blazing fast node.js: 10 performance tips from - LinkedIn Mobile `_ written by software engineer Shravya Garlapati. + about improving Node.js performance, such as `Blazing fast node.js: 10 performance tips + from LinkedIn Mobile `_ written by software engineer Shravya + Garlapati. **Don't Add User Data to ac.context** The ``context`` property of the ``ActionContext`` object contains a small set of - key/value pairs that define the run-time environment under which a mojit runs. These key/value - pairs are used as a cache key. Adding your own key/values to ``ac.context`` will cause - the cache to bloat. + key-value pairs that define the run-time environment under which a mojit runs. These + key-value pairs are used as a cache key. Adding your own key/values to ``ac.context`` + will cause the cache to bloat. As an alternative, you can share data using the following methods: - * Parent mojits can share data with the child mojits by attaching data to the ``ActionContext`` - object in the parent mojit's controller. For example, in the parent mojit, you could add - an object to ``ac.composite.command.params.body`` that the children can then access with + * Parent mojits can share data with the child mojits by attaching data to the + ``ActionContext`` object in the parent mojit's controller. For example, in the + parent mojit, you could add an object to ``ac.composite.command.params.body`` + that the children can then access with ``ac.composite.command.params.body['{obj_name}']``. * From the server and before mojits are executed, middleware can be used to share information about static handling and routing. * Assets and data can be shared through the - `template <../reference/glossary.html#view-template>`_ of a parent mojit or through a - frame mojit such as - `HTMLFrameMojit <../topics/mojito_framework_mojits.html#htmlframemojit>`_ that creates - a parent template. + `template <../reference/glossary.html#view-template>`_ of a parent mojit or + through a frame mojit such as + `HTMLFrameMojit <../topics/mojito_framework_mojits.html#htmlframemojit>`_ that + creates a parent template. **Rollup/Minify Assets** - Rolling up and minifying assets will reduce the number of network calls and improve load time. - For **rolling up assets**, we recommend that you use - `Shaker `_, which is a static asset rollup manager. + Rolling up and minifying assets will reduce the number of network calls and improve + load time. For **rolling up assets**, we recommend that you use + `Shaker `_, which is a static asset rollup + manager. Mojito also allows you to configure your app to use rollups by setting the ``useRollups`` property in the ``application.json`` file to ``true`` as shown below:: @@ -321,8 +330,9 @@ General "useRollups": true } - You can also compile rollups, inline CSS, or views using the Mojito command-line utility. See - the `Compile System <../reference/mojito_cmdline.html#compile-system>`_ to learn how. + You can also compile rollups, inline CSS, or views using the Mojito command-line + utility. See the `Compile System <../reference/mojito_cmdline.html#compile-system>`_ + to learn how. For **minification**, we recommend Shaker again. Other choices could be `YUI Compressor `_ or an npm module such as @@ -342,21 +352,24 @@ General .. _moj_version_conflict: -.. topic:: **When I run 'mojito version', why is the version different than the version I installed?** - - If you globally installed a version of Mojito (``npm install mojito -g``) that is different - than what is shown when running the the command ``mojito version``, it's likely that Node.js is - using a version of Mojito found in a local ``node_modules`` or ``.node_modules`` directory. - Node.js has an algorithm for resolving different versions of the same module, which - may be the reason it is running a different version of Mojito than you're expecting. You can read - the `high-level algorithm in pseudocode `_ +.. topic:: **When I run 'mojito version', why is the version different than the version I + installed?** + + If you globally installed a version of Mojito (``npm install mojito -g``) that is + different than what is shown when running the the command ``mojito version``, it's + likely that Node.js is using a version of Mojito found in a local ``node_modules`` or + ``.node_modules`` directory. Node.js has an algorithm for resolving different versions + of the same module, which may be the reason it is running a different version of + Mojito than you're expecting. You can read the + `high-level algorithm in pseudocode `_ in the Node.js API documentation. To make sure Node.js runs the global version of Mojito, you should search for local ``node_modules`` and ``.node_modules`` directories and remove ``mojito`` from them. - You can also run ``node -pe 'require.resolve("mojito")'`` to see what version of Mojito is - being used by Node.js. Once you have removed or moved any local versions of Mojito, try running - ``mojito version`` again. You should now see the same version as the globally installed Mojito. + You can also run ``node -pe 'require.resolve("mojito")'`` to see what version of + Mojito is being used by Node.js. Once you have removed or moved any local versions of + Mojito, try running ``mojito version`` again. You should now see the same version as + the globally installed Mojito. @@ -367,16 +380,17 @@ Mojits .. _mojit_exp: .. topic:: **What is a mojit?** - The basic unit of composition and reuse in a Mojito application. It typically corresponds to a - rectangular area of a page and uses MVC. + The basic unit of composition and reuse in a Mojito application. It typically + corresponds to a rectangular area of a page and uses MVC. ------------ .. _moj_children: .. topic:: **Can mojits have child mojits?** - Yes, you can configure your application to have mojits that have one or more child mojits. The - parent mojit can execute the child mojits using the `Composite addon <../../api/classes/Composite.common.html>`_. + Yes, you can configure your application to have mojits that have one or more child + mojits. The parent mojit can execute the child mojits using the + `Composite addon <../../api/classes/Composite.common.html>`_. See `Configuring Applications to Have Multiple Mojit <../intro/mojito_configuring.html#configuring-applications-to-have-multiple-mojits>`_ and `Composite Mojits <../topics/mojito_composite_mojits.html#composite-mojits>`_. @@ -388,8 +402,8 @@ Mojits .. _moj_share_y: .. topic:: **How can the same 'Y' instance be shared among mojits?** - Mojito creates sandboxes for mojits, thus, each mojit has its own ``Y`` instance. To allow - mojito to share one ``Y`` instance, you set the ``shareYUIInstance: true`` in the + Mojito creates sandboxes for mojits, thus, each mojit has its own ``Y`` instance. + To allow mojito to share one ``Y`` instance, you set the ``shareYUIInstance: true`` in the ``application.json`` configuration file. See the `configuration Object <../intro/mojito_configuring.html#configuration-object>`_ for more information. @@ -398,32 +412,34 @@ Mojits .. _moj_objects: .. topic:: **How do mojits share objects?** - You create an application-level middleware or an ActionContext addon that all mojits can access. - Your mojits can use this middleware or the ActionContext addon to share objects. See - `Creating Addons <../topics/mojito_extensions.html#creating-new-addons>`_ and - `Middleware <../topics/mojito_extensions.html#middleware>`_ for implementation details. + You create an application-level middleware or an ActionContext addon that all mojits + can access. Your mojits can use this middleware or the ActionContext addon to share + objects. See `Creating Addons <../topics/mojito_extensions.html#creating-new-addons>`_ + and `Middleware <../topics/mojito_extensions.html#middleware>`_ for implementation + details. ------------ .. _moj_dynamic_creation: .. topic:: **Can mojit instances be dynamically defined and then run?** - You can run dynamically defined instances of mojits that you created with the Mojito command-line - tool. You would create these instances in a mojit controller using the ``ActionContext`` object - with either the ``_dispatch`` or ``execute`` methods. + You can run dynamically defined instances of mojits that you created with the Mojito + command-line tool. You would create these instances in a mojit controller using the + ``ActionContext`` object with either the ``_dispatch`` or ``execute`` methods. See `Running Dynamically Defined Mojit Instances <../topics/mojito_run_dyn_defined_mojits.html>`_ for more information. ------------ -.. _moj_resources: -.. topic:: **Is there a way to make all of the resources, such as assets, addons, binders, models, - of one mojit available to other mojits?** +.. _moj_resources: +.. topic:: **Is there a way to make all of the resources, such as assets, addons, binders, + models, of one mojit available to other mojits?** - To make the resources of one mojit available to other mojits, you set the ``appLevel`` property - in the ``application.json`` file to ``true``. Mojits wanting to use the resources of - application-level mojit must include the YUI module of the application-level mojit in the - ``requires`` array. See `Configuring Metadata <../intro/mojito_configuring.html#configuring-metadata>`_ + To make the resources of one mojit available to other mojits, you set the ``appLevel`` + property in the ``application.json`` file to ``true``. Mojits wanting to use the + resources of application-level mojit must include the YUI module of the + application-level mojit in the ``requires`` array. + See `Configuring Metadata <../intro/mojito_configuring.html#configuring-metadata>`_ for more information. ------------ @@ -431,9 +447,10 @@ Mojits .. _moj_names_hyphens: .. topic:: **Why does Mojito replace hyphens in the names of my mojits with underscores?** - The ECMAScript syntax for ``Identifiers`` does not allow hyphens, so Mojito replaces them with - underscores. See the section **Identifier Names and Identifiers** in the `ECMAScript Documentation `_ - for the syntax rules for ``Identifier`` and ``IdentifierName``. + The ECMAScript syntax for ``Identifiers`` does not allow hyphens, so Mojito replaces + them with underscores. See the section **Identifier Names and Identifiers** in the + `ECMAScript Documentation `_ for the syntax rules + for ``Identifier`` and ``IdentifierName``. @@ -453,40 +470,41 @@ Configuration Binders always get deployed to the client, but to deploy your controller to the client, you need to use the `HTMLFrameMojit <../topics/mojito_framework_mojits.html#htmlframemojit>`_ and set the ``deploy`` field to ``true`` in the ``application.json`` file. See - `Deploying to Client <../topics/mojito_framework_mojits.html#deploying-to-client>`_ for more - details. + `Deploying to Client <../topics/mojito_framework_mojits.html#deploying-to-client>`_ + for more details. ------------ .. _moj_client: .. topic:: **How do you configure mojits to run on the client?** - Run Mojito at build time to generate the html page using "mojito build html5app". This runs the - Mojito infrastructure as if it were a running server instance and prints out the resulting - HTML+JSON required to bootstrap a client-side mojit. This is what Livestand does. Among other - things, it leads down a path where it's very hard to do incremental builds because the Web server - abstraction makes it hard to do the timestamp resolution that incremental builds require. A - better approach would be to allow people to hard-code the top-level mojit bootstrap code - by publishing mojit creation APIs that can be called from the top level. + Run Mojito at build time to generate the html page using "mojito build html5app". This + runs the Mojito infrastructure as if it were a running server instance and prints out + the resulting HTML+JSON required to bootstrap a client-side mojit. This is what + Livestand does. Among other things, it leads down a path where it's very hard to do + incremental builds because the Web server abstraction makes it hard to do the timestamp + resolution that incremental builds require. A better approach would be to allow people + to hard-code the top-level mojit bootstrap code by publishing mojit creation APIs that + can be called from the top level. ------------ .. _moj_config_port: .. topic:: **How do I configure the Mojito server to listen to specific port?** - In the `configuration Object <../intro/mojito_configuring.html#configuration-object>`_ of - ``application.json``, you set the ``appPort`` property to the port number that you want Mojito - to listen to. + In the `configuration Object <../intro/mojito_configuring.html#configuration-object>`_ + of ``application.json``, you set the ``appPort`` property to the port number that you + want Mojito to listen to. ------------ .. _moj_definition_defaults: .. topic:: **What is the difference between 'definition.json' and 'defaults.json'?** - The ``definitions.json`` file stores the class-level mojit values and is ideal for storing - metadata. The ``defaults.json`` file stories default configurations for your mojit instance that - will be overridden if they are found in the ``application.json`` file. See `Configuring Defaults - for Mojit Instances <../intro/mojito_configuring.html#configuring-defaults-for-mojit-instances>`_ + The ``definitions.json`` file stores the class-level mojit values and is ideal for + storing metadata. The ``defaults.json`` file stories default configurations for your + mojit instance that will be overridden if they are found in the ``application.json`` + file. See `Configuring Defaults for Mojit Instances <../intro/mojito_configuring.html#configuring-defaults-for-mojit-instances>`_ and `Configuring Defaults for Mojit Instances <../intro/mojito_configuring.html#configuring-defaults-for-mojit-instances>`_ for more information. @@ -500,9 +518,9 @@ Data .. _moj_content: .. topic:: **How do I get content for my mojits?** - YQL is the preferred method for accessing data in Mojito applications. YUI 3 also has a - `YQL module `_ that makes calling the YQL Web Service - easy. + YQL is the preferred method for accessing data in Mojito applications. YUI 3 also has + a `YQL module `_ that makes calling the YQL + Web Service easy. ------------ @@ -510,19 +528,20 @@ Data .. topic:: **How is data shared among mojits?** You can create an application-level mojit that can share data with its children. Your - application-level mojit would have a model to get data that can be stored data in a Model object. - The child mojits can then access this data through the application-level mojit's model. + application-level mojit would have a model to get data that can be stored data in a + Model object. The child mojits can then access this data through the application-level + mojit's model. ------------ .. _moj_parent_mojit_data: .. topic:: **How does a parent mojit send data to the template?** - From the controller of the parent mojit, pass the ``template`` object to ``ac.done`` as seen - below. The ``template`` object can contain key-value pairs that can be added to the view - template as Handlebars expressions. For example, the key ``foo`` in the ``template`` object shown - here can be used in the template as ``{{foo}}``, which will be replaced by the value 'bar' - when the template is rendered. + From the controller of the parent mojit, pass the ``template`` object to ``ac.done`` + as seen below. The ``template`` object can contain key-value pairs that can be added + to the view template as Handlebars expressions. For example, the key ``foo`` in the + ``template`` object shown here can be used in the template as ``{{foo}}``, which will + be replaced by the value 'bar' when the template is rendered. ``// Inside parent mojit`` @@ -533,24 +552,58 @@ Data .. _moj_params_controller_binder: .. topic:: **In Mojito applications, how are parameters passed from the controller to binders?** - In the controller, save a reference of the ``config`` object that is passed to the controller in the ``init`` function. - From the saved reference, you can add an additional parameter (e.g., this.config.addtionalParam) in other controller functions. In the binder, - you can access the additional parameter using the ``mojitProxy`` object passed to the ``init`` function. So, if the additional parameter added to - the ``config`` object in the controller was ``additionalParameter``, you can access that parameter in the binder using ``this.mojitProxy.config.additionalParam``. + Your controllers can pass parameters to binders by assigning values to + ``ac.instance.config.{property}`` in methods that are passed the ``ActionContext`` + object. The binder accesses those parameters through ``mojitProxy.config.{property}``. + In the ``index`` method of the controller below, the key-value pair + ``"name": "Mojito"`` is stored with ``ac.instance.config.name = "Mojito"``. + + .. code-block:: javascript + + YUI.add('myMojit', function(Y, NAME) { + Y.namespace('mojito.controllers')[NAME] = { + index: function(ac) { + ac.instance.config.name = "Mojito"; + ... + } + ... + }; + }, '0.0.1', {requires: ['mojito', 'myMojitModelFoo']}); + + The code snippet of the binder shown below references the key ``name`` + with ``this.mojitProxy.config.name``. + + .. code-block:: javascript + + YUI.add('myMojitBinderIndex', function(Y, NAME) { + Y.namespace('mojito.binders')[NAME] = { + init: function(mojitProxy) { + this.mojitProxy = mojitProxy; + }, + bind: function(node) { + Y.log(this.mojitProxy.config.name); + ... + } + ... + }; + }, '0.0.1', {requires: ['mojito-client']}); + ------------ .. _moj_pass_data_parent_to_child: .. topic:: **How can data be passed from a parent mojit to its child mojits?** - Currently the only way to do this is to pass data to the children in either the children config - or parameters. If you use ``ac.composite.execute`` you can create/modify the children - configuration in code before calling ``ac.composite.execute`` . See `ac.composite.execute <../../api/classes/Composite.common.html#method_execute>`_ + Currently the only way to do this is to pass data to the children in either the + children config or parameters. If you use ``ac.composite.execute`` you can + create/modify the children configuration in code before calling + ``ac.composite.execute``. See `ac.composite.execute <../../api/classes/Composite.common.html#method_execute>`_ for more information. - If you want to pass the data to the children in the parameters, you can do that with the - ``ac._dispatch`` function. See `ac._dispatch <../../api/classes/ActionContext.html#method__dispatch>`_ - for more information. + If you want to pass the data to the children in the parameters, you can do that with + the ``ac._dispatch`` function. See + `ac._dispatch <../../api/classes/ActionContext.html#method__dispatch>`_ for more + information. Binders ------- @@ -558,8 +611,8 @@ Binders .. _moj_binders: .. topic:: **What are binders and what do they do?** - Binders are mojit code that is only deployed to the browser. A mojit may have zero, one, or many - binders. The code can perform the following three functions: + Binders are mojit code that is only deployed to the browser. A mojit may have zero, + one, or many binders. The code can perform the following three functions: * allow event handlers to attach to the mojit DOM node * communicate with other mojits on the page @@ -573,22 +626,23 @@ CSS/JavaScript Assets .. _moj_assets: .. topic:: **How do I add assets templates?** - You define the location of application-level or mojit-level assets in the ``application.json`` - file. Once the location of your assets has been configured, you can statically add the path to - the assets in your template. You can also add assets to your view using the - `Assets addon <../../api/classes/Assets.common.html>`_ if your application is using the - ``HTMLFrameMojit``. See the `Assets <../topics/mojito_assets.html>`_ documentation for - implementation details. + You define the location of application-level or mojit-level assets in the + ``application.json`` file. Once the location of your assets has been configured, you + can statically add the path to the assets in your template. You can also add assets to + your view using the `Assets addon <../../api/classes/Assets.common.html>`_ if your + application is using the ``HTMLFrameMojit``. See the `Assets <../topics/mojito_assets.html>`_ + documentation for implementation details. ------------ .. _moj_dyn_assets: .. topic:: **How are assets dynamically added to views?** - The `Assets addon <../../api/classes/Assets.common.html>`_ allow you to dynamically add to your - view. You need to use the ``HTMLFrameMojit``, however, to use the ``Assets addon``. See - `Using the Assets Addon <../topics/mojito_assets.html#using-the-assets-addon>`_ for more - information. + The `Assets addon <../../api/classes/Assets.common.html>`_ allow you to dynamically + add to your view. You need to use the ``HTMLFrameMojit``, however, to use the + ``Assets addon``. See + `Using the Assets Addon <../topics/mojito_assets.html#using-the-assets-addon>`_ for + more information. Views @@ -597,8 +651,8 @@ Views .. _moj_partials: .. topic:: **Does Mojito support view partials?** - Mojito does not support partials, but you do have the following options for rendering data - through a template: + Mojito does not support partials, but you do have the following options for rendering + data through a template: * use a child mojit instead of a view partial * render data from a binder through a specific template with the @@ -625,33 +679,34 @@ Views .. _moj_refresh_view: .. topic:: **How do I refresh the view on the client?** - To refresh a view, you need to deploy a binder on the client. From the ``mojitProxy`` object of - the binder, you can call the ``refreshView`` method to render a new DOM node for the current - mojit and its children, as well as reattach all of the existing binders to their new nodes - within the new markup. Because all binder instances are retained, state can be stored within a - binder's scope. See `Refreshing Views <../intro/mojito_binders.html#refreshing-views>`_ and the - `MojitProxy Class <../../api/classes/MojitProxy.html>`_ in the Mojito API documentation for more - information. + To refresh a view, you need to deploy a binder on the client. From the ``mojitProxy`` + object of the binder, you can call the ``refreshView`` method to render a new DOM node + for the current mojit and its children, as well as reattach all of the existing + binders to their new nodes within the new markup. Because all binder instances are + retained, state can be stored within a binder's scope. See + `Refreshing Views <../intro/mojito_binders.html#refreshing-views>`_ and the + `MojitProxy Class <../../api/classes/MojitProxy.html>`_ in the Mojito API + documentation for more information. ------------ .. _moj_different_templating: .. topic:: **Can I use a different templating system other than Handlebars?** - Mojito currently only comes with a Handlebars rendering engine, but you can add other rendering - engines for templating systems such as EJS or Jade. See the - `View Engine <../topics/mojito_extensions.html#view-engines>`_ documentation for implementation - details. + Mojito currently only comes with a Handlebars rendering engine, but you can add other + rendering engines for templating systems such as EJS or Jade. See the + `View Engine <../topics/mojito_extensions.html#view-engines>`_ documentation for + implementation details. ------------ .. _moj_controller_specify_view: .. topic:: **Can the mojit controller specify which template should be rendered?** - Yes, you can a ``view`` object as the second parameter to ``ac.done`` that specifies which - template should receive the data and be rendered. - See `Controllers: Specifying the View <../intro/mojito_mvc.html#specifying-the-view>`_ for - details. + Yes, you can a ``view`` object as the second parameter to ``ac.done`` that specifies + which template should receive the data and be rendered. + See `Controllers: Specifying the View <../intro/mojito_mvc.html#specifying-the-view>`_ + for details. Logging/Testing @@ -661,8 +716,8 @@ Logging/Testing .. topic:: **How do I change the logging levels for my Mojito application?** You can set log levels for your application using the ``log`` object in ``application.json``. - You can also set default log levels using the ``log`` object in the ``defaults.json`` at the - application or mojit level. + You can also set default log levels using the ``log`` object in the ``defaults.json`` + at the application or mojit level. See `Logging <../topics/mojito_logging.html>`_ for details and the code example `Simple Logging <../code_exs/simple_logging.html>`_. @@ -673,9 +728,9 @@ Logging/Testing .. _moj_mod_log_exclusion: .. topic:: **Is there a way to exclude specific modules from logging on the client?** - Mojito does not offer such a fine-grain control over logging. Because each log statement tends - to be associated with a module name, you could start Mojito with the following command to - exclude the logs for certain modules: + Mojito does not offer such a fine-grain control over logging. Because each log + statement tends to be associated with a module name, you could start Mojito with the + following command to exclude the logs for certain modules: ``$ mojito start 2>&1 | grep -v ModuleName`` @@ -684,11 +739,11 @@ Logging/Testing .. _moj_client_server_logging: .. topic:: **Can logging be configured to be different for the client and server?** - Yes, the ``application.json`` configuration file can contain a ``log`` object that has a - ``client`` and a ``server`` object that allow you to independently configure logging for the - client and server. See `log Object <../intro/mojito_configuring.html#log-object>`_ and the - `Log Configuration <../topics/mojito_logging.html#log-configuration>`_ for implementation - details. + Yes, the ``application.json`` configuration file can contain a ``log`` object that has + a ``client`` and a ``server`` object that allow you to independently configure logging + for the client and server. See `log Object <../intro/mojito_configuring.html#log-object>`_ + and the `Log Configuration <../topics/mojito_logging.html#log-configuration>`_ for + implementation details. Addons/Libraries/Middleware @@ -697,17 +752,19 @@ Addons/Libraries/Middleware .. _moj_api_addons: .. topic:: **Does the Mojito framework offer API methods or addons?** - The Mojito framework provides API methods and addons through the ``ActionContext`` object. For - an overview of the API and addons, see `Mojito API Overview <../api_overview/>`_. To see the API - specifications and the available addons, see the `Mojito API documentation <../../api/>`_. + The Mojito framework provides API methods and addons through the ``ActionContext`` + object. For an overview of the API and addons, see + `Mojito API Overview <../api_overview/>`_. To see the API specifications and the + available addons, see the `Mojito API documentation <../../api/>`_. ------------ .. _moj_yui: .. topic:: **Can I repurpose or extend existing YUI modules?** - Although Mojit developers will have access to a library of modules, we realistically expect - modules to require some tweaking before they can be re-purposed. Mojito, however, does - offer facilities that make it possible and easy to extend existing modules. + Although Mojit developers will have access to a library of modules, we realistically + expect modules to require some tweaking before they can be re-purposed. Mojito, + however, does offer facilities that make it possible and easy to extend existing + modules.