2025年1月4日 星期六 甲辰(龙)年 冬月初二 设为首页 加入收藏
rss
您当前的位置:首页 > 计算机 > 编程开发 > JavaScript

使用浮动框架实现JS异步通信

时间:03-07来源:作者:点击数:57

使用框架集设计远程脚本存在以下缺陷:

  • 框架集文档需要多个网页文件配合使用,结构不符合标准,也不利于代码优化。
  • 框架集缺乏灵活性,如果完全使用脚本控制异步请求与交互,不是很方便。

iframe 元素(浮动框架)与 frameset(框架集)功能相同,但是 <iframe> 是一个普通标签,可以插入到页面任意位置,不需要框架集管理,也便于 CSS 样式和 JavaScript 脚本控制。

操作步骤

1) 在客户端交互页面(main.htm)中新建函数 hideIframe(),使用该函数动态创建浮动框架,借助这个浮动框架现实与服务器进行异步通信。

  • //创建浮动框架
  • //参数:url表示要请求的服务器端文件路径
  • //返回值:无
  • function hideIframe (url) {
  • var hideFrame = null; //定义浮动框架变量
  • hideFrame = document.createElement ("iframe"); //创建iframe元素
  • hideFrame.name = "hideFrame"; //设置名称属性
  • hideFrame.id = "hideFrame"; //设置ID属性
  • hideFrame.style.height = "0px"; //设置高度为0
  • hideFrame.style.weight = "0px"; //设置宽度为0
  • hideFrame.style.position = "absolute"; //设置绝对定位,避免浮动框架占据页面空间
  • hideFrame.style.visibility = "hidden"; //设置隐藏显示
  • document.body.appendChild (hideFrame); //把浮动框架元素插入body元素中
  • setTimeout (function () { //设置延缓请求时间
  • frames["hideFrame"].location.href = url;
  • }, 10)
  • }

当使用 DOM 创建 iframe 元素时,应设置同名的 name 和 id 属性,因为不同类型浏览器引用框架时分别使用 name 或 id 属性值。当创建好 iframe 元素之后,大部分浏览器(如 Mozilla 和 Opera)会需要一点时间(约为几毫秒)来识别新框架并将其添加到帧集合中,因此当加载地址准备向服务器进行请求时,应该使用 setTimeout() 函数使发送请求的操作延迟 10 毫秒。这样当执行请求时,浏览器能够识别这些新的框架,避免发生错误。

如果页面中需要多处调用请求函数,则建议定义一个全局变量,专门用来存储浮动框架对象,这样就可以避免每次请求时都创建新的 iframe 对象。

2) 修改客户端交互页面中 request() 函数的请求内容,直接调用 hideIframe() 函数,并传递 URL 参数信息。

  • function request () { //异步请求函数
  • var user = document.getElementById ("user"); //获取用户名文本框,注意引用路径的不同
  • var pass = document.getElementById ("pass"); //获取密码域,注意引用路径的不同
  • var s = "iframe_server.htm?user=" + user.value + "&pass=" + pass.value;
  • hideIframe(s); //创建浮动框架,指定请求文件和传递信息
  • }

由于浮动框架与框架集属于不同级别的作用域,浮动框架是被包含在当前窗口中的,所以应该使用 parent 来调用回调函数,而不是 parent.frames[0] 来调用回调函数,或者在回调函数中读取文档中的元素。

  • function callback (b, n) {
  • if (b && n) { //如果返回信息合法,则在页面中显示新的信息
  • var e = document.getElementsByTagName ("body")[0];
  • e.innerHTML = "<h1>" + n + "</h1><p>你好,欢迎登录站点</p>";
  • } else { //否则,提示错误信息,并显示表单要求重新输入
  • console.log("你输入的用户名或密码有误,请重新输入");
  • var user = parent.document.getElementById ("user"); //获取文档中的用户名文本框
  • var pass = parent.document.getElementById ("pass"); //获取文档中的密码域
  • user.value = ""; //情况文本框
  • pass.value = ""; //清空密码域
  • }
  • }

3) 在服务器端响应页面中也应该修改引用客户端回调函数的路径。

  • window.onload = function () {
  • //...
  • parent.callback (b, n); //注意,引用路径的变化
  • }

这样通过 iframe 浮动框架只需要两个文件:客户端交互页面(main.htm)和服务器端响应页面(server.htm),就可以完成异步信息交互的任务。由于安全的原因,谷歌等浏览器不支持页面之间的连续跳转。在 IE 下,必须点击“允许阻止的内容”,方可在 IE 下正常运行。演示效果如图所示: 

 
 
 
 
方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门