Как получить значение JS Grid по java - PullRequest
0 голосов
/ 04 июля 2018

Я использую сетку js (http://js -grid.com / docs / ), я хочу получить все содержимое js-grid, когда пользователь нажимает кнопку отправки в виде следующего кода:

<link type="text/css" rel="stylesheet" href="jsgrid.min.css" />
<link type="text/css" rel="stylesheet" href="jsgrid-theme.min.css" />

<script type="text/javascript" src="jquery-3.3.1.min.js"></script>    
<script type="text/javascript" src="jsgrid.min.js"></script>

<form name="form1"  method="post" action="MyJavaBackend">
<div id="jsGrid"></div>
<Input type="submit">
</form>
<script>
    var clients = [
        { "Name": "Otto Clay", "Age": 25, "Country": 1, "Address": "Ap #897-1459 Quam Avenue", "Married": false },

    ];

    var countries = [
        { Name: "", Id: 0 },
        { Name: "United States", Id: 1 },
        { Name: "Canada", Id: 2 },
        { Name: "United Kingdom", Id: 3 }
    ];

    $("#jsGrid").jsGrid({
        width: "100%",
        height: "400px",

        inserting: true,
        editing: true,
        sorting: true,
        paging: true,

        data: clients,

        fields: [
            { name: "Name", type: "text", width: 150, validate: "required" },
            { name: "Age", type: "number", width: 50 },
            { name: "Address", type: "text", width: 200 },
            { name: "Country", type: "select", items: countries, valueField: "Id", textField: "Name" },
            { name: "Married", type: "checkbox", title: "Is Married", sorting: false },
            { type: "control" }
        ]
    });
</script>

Но мой бэкэнд-файл:

public ActionForward create(ActionMapping mapping, ActionForm form,
            HttpServletRequest request,
            HttpServletResponse response)
    throws Exception {

        String[] datas = request.getParameterValues("data");// **get null**
        return mapping.findForward("create");
    }

Я проверил следующую статью: http://zetcode.com/articles/jsgridservlet/

Но он получает только одну строку отредактированных записей. (Я хочу получить все данные таблицы)

Как я могу получить все данные (все пользовательские данные) из jsgrid после того, как пользователь нажмет кнопку отправки через request.getParameterValues ​​или request.getParameter или ..... ???

1 Ответ

0 голосов
/ 10 июля 2018

В конце шрифта JavaScript:

function onSubmit(){    

    var items = $("#jsGrid").jsGrid("option", "data");//$("#jsGrid") must match <div id="jsGrid"></div>
    var json = JSON.stringify(items);
    document.form1.json.value=json;
}

<form name="form1"  method="post" action="MyJavaBackend">
<div id="jsGrid"></div>
<input type="hidden" name="json"  >
<Input type="button" onClick="onSubmit();">
</form>


В бэкэнд Java:

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

.....
String json_data = request.getParameter("json");
JSONArray jsonArray = new JSONArray(json_data);
for(int i=0;i<jsonArray.length();i++) {
                    JSONObject jsonObject=jsonArray.getJSONObject(i);

                    String name=jsonObject.getString("Name");
                    String age=jsonObject.getString("Age");
                }
....
...