JS如何实现在弹出窗口中加载页面

 更新时间:2020年12月03日 11:33:36   作者:David Huang  
这篇文章主要介绍了JS如何实现在弹出窗口中加载页面,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

弹出窗口,加载页面。弹出窗口初始位置为居中。可在关闭窗口时,回调主页面按钮。要求jquery。

效果演示

首先,演示主窗口两个按钮作用。然后,演示关闭弹出窗口时,调用主窗口的两个按钮。

主要代码(时间仓促,没加注释,不过代码很简单,就是创建几个元素拼在一起,每个元素都用var=标明了)

var _divMask;
var _divBox;

function ShowMask() {
  var divMask = $('<div></div>')
    .attr("id", "divMask")
    .css({
      "position": "absolute",
      "left": "0",
      "top": "0",
      "width": "100%",
      "height": "100%",
      "backgroundColor": "gray",
      "opacity": "0.4"
    }).appendTo("body");
  _divMask = divMask;
  return divMask;
}

function ShowBox(title, url, width, height) {
  ShowMask();
  var divBox = $("<div></div>")
    .attr("id", "divBox")
    .css({
      "position": "absolute",
      "top": (($(document).height() - height) / 2) < 0 ? 0 : (($(document).height() - height) / 2),
      "left": (($(document).width() - width) / 2),
      "width": width,
      "height": height,
      "border": "2px solid gray",
      "backgroundColor": "white"
    })
    .appendTo("body");
  var pTitle = $("<p></p>")
    .css({
      "width": (width - 20) / 2,
      "float": "left",
      "padding": "5px",
      "margin": "0"
    })
    .text(title)
    .appendTo(divBox);
  var pClose = $("<p></p>")
    .css({
      "width": (width - 20) / 2,
      "float": "left",
      "text-align": "right",
      "padding": "5px",
      "margin": "0"
    })
    .appendTo(divBox);
  var aClose = $("<a></a>")
    .css({
      "color": "black",
      "text-decoration": "none"
    })
    .attr("href", "javascript:CloseBox();")
    .text("关 闭")
    .appendTo(pClose);
  var hr = $("<hr/>")
    .css({
      "margin": "0",
      "border": "1px solid gray"
    })
    .appendTo(divBox);
  var iframeContainer = $("<iframe></iframe>")
    .attr("id", "divContainer")
    .css({
      "width": width,
      "height": height - 13 - pTitle.height(),
      "float": "left",
      "overflow": "auto",
      "border": "0"
    })
    .attr("src", url)
  .appendTo(divBox);
  _divBox = divBox;
  //divBox.draggable({ handle: "p" });
}

function CloseBox(btn) {
  if (_divMask == null) {
    if (btn != null && btn != '') {
      parent.document.getElementById(btn).click();
    }
    $(parent.document.getElementById("divMask")).remove();
    $(parent.document.getElementById("divBox")).remove();
  }
  else {
    _divMask.remove();
    _divBox.remove();
  }
}

下载

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • JavaScript WeakMap的具体使用

    JavaScript WeakMap的具体使用

    本文主要介绍了JavaScript WeakMap的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-02-02
  • 跟我学习javascript的基本类型和引用类型

    跟我学习javascript的基本类型和引用类型

    跟我学习javascript的基本类型和引用类型,利用图解的方式,告诉大家javascript的基本类型和引用类型的区别和联系,感兴趣的小伙伴们可以参考一下
    2015-11-11
  • JavaScript简单修改窗口大小的方法

    JavaScript简单修改窗口大小的方法

    这篇文章主要介绍了JavaScript简单修改窗口大小的方法,涉及javascript中moveTo与resizeTo方法的相关使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • JavaScript本地存储与会话存储的实现介绍

    JavaScript本地存储与会话存储的实现介绍

    本地存储和会话存储是比较常用的方法,你知道两者的区别吗,本文详细的介绍了JavaScript中本地存储(LocalStorage)和会话存储(SessionStorage)的使用,具有一定的参考价值,感兴趣的可以了解一下
    2022-08-08
  • js加减乘除丢失精度问题解决方法

    js加减乘除丢失精度问题解决方法

    在javascript中,带小数的数据运算时总会出现好多位小数.这是因为在javascript中浮点数的计算是以2进制计算的
    2014-05-05
  • js获取对象中所有属性的四种方法

    js获取对象中所有属性的四种方法

    这篇文章主要给大家介绍了关于js获取对象中所有属性的四种方法,在JavaScript 中,我们可以通过不同的方法获取对象的属性,文中通过代码示例介绍的非常详细,需要的朋友可以参考下
    2023-09-09
  • js判断两个日期是否相等的方法

    js判断两个日期是否相等的方法

    大家一定遇到过这样的情况,有两个日期对象,然后需要判断他们是否相等,下面来说下判断的方法
    2013-09-09
  • innerHTML innerText textContent使用区别示例详解

    innerHTML innerText textContent使用区别示例详解

    这篇文章主要为大家介绍了innerHTML innerText textContent使用区别示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • javascript获取wx.config内部字段解决微信分享

    javascript获取wx.config内部字段解决微信分享

    这篇文章主要介绍了javascript获取wx.config内部字段解决微信分享,需要的朋友可以参考下
    2016-03-03
  • js导出table到excel同时兼容FF和IE示例

    js导出table到excel同时兼容FF和IE示例

    js导出table到excel,在百度可以搜索很多的方法,但是其兼容性是相当差的,本文制定了一个可以同时兼容FF和IE的方法,感兴趣的朋友可以参考下
    2013-09-09

最新评论