InfoCity
InfoCity - виртуальный город компьютерной документации
Реклама на сайте







Размещение сквозной ссылки

 

Введение в технологию шаблонов


Developers.com.ua


Проблема - хранение html-кода в теле скрипта. - Нам необходимо отделить код скрипта (java-сервлет, perl, php) от html кода - чтобы дизайнеры могли вносить изменения. При этом нам надо (например) вставлять в страничку результаты выполнения запросов к sql базе. Или например нам нужно разослать пользователся сайта письмо вида: "Уважаемы Иван Иванович...". Для этого нам надо чтобы документ (html страничка) хранился на диске, а мы при необходимости загружали ее в память каким-то образом заполняли.

То есть мы подчитываем файл-шаблон, подставляем в него вычисленные значения переменных и выдаем его как результат работы скрипта. Как куда и с каком виде подставляются наши данные? - Очень просто - мы считали в String весь html код и, например, делем обыкновенную текстовую замену - $AGE$ заменяем на вычесленное значение 25. AGE выделенно значками $ чтобы случайно не заменить что-то лишнее :).

Такую работу по замене как раз и выполняют Template библиотеки классов. Существует множество библиотек классов реализующих шаблонные технологии, например webmacro.

Способ выделения переменной шаблона везде разный - в webmacro, например, переменная AGE в тексте html-кода выглядела бы как $AGE, в случае моего класса - $AGE$.

Рассмотрим подробнее как это работает. Например так мы можем сделать форму редактирования с default-значениями в полях ввода:

Создадим шаблон (файл myform.tmpl) :

<HTML>
<BODY>
 <FORM>
  <INPUT TYPE=TEXT NAME="FIO" VALUE="$FIO$">
  <INPUT TYPE=TEXT NAME="AGE" VALUE="$AGE$">
  <INPUT TYPE=SUBMIT>
 </FORM>
</BODY>
</HTML>

а в исходном коде напишем:

public final void doGet(HttpServletRequest req
                       ,HttpServletResponse res)
 throws ServletException,IOException

{ Template t=new Template(new File("myform.tmpl"));
  t.addVar("FIO","Иванов");
  t.addVar("AGE","25");

  try { res.setContentType("text/html");
        PrintWriter out = res.getWriter();
        out.println(t.getPage());
      } catch(Exception e)
        { System.out.println("Exception: "+e);}
}

и в результате сервлет выдаст html-код:

<HTML>
<BODY>
 <FORM>
  <INPUT TYPE=TEXT NAME="FIO" VALUE="Иванов">
  <INPUT TYPE=TEXT NAME="AGE" VALUE="25">
  <INPUT TYPE=SUBMIT>
 </FORM>
</BODY>
</HTML>

А как работать с таблицами? - Просто! - Для них надо уже два шаблона. Первый - шапка таблицы, второй - описывает одну строку. В StringBuffer мы накапливаем строки, после этого вставляем их в шапку (как значение одной переменной). Пример:

table.tmpl:

<HTML>
<BODY>
 Справочник товаров
<TABLE width="100%" cellspacing=0 border=0> <TR> <TD>Номенклатурный номер</TD> <TD>Наименование</TD> </TR> $rows$ </TABLE> </BODY> </HTML>

row.tmpl:

<TR>
<TD>$ITOVAR$</TD>
<TD>$HTOVAR$</TD>
</TR>

select.java:

public void doGet(HttpServletRequest req, HttpServletResponse res)
 throws ServletException,IOException

{ Template tbl=new Template(new File("table.tmpl"));
  Template row=new Template(new File("row.tmpl"));
  StringBuffer rows=new StringBuffer();

  try { Statement statement =
         (someconnection.getConnection()).createStatement();

        String str="SELECT * FROM TOVAR";
        ResultSet rs = statement.executeQuery(str);
        ResultSetMetaData md = rs.getMetaData();

        int cnt= md.getColumnCount();
        while(rs.next())
        { for(int i = 1; i <= cnt; i++)
          { String name=md.getColumnName(i);

            String s=rs.getString(i);

            if(s==null) s="";
            if(s.trim().length()==0) s=" ";
            row.addVar(name,s);
          }
          rows.append(row.getPage());
        }
        rs.close();
        statement.close();

      } catch(SQLException _ex) { System.out.println(""+_ex);}
        catch(Exception _ex) { System.out.println(""+_ex);}

      tbl.addVar("rows",rows.toString());

      res.setContentType("text/html");
      try{ res.getWriter().println(tbl.getPage());
         } catch(Exception e) {System.out.println(""+e);}
}

Достонство данной технологии - такми образом мы можем генерировать не только html текст но и данные в формате PDF (не сжатом!) или любом другом.


Реклама на InfoCity

Яндекс цитирования



Финансы: форекс для тебя








1999-2009 © InfoCity.kiev.ua