在velocity template中调用javascript但页面不自动刷新问题的解决

最近在做ali-dubbo-admin的二次开发,其页面使用的是velocity template,遇到了两个坑,记录一下

坑1:在ajax中取到vm中变量的值

两种思路:

1. 直接使用'$变量名'  vm中的语法 来做 

2. 先在vm中渲染出值来,然后hidden掉,在js中使用document.getElement来获取

最后采用的是第一种方式

坑2:节点下线后,前端VM页面无法直接感知下线状态

想了半天。终于弄明白了是怎么回事。

问题的原因在于vm是一个模板,当我们使用ajax更新的时候,只有在模板更新的情况下,其ajax更新才有效果,否则一直都是相同的模板的值。

这也就解释了为啥前端页面无法感知下线状态,因为即便ajax去访问了,但是值是不会渲染到vm模板上的。

只有一种情况,可以是前端页面渲染到vm上,那就是重新访问整个页面,即window.location.reload能够实现重新生成vm页面,于是ajax在window.location.reload之后就能取到最新的值,于是就能渲染出页面了

 

其实与jsp一样。比如我们在jsp中使用ajax来获取后端的值,其实你每一次js都能在后端获取到新值,但是却无法回调放到jsp中。只有重新生成jsp才能在回调中获取到

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值