admin管理员组

文章数量:1344194

Right now I have a JSP page that allows to sort some items, when is ready and a link is clicked a JavaScript function converts all the info into XML (text in a variable), after this i need to send this XML to the JSP page again, i tried putting the info in a hidden input and submitting the form, sending with $.post and a few more jQuery functions but nothing worked. Any ideas?

In my JSP I'm reading the post like this:

<% out.println(request.getParameter("data")); %>

This doesn't work:

xml = "<xml></xml>";
$("#form").submit(function(){
   alert("JS: " + $("#data").text());
   $("#data").text(xml);
});

This either:

xml = "<xml></xml>";
$("#data").text(xml);
$("#form").submit();

And replacing .text with .html doesn't work too. Any ideas are wele, thx

Right now I have a JSP page that allows to sort some items, when is ready and a link is clicked a JavaScript function converts all the info into XML (text in a variable), after this i need to send this XML to the JSP page again, i tried putting the info in a hidden input and submitting the form, sending with $.post and a few more jQuery functions but nothing worked. Any ideas?

In my JSP I'm reading the post like this:

<% out.println(request.getParameter("data")); %>

This doesn't work:

xml = "<xml></xml>";
$("#form").submit(function(){
   alert("JS: " + $("#data").text());
   $("#data").text(xml);
});

This either:

xml = "<xml></xml>";
$("#data").text(xml);
$("#form").submit();

And replacing .text with .html doesn't work too. Any ideas are wele, thx

Share edited Jun 15, 2020 at 7:58 Alyona Yavorska 5792 gold badges14 silver badges20 bronze badges asked Dec 30, 2008 at 19:02 Juan TecheraJuan Techera 1,2022 gold badges15 silver badges25 bronze badges
Add a ment  | 

3 Answers 3

Reset to default 4

You're probably going the wrong way here. You didn't provide the html code, but I assume it is something like this:

<form method="POST" id="form">
    <input type="hidden" id="data" />
</form>

If that is correct, then you should say $("#data").val(xml); instead of text() or html() as those change the matched thing with text or html you provide. This should work for your current solution.

Also I'd propose to look at jQuery's $.post() and others as an alternative to packing everything as xml unless this is really what you want on the backend. It could be easier to just make up a javascript object with all the values keyed by some names and pass it on to one of jQuery's $.post(), $.get(), etc. like this:

var values = {name: "John", surname: "Doe"};
values.age = 25;
$.post("index.jsp", values); // this will result in a post with 3 variables: name, surname, age

Actually it only occured to me now that you can also send your xml this way (unless you prefer your way of doing things):

$.post("index.jsp", {data: "<xml><whatever-else-needs-to-be-in-here/></xml>"});

You might want to enlighten yourself more here: Ajax @ jQuery docs

Trying using the jQuery Ajax API - you can use it to send arbitrary data via GET or POST and you don't need to set up a hidden form or anything.

You could always use an XMLHttpRequest to send the data. This can be done with our without user interaction on an element such as a form submit button. jQuery has functionality built in for assisting with such requests.

http://docs.jquery./Ajax

本文标签: javaSending a value from JavaScript to JSP (with jQuery)Stack Overflow