Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/316.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/376.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 自动刷新Portlet Liferay 6.0(定期刷新)_Java_Javascript_Liferay_Portlet_Liferay 6 - Fatal编程技术网

Java 自动刷新Portlet Liferay 6.0(定期刷新)

Java 自动刷新Portlet Liferay 6.0(定期刷新),java,javascript,liferay,portlet,liferay-6,Java,Javascript,Liferay,Portlet,Liferay 6,我想创建用于监视某些内容的Portlet,所以它需要每隔一段时间自动刷新Portlet页面,我如何实现这一点?我一直在尝试使用普通的方法,比如使用Javascript,但它不起作用。。。谢谢,请给我举个例子:( 任何帮助都将不胜感激 我正在尝试使用jsp的普通代码,但它无法运行 <%@ page import="java.io.*,java.util.*" %> <html> <head> <title>Auto Refresh Header Ex

我想创建用于监视某些内容的Portlet,所以它需要每隔一段时间自动刷新Portlet页面,我如何实现这一点?我一直在尝试使用普通的方法,比如使用Javascript,但它不起作用。。。谢谢,请给我举个例子:(

任何帮助都将不胜感激 我正在尝试使用jsp的普通代码,但它无法运行

<%@ page import="java.io.*,java.util.*" %>
<html>
<head>
<title>Auto Refresh Header Example</title>
</head>
<body>
<center>
<h2>Auto Refresh Header Example</h2>
<%
   // Set refresh, autoload time as 5 seconds
   response.setIntHeader("Refresh", 5);
   // Get current time
   Calendar calendar = new GregorianCalendar();
   String am_pm;
   int hour = calendar.get(Calendar.HOUR);
   int minute = calendar.get(Calendar.MINUTE);
   int second = calendar.get(Calendar.SECOND);
   if(calendar.get(Calendar.AM_PM) == 0)
      am_pm = "AM";
   else
      am_pm = "PM";
   String CT = hour+":"+ minute +":"+ second +" "+ am_pm;
   out.println("Crrent Time: " + CT + "\n");
%>
</center>
</body>
</html>

自动刷新标题示例
自动刷新标题示例
问候


Danial

如果您想定期更新portlet,可以使用ServerSource方法

对ServerSource方法进行ajax调用,您可以在此ajax调用上设置setTimeout-

function <portlet:namespace />get_updated_data() {
        var f = jQuery.ajax({
        type: "POST",
        url: '<<resourceUrl>>',
        data:  {"name" : "val"},
        dataType: 'json',
        async: false,
     }).success(function(data){
        // success code here             
    }).complete(function(){
        setTimeout(function(){<portlet:namespace />get_updated_data();}, 5000);
    });
函数获取更新的数据(){
var f=jQuery.ajax({
类型:“POST”,
url:“”,
数据:{“名称”:“val”},
数据类型:“json”,
async:false,
}).成功(功能(数据){
//这里是成功代码
}).complete(函数(){
setTimeout(函数(){get_updated_data();},5000);
});

}

如果希望定期更新portlet,可以使用serversource方法

对ServerSource方法进行ajax调用,您可以在此ajax调用上设置setTimeout-

function <portlet:namespace />get_updated_data() {
        var f = jQuery.ajax({
        type: "POST",
        url: '<<resourceUrl>>',
        data:  {"name" : "val"},
        dataType: 'json',
        async: false,
     }).success(function(data){
        // success code here             
    }).complete(function(){
        setTimeout(function(){<portlet:namespace />get_updated_data();}, 5000);
    });
函数获取更新的数据(){
var f=jQuery.ajax({
类型:“POST”,
url:“”,
数据:{“名称”:“val”},
数据类型:“json”,
async:false,
}).成功(功能(数据){
//这里是成功代码
}).complete(函数(){
setTimeout(函数(){get_updated_data();},5000);
});

}

设置
刷新
标题将在最佳情况下刷新整个页面(这就是它要做的),而不仅仅是您的portlet

如何设置此刷新取决于编写portlet的底层技术。基本上,您希望对页面执行AJAX请求,以获取新数据并重新显示,正如@harishkrsingla所建议的那样

如果您的代码是纯JSP,您将设置两个页面: -一个用于显示portlet -另一个正在呈现内容

然后,您的portlet页面将看起来像这样(实际上,在我的脑海中写下这一点,在线查看文档):


//假设jquery
无功负荷;
加载=函数(){
$('#portlet').load('/data.jsp',function(){
设置超时(加载,1000);
});
}
加载();
还可以查看JSFIDLE上的工作演示:


当然,这只是一个基本的想法。您应该真正包括一些错误处理等。

设置
刷新
标题将在最佳情况下刷新整个页面(这就是它要做的),而不仅仅是您的portlet

如何设置此刷新取决于编写portlet的底层技术。基本上,您希望对页面执行AJAX请求,以获取新数据并重新显示,正如@harishkrsingla所建议的那样

如果您的代码是纯JSP,您将设置两个页面: -一个用于显示portlet -另一个正在呈现内容

然后,您的portlet页面将看起来像这样(实际上,在我的脑海中写下这一点,在线查看文档):


//假设jquery
无功负荷;
加载=函数(){
$('#portlet').load('/data.jsp',function(){
设置超时(加载,1000);
});
}
加载();
还可以查看JSFIDLE上的工作演示:


当然,这只是基本的想法。你真的应该包括一些错误处理等。

我设法用这段代码解决了这个问题

<%@page import="com.liferay.portal.kernel.portlet.LiferayWindowState"%>
<%@page import="java.util.Date"%>
<%@ taglib uri="http://java.sun.com/portlet_2_0" prefix="portlet" %>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>

 <script type="text/JavaScript">
 <!--
 function timedRefresh(timeoutPeriod) {

 $.post('<portlet:renderURL windowState="<%= LiferayWindowState.EXCLUSIVE.toString() %>"></portlet:renderURL>', function(data){
     $("#myportlet").html(data);
 })
}
timedRefresh(5000);
//   -->

</script>
<div id="myportlet"><%= new Date() %></div>

感谢@boky,他给了我解决这个问题的主要思路:)

问候


Danial

我设法用这段代码解决了这个问题

<%@page import="com.liferay.portal.kernel.portlet.LiferayWindowState"%>
<%@page import="java.util.Date"%>
<%@ taglib uri="http://java.sun.com/portlet_2_0" prefix="portlet" %>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>

 <script type="text/JavaScript">
 <!--
 function timedRefresh(timeoutPeriod) {

 $.post('<portlet:renderURL windowState="<%= LiferayWindowState.EXCLUSIVE.toString() %>"></portlet:renderURL>', function(data){
     $("#myportlet").html(data);
 })
}
timedRefresh(5000);
//   -->

</script>
<div id="myportlet"><%= new Date() %></div>

感谢@boky,他给了我解决这个问题的主要思路:)

问候


Danial

如何触发此javascript运行?或者这个脚本将在onLoad时运行,或者怎么样?我如何触发这个javascript运行?或者这个脚本将在onLoad时运行,或者怎么样?嗨,boky。。。感谢您的回答,我尝试了您的答案,但仍然没有成功,它不起作用,在data.jsp中,我显示了当前日期时间,但它不会每秒更新,如果我尝试@harishkrsingla answer,我如何触发javascript在每次页面加载时运行?我使用的是MVC portlet:)首先确保load()中的URL是正确的。然后确保你的负载正在点火(与Chrome的检查员检查)。另外,请确保Javascript中没有任何语法错误(再次,请与Inspector联系)。您好,谢谢您的回答,我让它运行,并且只使用一个JSPhi boky。。。感谢您的回答,我尝试了您的答案,但仍然没有成功,它不起作用,在data.jsp中,我显示了当前日期时间,但它不会每秒更新,如果我尝试@harishkrsingla answer,我如何触发javascript在每次页面加载时运行?我使用的是MVC portlet:)首先确保load()中的URL是正确的。然后确保你的负载正在点火(与Chrome的检查员检查)。还要确保Javascript中没有任何语法错误(再次,请与Inspector联系)。您好,谢谢您的回答,我让它运行,并且只使用一个JSP