程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> xml在joomla表單中的應用詳解分享

xml在joomla表單中的應用詳解分享

編輯:關於PHP編程

使用起來基本都有固定格式,在此不多說,這裡主要說說xml在創建表單中的應用.表單的作用不言而喻,在模塊配置裡面有表單,組件裡面也有表單,這裡的配置裡面的參數設置就是xml生成的表單,相對於通過直接建表單方便不少,這裡通過編輯文章表單的使用過程來說,在使用之前,我們先來了解一下表單元素的類型,joomla提供了生成多種表單元素樣式.
復制代碼 代碼如下:
<param name="created" type="calendar" label="創建時間" description="時間顯示" /> //生成日歷時間
<param name="catid" type="category" default="2" label="Category" description="文章分類列表" /> //得到單元列表
<param name="catid" type="category" section="com_weblinks" default="0" label="Category" description="其他組件分類" /> //其他組件單元列表
<param name='m1' type='editors' label='編輯' /> //編輯器選擇列表
<param name='m1' type='filelist' label='編輯' directory='/images' hide_default="1" filter="html"/> //文件列表 html表示顯示擴展名為html
<param name='m1' type='Folderlist' label='編輯' directory='/images' hide_default="1" filter=""/> //文件夾列表
<param name='m1' type='Hidden'/> //隱藏域
<param name="file_name" type="imagelist" directory="/images/stories" filter="" hide_default="1" label="Menu Image" description="圖片列表列表" />
<param name="list" type="list" label="select列表" description="select 列表">
<option value="">未分類</option>
<option value="0">中國</option>
<option value="1">美國</option>
</param>
<param name='m1' type='password' label='測試' size='20'/> //密碼
<param name="cache" type="radio" default="0" label="單選" description="單選按鈕"> //單選
<option value="0">No</option>
<option value="1">Yes</option>
</param>
<param name="sectionid" type="section" default="0" label="選擇單元" description="單元" /> //單元選擇
<param type="spacer"/> //水平線
<param name='m1' type='sql' label='測試' query="select id,title from #__categories" key_field='id' value_field='title' /> //SQL生成列表
<param name="robots" type="text" size="20" default="10" label="文本框" description="文本框text" /> //文本框
<param name="keywords" type="textarea" rows="5" cols="90" label="文本域" description="文本域 textarea" /> //文本域無樣式
<param name="keywords" type="editor" rows="5" cols="90" label="文本域" description="文本域 textarea" /> //文本域有樣式
<param name='m1' type='Timezones' label='測試' default='8' /> //生成時區列表

上邊就是提供的一些生成元素,但是如何使用呢,我們首先建立一個form.xml,在組件的models文件夾內
復制代碼 代碼如下:
<?xml version="1.0" encoding="utf-8"?>
<form>
<name>表單測試 </name>
<fieldset name='details'/>
<params group="html" addpath="/administrator/components/com_category/elements">
<param name='m1' type='Hidden'/>
</params>
</form>

這裡只有一個隱藏元素其實我們可以建立更多的元素,就是上邊的那些生成元素類型,當然還可以自定義,這裡的addpath就是自定義元素類型,位置就是在組建的elements文件夾內,上邊的是內置的,筆者在這裡定義了如下類型
復制代碼 代碼如下:
<param name='custom' type='custom' label='自定義'> //自定義控件
<param name='arr' type='arr' label='數組' arr="array(1=>'中國',2=>'美國')"/>//數組轉換成列表 不寫下標從0開始
<param name='radios' type='radios' label='是否單選'> //生成是否單選
<param name='arr' type='upload' label='數組' size='20'/>//上傳控件
<param name='arr' type='checkbox' label='數組' arr="array('1'=>'中國','2'=>'美國')"/>//數組復選
<param name='type' type='type' label='無線分類' />//無限分類 注意添加section父類為0

使用方法如上,元素的自定義文件在下載裡面提供.接著我們在views文件夾下面你的視圖文件夾內的view.html.php增加如下語句
復制代碼 代碼如下:
$form = new JParameter('',JPATH_COMPONENT.DS.'models'.DS.'form.xml');
$form->set('m1','默認值');
$html=$form->render('details', 'html'); //details是元素名數組
$this->assignRef('html',$html);

上邊第二句就是賦值,把隱藏域賦值,相當於編輯裡面取值,第三四句是把表單html輸出到模版,details是元素名稱數組名,生成的m1的name就是details[m1],接著就是form.php調用如下
復制代碼 代碼如下:
<form action="index.php" method="post" name="adminForm">
<fieldset class="adminform"><legend>詳情</legend>
<?php
echo $this->html;
?>
<?php echo JHTML::_( 'form.token' ); ?>
</fieldset>
</form>

這樣一個表單就生成了,相對於直接寫表單元素,這種方法更容易修改風格或者內容,修改只需要改xml文件即可,在joomla2.5版本中,基本上都是通過這種方式實現的,不過變化比較大,xml文件寫法大不相同,通過xml是可以調用其他組件裡面表單元素的.

表單元素的這些類型在模版配置參數,模塊參數都是可以使用的,特別是可以自己擴展表單元素的樣式,你完全可以定義出其他樣式類型,筆者定義了比較常用的幾種但是內置沒有提供的,比如數組轉換列表,數組轉換復選,無限分類等樣式.這裡的類型其實就是api的JElement類,裡面的源文件可以參考libraries\joomla\html\parameter\element,這裡自定義表單元素怎麼寫呢這裡給個例子或者參考源文件就明白了,文件名custom.php,類型也就是custom了,調用方法<param name='custom' type='custom' label='自定義' />
復制代碼 代碼如下:
<?php
// 自定義顯示
//
defined('_JEXEC') or die('Restricted access');

class JElementCustom extends JElement{
var $_name = 'Custom';
function fetchElement($name, $value, &$node, $control_name) {
$html=<<<EOF
自定義
EOF;
return $html;
}
}

好了,就不多講了,其實這只是一種建立表單的方法,如果你不喜歡,完全可以使用寫表單元素,不過既然joomla提供了這些我們為什麼不用呢?
下載自定義元素: elements_jb51.rar

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved