DWR学习及应用(二,forward)

使用dwr我们可以动态请求一个页面内容到当前页:一下是代码:

1,后台方法:

public String getInclude() throws ServletException, IOException {

		WebContext ctx = WebContextFactory.get();
		System.out.println(ctx.getCurrentPage());
		ctx.getHttpServletRequest().setAttribute("test", "hello ,test forward");
		return ctx.forwardToString("/iclude.jsp");
	}

 

2,dwr配置:

 <create javascript="testinclude" creator="new">
        <param name="class" value="com.dwr.TestInclude"/>
    </create>

 3,页面:

<html>
	<head>
		<base href="<%=basePath%>">
		<script type="text/javascript" src="dwr/engine.js"></script>
		<script type="text/javascript" src="dwr/util.js"></script>
		<script type="text/javascript" src="dwr/interface/testinclude.js"></script>
<script type="text/javascript">

   function getInClude(){
    testinclude.getInclude(
       function(data){
           dwr.util.setValue("fq",data,{ escapeHtml:false });
       } 
    );
   }
</script>
	</head>
<body>
		<input type="button" value="include page"
			οnclick="javascript:getInClude()" />
		<div id="fq">
		</div>
</body>

</html>

 2,其中使用了

WebContext ctx = WebContextFactory.get();

ctx.forwardToString("/iclude.jsp");

查看dwr源代码:

 getServletContext().getRequestDispatcher(url).forward(realRequest, fakeResponse);

 其中:fakeResponse

HttpServletResponse fakeResponse = new SwallowingHttpServletResponse(realResponse, sout, realResponse.getCharacterEncoding());

  而SwallowingHttpServletResponse使用了WriterOutputStream

 public SwallowingHttpServletResponse(HttpServletResponse response, Writer sout, String characterEncoding)
    {
        super(response);

        pout = new PrintWriter(sout);
        outputStream = new WriterOutputStream(sout, characterEncoding);

        this.characterEncoding = characterEncoding;
    }

 WriterOutputStream:也就是对 ServletOutputStream的封装。

public final class WriterOutputStream extends ServletOutputStream

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值