国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

定制xDoclet標簽自動生成框架配置

2019-11-18 11:47:23
字體:
來源:轉載
供稿:網友

  xDoclet是一種通過讀取java源文件中的特定標簽,然后生成指定文件的工具。xDoclet標簽本身已經提供了一些常用的標簽,例如@ejb,@hibernate,@web等等,但是仍然不能滿足我們的需求。
  
  例如我們最新的項目中引用了一個javascript驗證框架,通過配置特定的xml配置文件,即可完成客戶端表單驗證,但是不想開發人員再去學習一套框架,于是想讓開發人員在源代碼中寫@Javascript這樣的標簽,然后生成其配置文件。
  
  Javascript客戶端驗證一直是web開發中一個比較頭疼的問題,經常是每一個頁面中充斥著許多類似甚至相同的驗證代碼,如何統一有效的治理這些代碼,以及如何做到代碼頁面的分離一直沒有太好的解決方法。
  
  運用這個驗證框架那么客戶端開發就變成了配置validation-config.xml這個文件如此輕松了,本文并不打算具體講述如何使用JSValidation框架,有愛好的朋友可以去http://www.cosoft.org.cn/PRojects/jsvalidation JSValidation的官方網站自己去學習。
  
  雖然運用這框架已經可以很好的完成客戶端驗證代碼的編寫,并且提供了dtd文件進行xml文件的,但是手動編寫xml文件還是很輕易出錯,效率比較低,而且新的開發人員還要把握一個全新的框架,不宜于開發人員入門。
  
  像Struts或JSF這樣的框架大都需要為表單寫一個類似FormBean的東西,以JSF為例,假如表單內有一文本框<input type=”text” name=”txtUsername” />,那么對應的Page類或叫FormBean類就應有如下代碼:
  private HtmlInputText txtUsername = new HtmlInputText();
  /**
  * @return 用戶名
  */
  public HtmlInputText getTxtUsername ()
  {
    return txtUsername;
  }
  /**
   * @param text
   */
  public void setTxtTeaName(HtmlInputText text)
  {
    txtTeaName = text;
  }
  假如可以利用xDoclet,那么,就可以自動生成JSValidation的配置文件了,而且還利于培訓新的開發人員,再加入ant task還可以形成每日構建。想象的代碼應該是下面這個樣子:
  /**
   * @javascript.field
   * name="frmZBAddGlobalPage:txtTeaName"
   * display-name="用戶名"
   *
   * @javascript.depend
   * name="required"
   *
   * @return用戶名
   */
   public HtmlInputText getTxtUsername()
   {
     return txtUsername;
   }
  通過分析xDoclet自帶的一些標簽包,發現只需要提供三個文件即可實現自定義xDoclet標簽:一個繼續于XmlSuBTask的類,一個繼續于DocletTask的類(用于ant),一個xdt的模板語言文件即可。
  
  在XmlSubTask類中,首先,定義模板文件名:
  private static String DEFAULT_TEMPLATE_FILE =
      "resources/validation-config.xdt";
  定義dtd文件名:
  private final static String DTD_FILE_NAME_20 =
      "resources/validation-config.dtd";
  定義要生成的配置文件名:
  private static String GENERATED_FILE_NAME = "validation-config.xml";
  
  然后只需將三個文件組合起來既可,具體代碼如下:
  public JavascriptSubTask()
    {
      setTemplateURL(getClass().getResource(DEFAULT_TEMPLATE_FILE));
      setDestinationFile(GENERATED_FILE_NAME);
    }
  
    public void execute() throws XDocletException
    {
      setDtdURL(getClass().getResource(DTD_FILE_NAME_20));
      startProcess();
    }
  
    protected void engineStarted() throws XDocletException
    {
      System.out.println(
        Translator.getString(
          XDocletMessages.class,
          XDocletMessages.GENERATING_SOMETHING,
          new String[] { getDestinationFile()}));
    }
  要想ant可以使用,只需要以下簡單的代碼:
  /*
   * 創建日期 2004-4-26
   */
  package paradise.xdoclet.modules.javascript;
  
  import xdoclet.DocletTask;
  
  /**
   * @author 清風
   */
  public class JavascriptDocletTask extends DocletTask
  {
    public JavascriptDocletTask()
    {
      addSubTask(new JavascriptSubTask());
    }
  }
  在ant中按如下方式定義:
  <target name="javascript" depends="jxdoc_init" description="Generate javascript validation-config">
      <javascriptdoclet destdir="${jsp}/javascript">
        <fileset dir="${src}">
          <include name="**/zaibian/*.java"/>
        </fileset>
      </javascriptdoclet>
  </target>
  
  接下來,也是最核心的部分,就是有關xdt模板語言,xdt文件可以說是自定義xDoclet標簽的最重要的文件之一,以JavaScriptxDoclet為例,簡單介紹一下xdt模板語言:
  <XDtClass:forAllClasses>  遍歷所有含有標簽的類(在ant中指定)
  <XDtMethod:forAllMethods>  遍歷當前類的所有方法
  <XDtMethod:ifHasMethodTag tagName="javascript.form">  假如遍歷到的方法中含有指定的標簽
  <XDtMethod:forAllMethodTags tagName="javascript.depend">  遍歷當前方法的所有標簽
  更多的模板語言,參考xDoclet的.XDT文檔,都是很好理解的模板語言。
  
  接下來,開始自定義自己的標簽,新建一個xtags.xml文件,加上開頭
  <?xml version="1.0" encoding="UTF-8"?>
  
  <!DOCTYPE xdoclet PUBLIC "-//XDoclet Team//DTD XDoclet Tags 1.1//EN" "http://xdoclet.sourceforge.net/dtds/xtags_1_1.dtd">
  然后寫下所有自定義的標簽,例如:
  <xdoclet>
    <namespace>
      <name>javascript</name>
      <tags>
        <tag>
          <level>method</level>
          <name>javascript.form</name>
          <usage-description>Form</usage-description>
          <condition type="method"/>
          <parameter type="text">
            <name>id</name>
            <usage-description>Form id</usage-description>
            <mandatory>true</mandatory>
          </parameter>
          <parameter type="text">
            <name>show-error</name>
            <usage-description>Form Error Display</usage-description>
            <mandatory>true</mandatory>
          </parameter>
          <parameter type="text">
            <name>onfail</name>
            <usage-description>Form Error Run Custom Javascript Function</usage-description>
            <mandatory>false</mandatory>
          </parameter>
        </tag>
      </tags>
    </namespace>
  </xdoclet>
  注重幾個地方:
  “<level> method </level>”代表該標簽出現在方法上而不是類之上。例如
  /**
  *@javascript.form
  *name=”test”
  */
  public String getXXX()
  {
  }
  a
  最后就是將這些文件打成jar,其放置目錄分別是:
  根目錄
  
  --META-INF/xtags.xml
  
  --源代碼
  ----
  ------resources/*.xdt,*.dtd

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 铁岭县| 邛崃市| 吉水县| 铜陵市| 章丘市| 宝鸡市| 宜昌市| 周至县| 灌云县| 松阳县| 肥城市| 安义县| 文登市| 板桥市| 屏东县| 米林县| 息烽县| 张家界市| 高邑县| 杂多县| 仁布县| 无为县| 张家港市| 舟曲县| 石景山区| 宁陵县| 绥棱县| 高邑县| 建平县| 甘南县| 淮北市| 葵青区| 吴忠市| 罗江县| 延津县| 湟中县| 云南省| 玉树县| 剑阁县| 垫江县| 阿鲁科尔沁旗|