使用框架集设计远程脚本存在以下缺陷:
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 下正常运行。演示效果如图所示: