:::

10. XOOPS的表單物件(40分鐘)

一、 新增與修改

  1. 新增和修改都需要一個編輯用的表單界面
  2. 我們可以在樣板多個新增的按鈕:
    <a href="main.php?op=add_form" class="btn btn-primary">新增詞彙</a>
  3. 在流程多一組對應:
      case "add_form":
      add_form();
      break;
  4. 然後多一個add_form()函數:
    //編輯詞彙表單
    function add_form(){
      global $xoopsTpl;
    
    }
  5. 接著,我們要在這個函數中,利用XOOPS的表單物件來建立一個編輯表單。

二、 物件的基本動作及概念

  1. PHP 的 Class(類)是一個物件藍圖
  2. 要讓 Class 有作用需要經過實體化(new)的動作:
    $物件 = new 某物件Class();
  3. 物件會有所謂的方法(method)其實就是函數,讓您對此物件進行設、取值或執行特定物件功能:
    $物件->方法();
  4. XOOPS的表單物件設定完,最後都需要進行$物件->render();以產生程式碼。
  5. 詳細的XOOPS Class請參考:http://dev.xoofoo.org/dev_xoops_255/inherits.html

三、 XOOPS內建表單Class

  1. 要使用內建表單需先引入此行:
    include_once(XOOPS_ROOT_PATH."/class/xoopsformloader.php");
  2. 建立一個表單:
    $form = new XoopsThemeForm('表單標題', 'name', 'action.php', 'post', '使用token' , '摘要');
    //例如:
    $form = new XoopsThemeForm('編輯詞彙', '', 'main.php', 'post', true);
  3. 標籤元件:
    $元件變數 =new XoopsFormLabel('標題', '內容');
  4. 文字輸入:
    $元件變數 =new XoopsFormText('標題', 'name', 大小 , 最大長度 , '值');
    //例如:
    $input_eng =new XoopsFormText('英文', 'eng', 20 , 255 , $eng);
  5. 隱藏欄位:
    $元件變數 =new XoopsFormHidden('name', '值');
    //例如:
    $hidden_op =new XoopsFormHidden('op', 'insert');
  6. 安全檢查:
    $元件變數=new XoopsFormHiddenToken('XOOPS_TOKEN_REQUEST',360);
  7. 上傳欄位:
    $form->setExtra("enctype='multipart/form-data'");
    $元件變數 =new XoopsFormFile('標題', 'name', '2048');
  8. 密碼欄位:
    $元件變數=new XoopsFormPassword('標題', 'name', 大小, 最大長度, '值');
  9. 大量文字:
    $元件變數=new XoopsFormTextArea('標題', 'name', '值' , 欄寬 , 列高 , 'id');
  10. XOOPS編輯器:
    $元件變數=new XoopsFormDhtmlTextArea('標題' , 'name',  '值' , 欄寬 , 列高);
  11. 複選方塊:
    $元件變數 = new XoopsFormCheckBox('標題', 'name', '值','id');
    
    //加入選項方法一:
    $元件變數->setValue($多重預設值陣列);
    
    //加入選項方法二:
    $元件變數->addOption('選單值1', '顯示值1', false);
    
    //加入選項方法三:
    $options['選單值2']='顯示值2';
    $options['選單值3']='顯示值3';
    $元件變數->addOptionArray($options);
  12. 單選鈕:(選項及預設值設法同複選)
    $元件變數 = new XoopsFormRadio('標題', 'name', '值');
  13. 是否單選:
    $元件變數=new XoopsFormRadioYN('標題', 'name', '值');
  14. 下拉選單:(選項及預設值設法同複選,多選預設false)
    $元件變數=new XoopsFormSelect('標題', 'name', '預設值', 大小, 多選);
  15. 群組核選:(多選預設false)
    $元件變數=new XoopsFormSelectCheckGroup('標題', 'name', '值', 大小 ,多選);
  16. 國家選單:(值:TW)
    $元件變數=new XoopsFormSelectCountry('標題', 'name', '值', 大小);
  17. 編輯器選單:(使用HTML預設false )
    $元件變數=new XoopsFormSelectEditor(&$form, 'name', '值', 使用HTML , 可選編輯器陣列);
  18. 群組選單:(含訪客預設false,多選預設false)
    $元件變數=new XoopsFormSelectGroup('標題', 'name', 含訪客, '值', 大小 ,多選);
  19. 語系選單:(值tchinese_utf8,多選預設false)
    $元件變數=new XoopsFormSelectLang('標題', 'name', '值', 大小);
  20. 比對選單:
    $元件變數=new XoopsFormSelectMatchOption('標題', 'name', '值', 大小);
  21. 佈景選單:
    $元件變數=new XoopsFormSelectTheme('標題', 'name', '值', 大小);
  22. 時區選單:
    $元件變數=new XoopsFormSelectTimezone('標題', 'name', '值', 大小);
  23. 使用者選單:(含訪客預設false,多選預設false)
    $元件變數=new XoopsFormSelectUser('標題', 'name', 含訪客, '值', 大小 ,多選);
  24. 按鈕:(類型:submit或reset)
    $元件變數 =new XoopsFormButton('標題', 'name', '值', '類型');
    //例如:
    $submit_btn =new XoopsFormButton('', '', '儲存', 'submit');
  25. 把元件加入表單中:
    $form->addElement($元件變數);
    //例如:
    $form->addElement($input_eng);
    $form->addElement($input_cht);
    $form->addElement($hidden_op);
    $form->addElement($submit_btn);
  26. 把幾個元件組合在一起,並放到表單中:
    $Tray1=new XoopsFormElementTray('標題', '&nbsp;', 'name');
    $Tray1->addElement(new XoopsFormButton('', 'name', '送出', 'submit'));
    $Tray1->addElement(new XoopsFormButton('', 'name', '清除', 'reset'));
    $form->addElement($Tray1);
  27. 產生表單程式碼:
    $f=$form->render();

三、 完整範例

  1. 寫成函數看起來如下:
    //編輯詞彙表單
    function add_form(){
      global $xoopsTpl;
      include_once(XOOPS_ROOT_PATH."/class/xoopsformloader.php");
      $form = new XoopsThemeForm('編輯詞彙', '', 'main.php', 'post', true);
      $input_eng =new XoopsFormText('英文', 'eng', 20 , 255 , $eng);
      $input_cht =new XoopsFormText('中文解釋', 'cht', 20 , 255 , $cht);
      $hidden_op =new XoopsFormHidden('op', 'insert');
      $submit_btn =new XoopsFormButton('', '', '儲存', 'submit');
      $form->addElement($input_eng);
      $form->addElement($input_cht);
      $form->addElement($hidden_op);
      $form->addElement($submit_btn);
      $f=$form->render();
      $xoopsTpl->assign("form" ,$f);
    }
  2. 利用 $xoopsTpl->assign('form',$f) 將產生的表單語法,套用到樣板中的<{$form}>標籤裡。
  3. 請在樣板中加入 <{$form}> 標籤,如:
    <{if $form}>
      <{$form}>
    <{else}>
      <h1>字典管理</h1>
      ....略....
      <{$bar}>
    <{/if}>

 


:::

搜尋

QR Code 區塊

https%3A%2F%2Ftad0616.net%2Fmodules%2Ftad_book3%2Fpage.php%3Ftbsn%3D35%26tbdsn%3D1031

書籍目錄

展開 | 闔起

線上使用者

169人線上 (36人在瀏覽線上書籍)

會員: 0

訪客: 169

更多…