JS弹出框、对话框、提示框,JS关闭窗口、关闭页面和JS控制页面跳转

一、JS弹出框、对话框、提示框

  1. //====================== JS最常用三种弹出对话框 ========================
  2. //1弹出对话框并输出一段提示信息
  3. function ale() {
  4. //弹出一个对话框
  5. alert("提示信息!");
  6. }
  7. //2弹出一个询问框,有确定和取消按钮
  8. function firm() {
  9. //利用对话框返回的值 (true 或者 false)
  10. if (confirm("你确定提交吗?")) {
  11. alert("点击了确定");
  12. }
  13. else {
  14. alert("点击了取消");
  15. }
  16. }
  17. //3弹出一个输入框,输入一段文字,可以提交
  18. function prom() {
  19. var name = prompt("请输入您的名字", ""); //将输入的内容赋给变量 name ,
  20. //这里需要注意的是,prompt有两个参数,前面是提示的话,后面是当对话框出来后,在对话框里的默认值
  21. if (name)//如果返回的有内容
  22. {
  23. alert("欢迎您:" + name)
  24. }
  25. }
  1. //按钮提示框
  2. <input type="button" name="btn2" id="btn2" value="删除" onclick="return confirm(‘Yes/No‘););
  3. //按钮提示框
  4. <input type="button" name="btn2" id="btn2" value="提示" onclick="javaScript:alert(‘您确定要删除吗?‘);
  5. //提交按钮
  6. <input type="button" value="提交" onclick="javaScript:window.location.href=‘http://www.baidu.com‘;"/>
  7. //关闭按钮
  8. <input type="button" value="关闭" onclick="javaScript:window.close();">
  9. //返回并关闭连接
  10. <a href="#" onclick="javascript:;window.opener.location.reload();window.close()">返回</a>
  11. javaScript:window.location.reload();//返回当前页并刷新
  12. //返回上一级页面
  13. <input type="button" name="button" value="< 返回" onclick="javascript:history.go(-1)"/>

二、JS关闭窗口、关闭页面

//普通带提示关闭
function closeie(){
window.close();
}
//关闭IE6不提示
function closeie6(){
window.opener=null;
window.close();
}
//关闭IE7不提示
function closeie7(){
window.open(‘‘,‘_top‘);
window.top.close();
}

三、JS控制页面跳转

1. RequestDispatcher.forward()

在服务器端起作用,当使用forward()时,Servlet engine传递HTTP请求从当前的Servlet或者是JSP到另外的一个Servlet、JSP 或普通HTML文件,也即你的form提交至a.jsp,在a.jsp用到了forward()重定向至b.jsp,此时form提交的所有信息在 b.jsp都可以获得,参数自动传递. 但forward()无法重定向至有frame的jsp文件,可以重定向至有frame的html文件,同时forward()无法在后面带参数传递,比 如servlet?name=frank,这样不行,可以程序内通过response.setAttribute("name",name)来传至下一个 页面。

重定向后浏览器地址栏URL不变。

例:在servlet中进行重定向

public void doPost(HttpServletRequest request,HttpServletResponse response)

throws ServletException,IOException{

response.setContentType("text/html; charset=gb2312");

ServletContext sc = getServletContext();

RequestDispatcher rd = null;

rd = sc.getRequestDispatcher("/index.jsp"); //定向的页面

rd.forward(request, response);

}

request.getRequestDispatcher(" /index.jsp ").forward(request, response);//转发到index .jsp       getServletConfig().getServletContext().getRequestDispatcher("

/index.jsp ").forward(request, response);

//转发到 index .jsp

通常在servlet中使用,不在jsp中使用。

2. response.sendRedirect()

在用户的浏览器端工作,sendRedirect()可以带参数传递,比如servlet?name=frank传至下个页面,同时它可以重定向至不同的主机上,sendRedirect()可以重定向有frame.的jsp文件.

重定向后在浏览器地址栏上会出现重定向页面的URL。

例:在servlet中重定向

public void doPost(HttpServletRequest request,HttpServletResponse response)

throws ServletException,IOException{

response.setContentType("text/html; charset=gb2312");

response.sendRedirect("/index.jsp");

}

由于response是jsp页面的隐含对象,故在jsp页面中可用response.sendRedirect()直接实现重定位。

注意:

(1) 使用response.sendRedirect时,前面不能有HTML输出;

这并不是绝对的,不能有HTML输出其实是指不能有HTML被送到了浏览器。事实上现在的server都有cache机制,一般在8K(我是说 JSP SERVER),这就意味着,除非你关闭了cache,或者你使用了out.flush()强制刷新,那么在使用sendRedirect之前, 有少量的HTML输出也是允许的。

(2) response.sendRedirect之后,应该紧跟一句return。

我们已经知道response.sendRedirect是通过浏览器来做转向的,所以只有在页面处理完成后,才会有实际的动作。既然你已经要做转向了,那么后的输出还有什么意义呢?而且有可能会因为后面的输出导致转向失败。

比较:

(1) Dispatcher.forward()是容器中控制权的转向,在客户端浏览器地址栏中不会显示出转向后的地址;

(2) response.sendRedirect()则是完全的跳转,浏览器将会得到跳转的地址,并重新发送请求链接。这样,从浏览器的地址栏中可以看到跳转后的链接地址。

前者更加高效,在前者可以满足需要时,尽量使用RequestDispatcher.forward()方法。

在有些情况下,比如,需要跳转到一个其它服务器上的资源,则必须使HttpServletResponse.sendRequest()方法

3. <jsp:forward page="" />

它的底层部分是由RequestDispatcher来实现的,因此它带有RequestDispatcher.forward()方法的印记。

如果在之前有很多输出,前面的输出已使缓冲区满,将自动输出到客户端,那么该语句将不起作用,这一点应该特别注意。

注意:

它不能改变浏览器地址,刷新的话会导致重复提交

4. 修改HTTP header的Location属性来重定向

通过设置直接修改地址栏来实现页面的重定向。

jsp文件代码如下:

<%

response.setStatus(HttpServletResponse.SC_MOVED_PERMANENTLY);

String newLocn = "/newpath/jsa.jsp";

response.setHeader("Location",newLocn);

%>

5. JSP中实现在某页面停留若干秒后,自动重定向到另一页面

在html文件中,下面的代码:

<meta http-equiv="refresh" content="300; url=target.jsp">

它的含义:在5分钟之后正在浏览的页面将会自动变为target.html这一页。代码中300为刷新的延迟时间,以秒为单位。targer.html为你想转向的目标页,若为本页则为自动刷新本页。

由上可知,可以通过setHeader来实现某页面停留若干秒后,自动重定向到另一页面。代码:

String content=stayTime+";URL="+URL;

response.setHeader("REFRESH",content);

js 页面跳转(父页面,外层页面,本页面)

"window.location.href"、"location.href"是本页面跳转

"parent.location.href"是上一层页面跳转

"top.location.href"是最外层的页面跳转

举例说明:

如果A,B,C,D都是jsp,D是C的iframe,C是B的iframe,B是A的iframe,如果D中js这样写

"window.location.href"、"location.href":D页面跳转

"parent.location.href":C页面跳转

"top.location.href":A页面跳转

如果D页面中有form的话,

: form提交后D页面跳转

: form提交后弹出新页面

: form提交后C页面跳转

: form提交后A页面跳转

关于页面刷新,D 页面中这样写:

"parent.location.reload();": C页面刷新 (当然,也可以使用子窗口的 opener 对象来获得父窗口的对象:window.opener.document.location.reload(); )

"top.location.reload();": A页面刷新

Js 控制页面跳转的几种方法

第一种:

<script language="javascript" type="text/javascript">
           window.location.href="login.jsp?backurl="+window.location.href;
    </script>

第二种:

<script language="javascript">
alert("返回");
window.history.back(-1);
   </script>

第三种:

<script language="javascript">
window.navigate("top.jsp");
  </script>

第四种:

<script language="JavaScript">
          self.location=‘top.htm‘;
   </script>

第五种:

<script language="javascript">
          alert("非法访问!");
          top.location=‘xx.jsp‘;
   </script>

第六种:

<script type="text/javascript">
// 页面若在框架内,则跳出框架
if (self != top) {
  top.location = self.location;
}; 

</script>

第七种:

自定义时间跳转(方法一):

<script language="javascript">
var secs = 3; //倒计时的秒数
var URL ;
function Load(url){
URL = url;
for(var i=secs;i>=0;i--)
{
  window.setTimeout(‘doUpdate(‘ + i + ‘)‘, (secs-i) * 1000);
}
}
function doUpdate(num)
{
document.getElementById(‘ShowDiv‘).innerHTML = ‘将在‘+num+‘秒后自动跳转到主页‘ ;
if(num == 0) { window.location = URL; }
}
</script>

然后在里面加上   index.asp为自己要跳转的页面。

在之间加上

自定义时间跳转(方法二):

<p style="text-indent: 2em; margin-top: 30px;">
系统将在 <span id="time">5</span> 秒钟后自动跳转至新网址,如果未能跳转,<a href="http://www.jb51.net" title="点击访问">请点击</a>。
<script type="text/javascript">
  delayURL();
  function delayURL() {
    var delay = document.getElementById("time").innerHTML;
 var t = setTimeout("delayURL()", 1000);
    if (delay > 0) {
      delay--;
      document.getElementById("time").innerHTML = delay;
    } else {
   clearTimeout(t);
      window.location.href = "http://www.jb51.net";
    }
  }
</script>

参考文献:

http://blog.csdn.net/anhuidelinger/article/details/17024491

http://www.jb51.net/article/44514.htm

http://www.tuicool.com/articles/6fQBFzF

时间: 2024-08-04 04:05:28

JS弹出框、对话框、提示框,JS关闭窗口、关闭页面和JS控制页面跳转的相关文章

点击删除时弹出是否删除提示框

点击删除时弹出是否删除提示框:在通常情况下,想要点击删除某一项的时候,一般会弹出一个框,以提示操作者是否真的要删除此项,这样可以免于出现误操作,比较人性化的一个举措,下面就简单介绍一下如何实现此效果.实例代码: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="author" content="http://www.soft

a链接中 JS弹出确认对话框方法

一种: <a href="javascript:if(confirm('确实要删除该内容吗?'))location='http://www.google.com'">弹出窗口</a> 二种: <script language="JavaScript">             function delete_confirm(e) {    if (event.srcElement.outerText == "删除&quo

Process启动.exe,当.exe内部抛出异常时,总会弹出一个错误提示框,阻止Process进入结束

1 public class TaskProcess 2 { 3 [DllImport("kernel32.dll", SetLastError = true)] 4 public static extern int SetErrorMode(int wMode); 5 6 public Process process { get; set; } 7 8 public void Do() 9 { 10 try 11 { 12 int oldMode = SetErrorMode(3);

在JSP中,当添加信息成功后跳转回主页面并弹出操作成功提示框

if(dg.addmes(title,forumname,pdate,cont)){//成功 此处向request中添加一个参数request.setAttribute("str", "true");request.getRequestDispatcher("suc.jsp").forward(request, response);}else{//失败 此处向request中添加一个参数request.setAttribute("str

ASP.net后台弹出消息对话框的方法!【转】

在winform后台,我们通过MessageBox.show(“消息")的方式来返回后台信息,在webform后台,我们通过Response.write(”消息")来返回后台消息,但这样需要将消息值以字符串形式显示到前台页面,是否有类似于MessageBox.show("消息")的方式弹出信息呢.我们会很快想到javascript的alert方法.通过在后台调用js来实现alert的调用.用法为:Response.write("<script>

如何使用Service的Context弹出Dialog对话框,即全局性对话框

在dialog.show()语句前加入: dialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT); 然后在AndroidManifest.xml中加入权限: <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/> 下面进行简单的解释: 如果只在Service中写入常在Activity中使用的创建D

JavaScript特效实例009-关闭IE主窗口时,不弹出询问对话框

实例009                      关闭IE主窗口时,不弹出询问对话框 实例说明 通常情况我们使用window.close()关闭IE窗口时,都会弹出一个是否关闭的询问框,这节我们来屏蔽掉它. 技术要点 本例主要应用JavaScript的window对象的opener属性将要关闭的IE窗口的打开窗口设置为NULL,然后再通过window对象的close()方法将该窗口关闭,这样就不会弹出询问对话框了. 实现过程 (1)实现功能主页面index.html <html> <

Win10系统potplayer经常弹出“自动更新提示”怎么办?

Potplayer是一款视频播放器,具有非常强大的功能,因此受到很多人的喜欢.但最近,有Win10的用户在使用电脑的时候,Potplayer经常会弹出“自动更新提示”.那要如何关闭这个提示呢?现在打牌就和大家说一下Win10系统potplayer经常弹出自动更新提示的解决方法. 具体步骤如下: 1.打开控制面板,进入防火墙的高级设置:    2.右键出站规则→新建规则: 3.程序→下一步→浏览-选择Potplayer安装文件夹下的播放器程序文件→下一步-阻止连接→下下下-最后的名称描述随意→完成

(转)js弹出框、对话框、提示框、弹窗总结

一.JS的三种最常见的对话框 [javascript] view plain copy //====================== JS最常用三种弹出对话框 ======================== //弹出对话框并输出一段提示信息 function ale() { //弹出一个对话框 alert("提示信息!"); } //弹出一个询问框,有确定和取消按钮 function firm() { //利用对话框返回的值 (true 或者 false) if (confirm

js弹出框、对话框、提示框、弹窗总结

一.JS的三种最常见的对话框 //====================== JS最常用三种弹出对话框 ======================== //弹出对话框并输出一段提示信息 function ale() { //弹出一个对话框 alert("提示信息!"); } //弹出一个询问框,有确定和取消按钮 function firm() { //利用对话框返回的值 (true 或者 false) if (confirm("你确定提交吗?")) { aler