2013-03-27 80 views
0

我有一个SpringController获取名为“开始”的搜索/休眠分页目的的RequestParameter。如果参数为null,则从零开始并使用JavaScript var'start = {start + 10}'呈现JSP,因此如果用户单击“下一个10”按钮,控制器将获得'start = 10' 。然后,控制器应该使用'start = {start + 10} = 20来呈现一个JSP,但无论我经过控制器多少次,它仍然是10。 我已经在服务器端和客户端进行了添加。同样的事情发生:没有。 这里的控制方法:春天MVC-型号属性参数不刷新上GET

@RequestMapping(value = "/customers", method = RequestMethod.GET) 
public String customersView(@RequestParam(value = "start", required = false) Integer start, ModelMap model) { 
    if (start == null || start <= 0) start = 0; 

    List<Customer> customers = customerService.findAllCustomers(start, pagesize);  
    CustomersForm customersForm = new CustomersForm(); 
    customersForm.setCustomers(customers); 
    start += 10; // I can see a "20" here, actually. 
    model.clear(); 
    model.addAttribute("customersform", customersForm); 
    model.addAttribute("start", start); //This should render a "20" on client side on the first call, but it doesn't. 
    return "customers"; 
} 

这是JSP的相关部分:

<script type="text/javascript"> 
jq(document).ready(function() { 
    jq("#next_20").click(function() { 
     var st = "${start}"; //This gets set OK only first time, i.e., a "10" is rendered. 
     jq.get("customers", 
     { 
      start: st 
     }); 
    }); 
}); 

现在好了,我还添加了这些行到我的servlet上下文,因为我怀疑它与一些缓存有关(浏览器,Tomcat)正在做...

<!-- Disable web cache for GET requests --> 
<mvc:interceptors> 
    <bean id="webContentInterceptor" 
     class="org.springframework.web.servlet.mvc.WebContentInterceptor"> 
     <property name="cacheSeconds" value="0" /> 
     <property name="useExpiresHeader" value="true" /> 
     <property name="useCacheControlHeader" value="true" /> 
     <property name="useCacheControlNoStore" value="true" /> 
    </bean> 
</mvc:interceptors> 

就是这样。当我点击“next_20”按钮时,我的控制器被调用,一个“开始”参数被传递(10),应该在模型中用“20”代替,但渲染后的页面仍然有一个“10”。

我在做什么错?

干杯

回答

1

您的来电jq.get是一个Ajax调用不刷新页面,所以${start} JSTL表达式将不会再次评估。您可以存储st Ajax调用之外,从Ajax调用,而不是“客户”回归start,并更新st当调用返回:

var st = "${start}"; //This gets set OK only first time, i.e., a "10" is rendered. 

jq("#next_20").click(function() { 

    jq.get("customers", 
     { 
      start: st 
     }, 
     function(newStartValue) { 
      st = newStartValue; 
     } 
    ); 
}); 
+0

谢谢,伙计。我是新来的jQuery和AJAX,我没有注意到,即使方法请求不刷新页面...所以这根本不符合我的要求,因为我需要刷新'客户'对象列表。我使用PO JavaScript函数调用完成了像onlick =“location.href ='customers?start = ...”'这样的操作。谢谢。 – Azurlake 2013-03-28 01:14:32