/documentation/manual/ar/module_specs/Zend_View-Controllers.xml

https://github.com/decaoz/zf1 · XML · 154 lines · 122 code · 29 blank · 3 comment · 0 complexity · 61ec62e8fb288d92182ae255c751a5ef MD5 · raw file

  1. <sect1 id="zend.view.controllers">
  2. <title>جزء الـ Controller</title>
  3. <para>
  4. الـ controller هو حيث يتم إنشاء نسخة من Zend_View و إعدادها , أنت بعد ذلك تقم
  5. بإنشاء متغيرات جديدة فيها و إعطائها قيم ليتم إستخدامها فى الـ view ,
  6. ثم تقوم بالأمر بأن يتم معاجلة الـ view و إنتاج الخرج الذى سيتم عرضه.
  7. </para>
  8. <sect2 id="zend.view.controllers.assign">
  9. <title>إنشاء متغيرات و إعطائها قيم</title>
  10. <para>
  11. يجب أن يقوم الـ controller خاصتك بإنشاء المتغيرات التى يحتاج إليها فى الـ view و تمريرها له
  12. قبل أن يقوم بنقل التحكم إلى الكود الخاص بالـ view , بشكل طبيعى يمكنك إضافة متغيرات إلى
  13. الـ view عن طريق الـ properties الخاصة بالنسخة التى أنشئتها من Zend_View :
  14. </para>
  15. <programlisting role="php"><![CDATA[<?php
  16. $view = new Zend_View();
  17. $view->a = "Hay";
  18. $view->b = "Bee";
  19. $view->c = "Sea";
  20. ?>]]>
  21. </programlisting>
  22. <para>
  23. لكن ربما هذا سيكون مزعج فى حالة أنك قد قمت مسبقاً بجمع كل القيم التى تريد تمريرها فى مصفوفة
  24. أو فى كائن.
  25. </para>
  26. <para>
  27. الـ method المسمى ()assign يسمح لك بإنشاء متغيرات من مصفوفة أو كائن (بشكل مفكك) ,
  28. المثال التالى لديه نفس التأثير الذى تقوم به عملية إنشاء المتغيرات واحد-واحد .
  29. </para>
  30. <programlisting role="php"><![CDATA[<?php
  31. $view = new Zend_View();
  32. // assign an array of key-value pairs, where the
  33. // key is the variable name, and the value is
  34. // the assigned value.
  35. $array = array(
  36. 'a' => "Hay",
  37. 'b' => "Bee",
  38. 'c' => "Sea",
  39. );
  40. $view->assign($array);
  41. // do the same with an object's public properties;
  42. // note how we cast it to an array when assigning.
  43. $obj = new StdClass;
  44. $obj->a = "Hay";
  45. $obj->b = "Bee";
  46. $obj->c = "Sea";
  47. $view->assign((array) $obj);
  48. ?>]]>
  49. </programlisting>
  50. <para>
  51. أيضاً, يمكنك ان تستخدم الـ method المسمى assign لإنشاء متغيرت بطريقة واحد-واحد ,
  52. و ذلك عن طريق تمرير اسم المتغير الذى تريد إنشائه كـ string , ثم فى البراميتر الثانى
  53. مرر قيمة المتغير .
  54. </para>
  55. <programlisting role="php"><![CDATA[<?php
  56. $view = new Zend_View();
  57. $view->assign('a', "Hay");
  58. $view->assign('b', "Bee");
  59. $view->assign('c', "Sea");
  60. ?>]]>
  61. </programlisting>
  62. </sect2>
  63. <sect2 id="zend.view.controllers.render">
  64. <title>معالجة(تصيير) جزء الـ View</title>
  65. <para>
  66. بمجرد إنتهائك من عملية إنساب المتغيرات التى تحتاجها فى الـ view , يجب أن يقوم الـ controller
  67. بأمر Zend_View أن يقوم بمعالجة view محدد , يمكن القيام بهذا عن طريق إستدعاء الـ method
  68. المسمى ()render , لاحظ أن هذا الـ method سيقوم بإرجاع الـ view بعد معالجته و لن يقوم بطباعته,
  69. لذلك أنت تحتاج لطباعته بنفسك فى الوقت الذى يناسبك.
  70. </para>
  71. <programlisting role="php"><![CDATA[<?php
  72. $view = new Zend_View();
  73. $view->a = "Hay";
  74. $view->b = "Bee";
  75. $view->c = "Sea";
  76. echo $view->render('someView.php');
  77. ?>]]>
  78. </programlisting>
  79. </sect2>
  80. <sect2 id="zend.view.controllers.script-paths">
  81. <title>مسارات أجزاء الـ View</title>
  82. <para>
  83. الأعدادات الأساسية لـ Zend_View تعتبر أن الملفات التى تحتوى أجزاء الـ view خاصتك
  84. تتواجد فى مسارات لها علاقة "relative" مع مكان تواجد الكود الذى يستدعيها,
  85. على سبيل المثال : إن كان الـ controller خاصتك موجود فى "path/to/app/controllers/"
  86. و هو يقوم بإستدعاء ('view->render('someView.php$ , سيقوم Zend_View
  87. بالبحث فى المسار "path/to/app/controllers/someView.php/".
  88. </para>
  89. <para>
  90. من الطبيعى أن تكون ملفات الـ view خاصتك محفوظة فى مسار أخر ,
  91. لكى تخبر Zend_View أين يجب عليه أن يبحث عن ملفات الـ view ,
  92. يمكنك إستخدام الـ method المسمى ()setScriptPath .
  93. </para>
  94. <programlisting role="php"><![CDATA[<?php
  95. $view = new Zend_View();
  96. $view->setScriptPath('/path/to/app/views');
  97. ?>]]>
  98. </programlisting>
  99. <para>
  100. الأن عندما ستقوم بإستدعاء ('view->render('someView.php$ ,
  101. سيتم البحث فى المسار "path/to/app/views/someView.php/".
  102. </para>
  103. <para>
  104. فى الحقيقة, يمكنك عمل مرصوصة من المسارات بإستخدام الـ method المسمى ()addScriptPath ,
  105. كلما قمت بإضافة مسار جديد إلى المرصوصة , سيقوم Zend_View بالبحث فى المسارات التى تم إضافتها
  106. إلى المرصوصة من أخر واحد تم إضافته إلى المرصوصة صعوداً إلى أول من تم إضافته
  107. لجلب جزء الـ view المراد معالجته, هذا يسمح لك بأن تقوم بالتغطية على الـ views
  108. الأساسية و إستخدام views أخرى , و هذا سيسمح لك بأن تقوم بإنشاء themes أو skins خاصة لبعض
  109. الـ views , مع أمكانية ترك views أخرى بدون.
  110. </para>
  111. <programlisting role="php"><![CDATA[<?php
  112. $view = new Zend_View();
  113. $view->addScriptPath('/path/to/app/views');
  114. $view->addScriptPath('/path/to/custom/');
  115. // now when you call $view->render('booklist.php'), Zend_View will
  116. // look first for "/path/to/custom/booklist.php", then for
  117. // "/path/to/app/views/booklist.php", and finally in the current
  118. // directory for "booklist.php".
  119. ?>]]>
  120. </programlisting>
  121. </sect2>
  122. </sect1>
  123. <!--
  124. vim:se ts=4 sw=4 et:
  125. -->