林集成jQuery的阿賈克斯試圖與檢票jQuery的Ajax請求相結合,但我面臨的一個小問題...當檢票
的請求工作第一次,但失敗了,第二次奇怪的行爲。 js控制檯說它是由於語法錯誤「意外標記」而發生的。用firedebug查看請求時,第一次看起來正確,但第二次看不到響應。
第一次按下按鈕同時調用「onRequest」和「neforeRender」,第二次調用只有「beforeRender」。
我不確定它的jQuery或Wicket是否認爲這裏的惡棍......「onBeforeRender」被稱爲兩個tiems的事實似乎表明請求正在通過,同時bvut「onRequest」不被稱爲第二即使firedebug確認數據發送...
任何人在這裏得到了什麼問題的線索或理論?
以下是在提交按鈕上的「onClick」事件上調用的jQuery代碼。
function getTestValue()
{
var testArray = [ 1, 2, 3, 4, 5 ];
$.ajax({
url : $('#mark').attr('json:callback.url'),
type : 'post',
cache : false,
data : JSON.stringify(testArray),
contentType : 'application/json',
dataType : 'json',
success: function(responseData)
{
var values = responseData.sumPerTimeUnit;
var labels = responseData.labels;
},
error: function(XMLHttpRequest, textStatus, errorThrown)
{
alert($('#mark').attr('json:callback.url'));
console.log(XMLHttpRequest);
console.log(textStatus);
console.log(errorThrown);
},
});
}
即使請求失敗,按鈕被按下時調用面板「onBeforeRender」。
public class AbstractJSONHandlerPanel extends Panel
{
private static final long serialVersionUID = 1L;
private AbstractJSONBehavior JSONBehavior;
private Form mMarkUp;
public AbstractJSONHandlerPanel(String id)
{
super(id);
JSONBehavior = new AbstractJSONBehavior();
mMarkUp = new Form("markupid")
{
@Override
protected void onComponentTag(ComponentTag tag) {
super.onComponentTag(tag);
tag.put("json:callback.url", JSONBehavior.getCallbackUrl());
}
};
mMarkUp.setMarkupId("mark");
add(JSONBehavior);
Button n = new Button("dummyButton");
n.add(AttributeModifier.replace("onclick", "getTestValue();"));
mMarkUp.add(n);
add(mMarkUp);
}
@Override
protected void onBeforeRender()
{
System.out.println("BEFORE RENDER");
String callbackUrl = JSONBehavior.getCallbackUrl().toString();
mMarkUp.add(AttributeModifier.replace("json:callback.url", callbackUrl));
super.onBeforeRender();
}
}
的「onRequest」僅稱爲第一次按下該按鈕。
public class AbstractJSONBehavior extends AbstractAjaxBehavior
{
private static final long serialVersionUID = 1L;
public void onRequest()
{
System.out.println("REQUEST");
RequestCycle requestCycle = RequestCycle.get();
readRequestData(requestCycle);
writeResponseData(requestCycle);
}
private void readRequestData(final RequestCycle requestCycle)
{
WebRequest wr = (WebRequest) requestCycle.getRequest();
HttpServletRequest hsr = (HttpServletRequest) wr.getContainerRequest();
try
{
BufferedReader br = hsr.getReader();
String jsonString = br.readLine();
if((jsonString == null) || jsonString.isEmpty())
{
System.out.println(" no json found");
}
else
{
System.out.println(" json is :" + jsonString);
}
br.close();
}
catch(IOException ex)
{
throw new RuntimeException(ex);
}
}
private void writeResponseData(RequestCycle requestCycle)
{
WebResponse wr = (WebResponse) requestCycle.getResponse();
HttpServletResponse hsr = (HttpServletResponse) wr
.getContainerResponse();
try
{
PrintWriter br = hsr.getWriter();
List<Integer> data = new ArrayList<Integer>(6);
data.add(350);
data.add(421);
data.add(976);
data.add(1521);
data.add(432);
data.add(121);
List<String> labels = new ArrayList<String>(6);
labels.add("Jan");
labels.add("Feb");
labels.add("Mar");
labels.add("Apr");
labels.add("Maj");
labels.add("Jun");
StatisticsResponse resp = new StatisticsResponse(data, labels);
Gson mGsonParser = new Gson();
String json = mGsonParser.toJson(resp);
System.out.println("RESPONSE: " + json);
br.write(json);
br.flush();
br.close();
}
catch(IOException ex)
{
throw new RuntimeException(ex);
}
}
}
如何使用jquery而不是內置的檢票器,例如從javascript調用ajax?此外,如果你升級到wicket 1.6,它將使用jquery來處理所有的ajax內容。 – drobson
我是jsute,將javascript庫與wicket結合在一起進行實驗,想要測試它是否有可能通過使用jquery的manuella來完成。 – David
也即時使用1.5 ...雖然形成它的外觀,我可能只是省去了一些麻煩和使用1.6,似乎它會導致更清潔的代碼。 – David