Zend_Dojo-Data.xml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <sect1 id="zend.dojo.data">
  4. <title>Zend_Dojo_Data: Envolturas de dojo.data</title>
  5. <para>
  6. Dojo proporciona abstracción de datos para los widgets de datos
  7. habilitados a través de su componente dojo.data. Este componente
  8. proporciona la capacidad de adjuntar un datastore, ofrecer algunos
  9. metadatos relativos al campo identidad, opcionalmente una etiqueta de
  10. campo, y una API para efectuar consultas, clasificación, recuperación
  11. de archivos y conjuntos de registros del datastore.
  12. </para>
  13. <para>
  14. dojo.data se utiliza a menudo con XmlHttpRequest para traer dinámicamente
  15. datos desde el servidor. El principal mecanismo para esto es extender
  16. el QueryReadStore para que apunte a una URL y especificar la información
  17. a consultar. El lado del servidor después devuelve los datos con el
  18. siguiente formato JSON:
  19. </para>
  20. <programlisting role="javascript"><![CDATA[
  21. {
  22. identifier: '<name>',
  23. <label: '<label>',>
  24. items: [
  25. { name: '...', label: '...', someKey: '...' },
  26. ...
  27. ]
  28. }
  29. ]]></programlisting>
  30. <para>
  31. <classname>Zend_Dojo_Data</classname> ofrece una interfaz simple para la
  32. construcción de estas estructuras programáticamente, interactuando
  33. con ellos, y serializándolos a un array o a JSON.
  34. </para>
  35. <sect2 id="zend.dojo.data.usage">
  36. <title>Uso de Zend_Dojo_Data</title>
  37. <para>
  38. En su forma más simple, dojo.data requiere que se proporcione el
  39. nombre del campo identificador en cada item, y un conjunto de
  40. items (datos). Puede pasarlos tanto via el constructor, o via mutators:
  41. </para>
  42. <example id="zend.dojo.data.usage.constructor">
  43. <title>Inicialización de Zend_Dojo_Data via constructor</title>
  44. <programlisting role="php"><![CDATA[
  45. $data = new Zend_Dojo_Data('id', $items);
  46. ]]></programlisting>
  47. </example>
  48. <example id="zend.dojo.data.usage.mutators">
  49. <title>Inicialización de Zend_Dojo_Data via mutators</title>
  50. <programlisting role="php"><![CDATA[
  51. $data = new Zend_Dojo_Data();
  52. $data->setIdentifier('id')
  53. ->addItems($items);
  54. ]]></programlisting>
  55. </example>
  56. <para>
  57. También puede añadir un solo item a la vez, o agregar items utilizando
  58. <code>addItem()</code> y <code>addItems()</code>.
  59. </para>
  60. <example id="zend.dojo.data.usage.append">
  61. <title>Agregando datos a <classname>Zend_Dojo_Data</classname></title>
  62. <programlisting role="php"><![CDATA[
  63. $data = new Zend_Dojo_Data($identifier, $items);
  64. $data->addItem($someItem);
  65. $data->addItems($someMoreItems);
  66. ]]></programlisting>
  67. </example>
  68. <note>
  69. <title>Siempre use un identificador!</title>
  70. <para>
  71. Cada datastore de dojo.data requiere que la columna identificadora
  72. se proporcione como metadatos, incluyendo
  73. <classname>Zend_Dojo_Data</classname>.
  74. De hecho, si intenta añadir items sin un identificador, se
  75. generará una excepción.
  76. </para>
  77. </note>
  78. <para>
  79. Los items individuales pueden ser uno de los siguientes:
  80. </para>
  81. <itemizedlist>
  82. <listitem><para>
  83. Arrays asociativos
  84. </para></listitem>
  85. <listitem><para>
  86. Objectos implementando un método <code>toArray()</code>
  87. </para></listitem>
  88. <listitem><para>
  89. Cualquiera de los otros objetos (se serializarán via get_object_vars())
  90. </para></listitem>
  91. </itemizedlist>
  92. <para>
  93. Puede adjuntar colecciones de los items anteriores via
  94. <code>addItems()</code> o <code>setItems()</code>
  95. (sobreescribe todos los items previamente establecidos); cuando lo
  96. haga, puede pasar un solo argumento:
  97. </para>
  98. <itemizedlist>
  99. <listitem><para>
  100. Arrays
  101. </para></listitem>
  102. <listitem><para>
  103. Objectos implementando la interfaz <code>Traversable</code>,
  104. que incluye las interfaces <code>Iterator</code> y
  105. <code>ArrayAccess</code>.
  106. </para></listitem>
  107. </itemizedlist>
  108. <para>
  109. Si quiere especificar un campo que actuará como una etiqueta para
  110. el item, llame a <code>setLabel()</code>:
  111. </para>
  112. <example id="zend.dojo.data.usage.label">
  113. <title>Especificando la etiqueta de un campo en
  114. <classname>Zend_Dojo_Data</classname></title>
  115. <programlisting role="php"><![CDATA[
  116. $data->setLabel('name');
  117. ]]></programlisting>
  118. </example>
  119. <para>
  120. Por último, también puede cargar un item
  121. <classname>Zend_Dojo_Data</classname>
  122. de un array JSON dojo.data, utilizando el método
  123. <code>fromJson()</code>.
  124. </para>
  125. <example id="zend.dojo.data.usage.populate">
  126. <title>Alimentando <classname>Zend_Dojo_Data</classname> desde JSON</title>
  127. <programlisting role="php"><![CDATA[
  128. $data->fromJson($json);
  129. ]]></programlisting>
  130. </example>
  131. </sect2>
  132. <sect2 id="zend.dojo.data.metadata">
  133. <title>Agregando metadatos a sus contenedores</title>
  134. <para>
  135. Algunos componentes de Dojo requieren metadatos adicionales junto
  136. al conjunto de datos de dojo.data.
  137. Como ejemplo, <code>dojox.grid.Grid</code> puede tirar datos
  138. dinámicamente desde un <code>dojox.data.QueryReadStore</code>.
  139. Para que la paginación funcione correctamente, cada conjunto de datos
  140. de regreso debería contener una clave <code>numRows</code> con el
  141. número total de filas que podrían ser devueltas por la consulta.
  142. Con estos datos, la plantilla sabe cuando seguir haciendo pequeños
  143. pedidos de subconjuntos de datos al servidor y cuando dejar de
  144. hacer más peticiones (es decir, ha llegado a la última página de
  145. datos). Esta técnica es útil para despachar grandes conjuntos de
  146. datos en sus plantillas sin cargar todo el conjunto de una sola vez.
  147. </para>
  148. <para>
  149. <classname>Zend_Dojo_Data</classname> permite asignar propiedades
  150. a los metadatos como al objeto. Lo siguiente ilustra su uso:
  151. </para>
  152. <programlisting role="php"><![CDATA[
  153. // Establece el "numRows" a 100
  154. $data->setMetadata('numRows', 100);
  155. // Establece varios items a la vez:
  156. $data->setMetadata(array(
  157. 'numRows' => 100,
  158. 'sort' => 'name',
  159. ));
  160. // Inspecciona un único valor de metadatos:
  161. $numRows = $data->getMetadata('numRows');
  162. // Inspecciona todos los metadatos:
  163. $metadata = $data->getMetadata();
  164. // Elimina un item de metadatos:
  165. $data->clearMetadata('numRows');
  166. // Elimina todos los metadatos:
  167. $data->clearMetadata();
  168. ]]></programlisting>
  169. </sect2>
  170. <sect2 id="zend.dojo.data.advanced">
  171. <title>Casos Avanzados de Uso</title>
  172. <para>
  173. Además de actuar como un contenedor de datos serializable,
  174. <classname>Zend_Dojo_Data</classname> también ofrece la posibilidad
  175. de manipular y recorrer los datos en una variedad de formas.
  176. </para>
  177. <para>
  178. <classname>Zend_Dojo_Data</classname> implementa las interfaces
  179. <code>ArrayAccess</code>, <code>Iterator</code>, y
  180. <code>Countable</code>. Por lo tanto, puede usar la recopilación de
  181. datos casi como si fuera un array.
  182. </para>
  183. <para>
  184. Todos los items son referenciados por el identificador de campo.
  185. Dado que los identificadores deben ser únicos, puede usar los
  186. valores de este campo para sacar los registros individuales.
  187. Hay dos maneras de hacer esto: con el método <code>getItem()</code>,
  188. o via notación de array.
  189. </para>
  190. <programlisting role="php"><![CDATA[
  191. // Usando getItem():
  192. $item = $data->getItem('foo');
  193. // O usando notación de array:
  194. $item = $data['foo'];
  195. ]]></programlisting>
  196. <para>
  197. Si conoce el identificador, puede utilizarlo para recuperar un item,
  198. actualizarlo, borrarlo, crearlo, o probarlo:
  199. </para>
  200. <programlisting role="php"><![CDATA[
  201. // Actualizar o crear un item:
  202. $data['foo'] = array('title' => 'Foo', 'email' => 'foo@foo.com');
  203. // Borrar un item:
  204. unset($data['foo']);
  205. // Efectuar una prueba para un item:
  206. if (isset($data[foo])) {
  207. }
  208. ]]></programlisting>
  209. <para>
  210. También puede hacer un loop sobre todos los items.
  211. Internamente, todos los items se almacenan como arrays.
  212. </para>
  213. <programlisting role="php"><![CDATA[
  214. foreach ($data as $item) {
  215. echo $item['title'] . ': ' . $item['description'] . "\n";
  216. }
  217. ]]></programlisting>
  218. <para>
  219. O inclusive contar para ver cuántos ítems tiene:
  220. </para>
  221. <programlisting role="php"><![CDATA[
  222. echo count($data), " items encontrados!";
  223. ]]></programlisting>
  224. <para>
  225. Por último, como la clase implementa <code>__toString()</code>,
  226. también puede convertirlo a JSON simplemente con "echo" de PHP o
  227. convertirlo a string:
  228. </para>
  229. <programlisting role="php"><![CDATA[
  230. echo $data; // echo como un string JSON
  231. $json = (string) $data; // conversión a string == conversión a JSON
  232. ]]></programlisting>
  233. <sect3 id="zend.dojo.data.advanced.methods">
  234. <title>Métodos Disponibles</title>
  235. <para>
  236. Además de los métodos necesarios para aplicar las interfaces
  237. enumeradas anteriormente, están disponibles los siguientes métodos.
  238. </para>
  239. <itemizedlist>
  240. <listitem><para>
  241. <code>setItems($items)</code>: establece varios items a la
  242. vez, sobrescribiendo cualquier item que figurase anteriormente
  243. en el objeto. <code>$items</code> debe ser un array o un
  244. objeto <code>Traversable</code>.
  245. </para></listitem>
  246. <listitem><para>
  247. <code>setItem($item, $id = null)</code>: establece un
  248. item individual, opcionalmente puede pasar un identificador
  249. explícito. Sobreescribe el item si ya existe en la colección.
  250. Los items válidos incluyen a arrays asociativos, objetos
  251. implementando <code>toArray()</code>, o cualquier objeto
  252. con propiedades públicas.
  253. </para></listitem>
  254. <listitem><para>
  255. <code>addItem($item, $id = null)</code>: añade un item
  256. individual, opcionalmente puede pasar un identificador
  257. explícito.
  258. Generará una excepción si el item ya existe en la colección.
  259. Los items válidos incluyen a arrays asociativos, objetos
  260. implementando <code>toArray()</code>, o cualquier objeto
  261. con propiedades públicas.
  262. </para></listitem>
  263. <listitem><para>
  264. <code>addItems($items)</code>: agrega múltiples items a la
  265. vez, añadiendolos a cualquiera de los items actuales.
  266. Generará una excepción si alguno de los nuevos items tiene
  267. un identificador concordante a un identificador ya existente
  268. en la colección. <code>$items</code> debe ser un array o un
  269. objeto <code>Traversable</code>.
  270. </para></listitem>
  271. <listitem><para>
  272. <code>getItems()</code>: recupera todos los items como un
  273. array de arrays.
  274. </para></listitem>
  275. <listitem><para>
  276. <code>hasItem($id)</code>: determina si un item con el
  277. identificador dado existe en la colección.
  278. </para></listitem>
  279. <listitem><para>
  280. <code>getItem($id)</code>: recupera un item con el
  281. identificador dado de la colección; el item retornado será
  282. un array asociativo. Si ningún item coincide, se devolverá
  283. un valor null.
  284. </para></listitem>
  285. <listitem><para>
  286. <code>removeItem($id)</code>: elimina de la colección un
  287. item con el identificador dado.
  288. </para></listitem>
  289. <listitem><para>
  290. <code>clearItems()</code>: elimina todos los items de la
  291. colección.
  292. </para></listitem>
  293. <listitem><para>
  294. <code>setIdentifier($identifier)</code>: establece el
  295. nombre del campo que representa el identificador único para
  296. cada item en la colección.
  297. </para></listitem>
  298. <listitem><para>
  299. <code>getIdentifier()</code>: recupera el nombre del campo
  300. identificador.
  301. </para></listitem>
  302. <listitem><para>
  303. <code>setLabel($label)</code>: establece el nombre de un
  304. campo para ser utilizado como la etiqueta a mostrar para
  305. un item.
  306. </para></listitem>
  307. <listitem><para>
  308. <code>getLabel()</code>: recupera la etiqueta del nombre
  309. del campo.
  310. </para></listitem>
  311. <listitem><para>
  312. <code>toArray()</code>: enviar el objeto a un array.
  313. Como mínimo, el array contendrá las claves 'identifier',
  314. 'items', y 'label' si una etiqueta de campo ha sido
  315. establecida en el objeto.
  316. </para></listitem>
  317. <listitem><para>
  318. <code>toJson()</code>: enviar el objeto a una representación JSON.
  319. </para></listitem>
  320. </itemizedlist>
  321. </sect3>
  322. </sect2>
  323. </sect1>
  324. <!--
  325. vim:se ts=4 sw=4 et:
  326. -->