JSP頁面右下角消息彈框的實現

JSP頁面上通過JS實現消息彈出框,樣式可根據要求修改,這邊只是一個簡單的示範例子,自定義了兩條消息,彈框效果如下

 

JSP頁面

<%@ page language="java" import="java.util.*" pageEncoding="gb2312"%>
<%@page import="java.util.*"%>
<html>
  <head>
	<style type="text/css">
		#winpop { width:250px; height:0px; position:absolute; right:0; bottom:0; border:1px solid grey; margin:0; padding:1px; overflow:hidden; display:none; background:#FFFFFF}
		#winpop .title { width:100%; height:20px; line-height:20px; background:#0AB0FF ; font-weight:bold; text-align:center; font-size:12px;color:white}
		#winpop .con { width:100%; height:360px; line-height:80px; font-weight:bold; font-size:12px; color:#FF0000; text-decoration:underline; text-align:center}
		.close { position:absolute; right:4px; top:-1px; color:#FFFFFF; cursor:pointer}
	</style>
  </head>
<%     
    //未讀消息unreadList根據實際情況取
    List<Map> unreadList = new ArrayList<Map>();
	Map<String,String> map1=new HashMap<String,String>();
	map1.put("msgId","1");
	map1.put("msgContent","message111111");
	unreadList.add(map1);
	Map<String,String> map2=new HashMap<String,String>();
	map2.put("msgId","2");
	map2.put("msgContent","message222222");
	unreadList.add(map2);
    int num=unreadList.size();
%>
  <body>
    <script language="javascript" type="text/javascript">
		window.onload = function tanchuang() { //加載
			document.getElementById('winpop').style.height = '0px';//要初始化這個高度,雖然CSS裏已經初始化了
			
				setTimeout("tips_pop()",0); //調用tips_pop()這個函數
		}
		
		function tips_pop() {
			var MsgPop = document.getElementById("winpop");//獲取窗口這個對象,即ID爲winpop的對象
			var popH = parseInt(MsgPop.style.height);//用parseInt將對象的高度轉化爲數字,以方便下面比較
		
			if (popH == 0) { //如果窗口的高度是0
				MsgPop.style.display = "block";//那麼將隱藏的窗口顯示出來
				show = setInterval("changeH('up')", 2);//開始以每0.002秒調用函數changeH("up"),即每0.002秒向上移動一次
			} else { //否則
				hide = setInterval("changeH('down')", 2);//開始以每0.002秒調用函數changeH("down"),即每0.002秒向下移動一次
			}
		}
		function changeH(str) {
			var MsgPop = document.getElementById("winpop");
			var popH = parseInt(MsgPop.style.height);
			if (str == "up") { //如果這個參數是UP
				if (popH <= 100) { //如果轉化爲數值的高度小於等於100
					MsgPop.style.height = (popH + 4).toString() + "px";//高度增加4個象素
				} else {
					clearInterval(show);//否則就取消這個函數調用,意思就是如果高度超過100象度了,就不再增長了
				}
			}
			if (str == "down") {
				if (popH >= 4) { //如果這個參數是down
					MsgPop.style.height = (popH - 4).toString() + "px";//那麼窗口的高度減少4個象素
				} else { //否則
					clearInterval(hide); //否則就取消這個函數調用,意思就是如果高度小於4個象度的時候,就不再減了
					MsgPop.style.display = "none"; //因爲窗口有邊框,所以還是可以看見1~2象素沒縮進去,這時候就把DIV隱藏掉
				}
			}
		}
	</script>
	
	<%if(num>0){ %>
		<div id="winpop">
		<div class="title" >系統信息<br>
		共有<font color="red"><big><%=num %></big></font>條未讀消息
		<span class="close" onclick="tips_pop()">X</span></div>
		<%for(int i=0;i<num;i++) { %>
		<!-- 點擊信息標題鏈接到信息明細,傳遞信息編號參數 -->
		      <a href="/XXXAction.do?msgId=<%=unreadList.get(i).get("msgId") %>">
				<%if(String.valueOf(unreadList.get(i).get("msgContent")).length()>16) {%>
					<%=String.valueOf(unreadList.get(i).get("msgContent")).substring(0,16)+"..." %>
					<%} else{ %>
					<%=String.valueOf(unreadList.get(i).get("msgContent")) %>
					<%} %>
			  </a><br>
			<%
				if(i>=1){//最多顯示兩條
					break;
				}
			} %>
			<center>
			<!-- 點擊查看更多未讀消息 -->
			<a href="/XXXAction.do %>"><font color="red">更多未讀消息...</font></a></center>
		</div>
		<%} %>
  </body>
</html>


 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章