Рекомендуемые рамки JSF 2.0 CRUD

Может кто-нибудь рекомендовать какие-либо рамки для облегчения разработки CRUD в JSF 2.0?

Аспекты, которые я больше всего ценю:

  • Как можно более легкий; ограниченные зависимости от сторонних библиотек
  • Поддержка развивающейся модели домена
  • Ограниченная потребность в повторном кодировании; поддержка лесов и/или метанаботов

Любые подсказки высоко оценены! С уважением, J.

Ответ 1

CRUD - это кусок пирога с использованием JSF 2.0, предоставляемый стандартным средством: @ViewScoped bean в сочетании с <h:dataTable> в основном уже достаточно. Вот пример кода, который бесстыдно скопирован из в этой статье.

Bean:

package com.example;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.List;

import javax.annotation.PostConstruct;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ViewScoped;

@ManagedBean
@ViewScoped
public class Bean implements Serializable {

    private List<Item> list;
    private Item item = new Item();
    private boolean edit;

    @PostConstruct
    public void init() {
        // list = dao.list();
        // Actually, you should retrieve the list from DAO. This is just for demo.
        list = new ArrayList<Item>();
        list.add(new Item(1L, "item1"));
        list.add(new Item(2L, "item2"));
        list.add(new Item(3L, "item3"));
    }

    public void add() {
        // dao.create(item);
        // Actually, the DAO should already have set the ID from DB. This is just for demo.
        item.setId(list.isEmpty() ? 1 : list.get(list.size() - 1).getId() + 1);
        list.add(item);
        item = new Item(); // Reset placeholder.
    }

    public void edit(Item item) {
        this.item = item;
        edit = true;
    }

    public void save() {
        // dao.update(item);
        item = new Item(); // Reset placeholder.
        edit = false;
    }

    public void delete(Item item) {
        // dao.delete(item);
        list.remove(item);
    }

    public List<Item> getList() {
        return list;
    }

    public Item getItem() {
        return item;
    }

    public boolean isEdit() {
        return edit;
    }

    // Other getters/setters are actually unnecessary. Feel free to add them though.

}

Page:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:f="http://java.sun.com/jsf/core"
      xmlns:h="http://java.sun.com/jsf/html">
    <h:head>
        <title>Really simple CRUD</title>
    </h:head>
    <h:body>
        <h3>List items</h3>
        <h:form rendered="#{not empty bean.list}">
            <h:dataTable value="#{bean.list}" var="item">
                <h:column><f:facet name="header">ID</f:facet>#{item.id}</h:column>
                <h:column><f:facet name="header">Value</f:facet>#{item.value}</h:column>
                <h:column><h:commandButton value="edit" action="#{bean.edit(item)}" /></h:column>
                <h:column><h:commandButton value="delete" action="#{bean.delete(item)}" /></h:column>
            </h:dataTable>
        </h:form>
        <h:panelGroup rendered="#{empty bean.list}">
            <p>Table is empty! Please add new items.</p>
        </h:panelGroup>
        <h:panelGroup rendered="#{!bean.edit}">
            <h3>Add item</h3>
            <h:form>
                <p>Value: <h:inputText value="#{bean.item.value}" /></p>
                <p><h:commandButton value="add" action="#{bean.add}" /></p>
            </h:form>
        </h:panelGroup>
        <h:panelGroup rendered="#{bean.edit}">
            <h3>Edit item #{bean.item.id}</h3>
            <h:form>
                <p>Value: <h:inputText value="#{bean.item.value}" /></p>
                <p><h:commandButton value="save" action="#{bean.save}" /></p>
            </h:form>
        </h:panelGroup>
    </h:body>
</html>

Кроме того, Netbeans имеет несколько полезных мастеров для создания CRUD-приложения на основе данных.

Ответ 2

JSF 2.0. CRUD очень прост в использовании с JSF - нет необходимости в каких-либо других рамках. Вам нужно

  • 1 управляемый bean (аннотированный с помощью @ManagedBean)
  • 2 xhtml pages (facelets) - один для списка и один для редактирования/создания
  • A <h:dataTable> с кнопкой edit link/, с помощью которой вы устанавливаете текущий объект строки в управляемом bean (используя action="#{bean.edit(currentRowObject)}"). (В JSF 1.2 это было достигнуто <f:setPropertyActionListener>)
  • Методы действий (void без аргументов) для обработки операций
  • @PostConstruct для первоначальной загрузки данных.

Ответ 3

Я создал этот, чтобы ускорить процесс создания приложения jsf crud: https://github.com/ignl/happyfacescrud Внекованный поиск, ленивая таблица данных, просмотр/редактирование, пользовательские компоненты, которые значительно уменьшают код и, конечно, гибкие.

Ответ 5

У меня была такая же проблема, как описано: Создание как можно CRUD-App в JEE6.

Красивый генератор найден по адресу: http://sourceforge.net/projects/jbizmo/

После определения (Graph-Editor!) вашей бизнес-модели/модели домена JBizMo создает базу данных и целое CRUD-приложение из коробки.

  • i18n, JAAS, также поддерживается
  • Созданы представления и меню
  • ... набор параметров для определения...