iframe实现局部刷新和回调--开篇

今天做项目遇到一个问题。就是提交表单的时候,验证用户名是否存在和验证码是否正确。

当验证码或者用户名存在的时候。在后台弹窗提示。可页面原本file里面符合要求的值刷新没了。用户体验不好。因为用ifream刷新技术已不是什么新鲜技术。所以网上有大把的资料可参考。只是因为本人是初次接触。所以记下自己的知识点。当成长经历。对于入门的我们先来全名了解下。

什么是iframe

Iframe是Inline Frame的缩写,称为内联框架(即行内框架)。看着很眼熟吧,对了,它有个近亲可是大名鼎鼎的Frame(框架)标记。使用框架有两个缺点:占用了宝贵的显示面积、不利于保持网站整体风格。而使用Iframe则可以避免此类缺点。它可以在网页的局部插入另一个文件,更新时只要更改所插入的文件即可

Iframe标记格式使用:

  <iframe src="http://www.cnblogs.com" width=830 heitht=999  scrolling="yes"></iframe>

            

 

  src:文件的路径,既可是HTML文件,也可以是文本、ASP等;
  width、height:“画中画“区域的宽与高;
  scrolling:当src的指定的HTML文件在指定的区域不显不完时,滚动选项,如果设置为NO,则不出现滚动条;如为Auto:则自动出现滚动条;如为Yes,则显示;
  FrameBorder:区域边框的宽度,为了让“画中画“与邻近的内容相融合,常设置为0。

iframe框架与form表单实例

我们经常做的是在页面放一个隐藏的iframe,然后把form的target属性指向iframe的name属性

<!--这里设置target="ajaxifr",这样表单就提交到iframe里面了,和平时未设置target属性时默认提交到当前页面 -->
<iframe name="ajaxifr" runat="server" style="display:block;"></iframe>
<form method="post" runat ="server" enctype="multipart/form-data" action="check.ashx" target="ajaxifr" οnsubmit="return check()" >
    选择文件:<input type="file" name="upfile" /><br />
   <input type="submit" runat="server" value="提交" />
</form>

现在action的页面是子窗体,即check.ashx,from当前页面为父页面。

在父窗体中,Iframe即子窗体是document对象的一个子对象,可以直接在脚本中访问子窗体中的对象。

在子窗体中我们可以通过其parent即父(双亲)对象来访问父窗口中的对象。

function msg()
{alert("回调");       
}
//通过parent访问父页面的函数。实现回调
Response.Write("<script>parent.msg()</script>");
//如果不想回调,只想弹窗,可以加parent也可以不加(因为弹窗会在顶层显示),其他的同理
Response.Write("<script>parent.alert('提示')</script>");
//重定向
Response.Write("<script>parent.window.location.href='http://www.cnblogs.com'</script>"); //记住:这里如果不用parent(主动权交给父页面),那就会在iframe中打开网页,
                                                   //那当我们回调显示的时候。在前台就永远都不会看到跳转的页面。除非你要求在iframe中打开

 最后附一个完整的实例。仅仅是图片上传并回调显示图片信息

 

$("#id", window.parent.document).val("cc");

var btn = ifmMain.window.document.getElementById("id");

index.aspx页面

View Code
 1 <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm2.aspx.cs" Inherits="tlxRegist.Test.WebForm2" %>
 2 
 3 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 4 <html xmlns="http://www.w3.org/1999/xhtml">
 5 <head runat="server">
 6     <title></title>
 7     <script src="../Scripts/jquery-1.3.2.min.js" type="text/javascript"></script>
 8 </head>
 9 <body>
10     <script type="text/javascript">
11         function UpdateMsg(des, filename) {//此函数用来提供给提交到的页面如upload.ashx输出js的回调,更新当前页面的信息
12             if (filename == '') { alert('未上传文件!'); return false; }
13             document.getElementById('ajaxMsg').innerHTML = '你在表单中输入的“文件描述”为:' + des + '<br/>'
14       + '上传的图片为:<a href="uploads/' + filename + '" target="_blank">' + filename + '</a>';
15         }
16 
17         function check(f) {
18             if (f.des.value == '') {
19                 alert('请输入文件描述!'); f.des.focus(); return false;
20             }
21             if (f.upfile.value == '') {
22                 alert('请选择文件!'); f.upfile.focus(); return false;
23             }
24         }
25     </script>
26     <!--隐藏的iframe来接受表单提交的信息-->
27     <iframe name="ajaxifr" style="display:none;"></iframe>
28     <!--这里设置target="ajaxifr",这样表单就提交到iframe里面了,和平时未设置target属性时默认提交到当前页面-->
29     <!--注意一点的是使用iframe时在提交到的页面可以直接输出js来操作父页面的信息,一般的ajax提交文本信息时你需要返回信息,如果是js信息你还得eval下-->
30     <form method="post" enctype="multipart/form-data" action="../upload.ashx" target="ajaxifr" οnsubmit="return check(this)">
31     文件描述:<input type="text" name="des" /><br />
32     选择文件:<input type="file" name="upfile" /><br />
33     <input type="submit" value="提交" />
34     </form>
35     <!--放入此div用来实现上传的结果-->
36     <div id="ajaxMsg">
37     </div>
38 
39 </body>
40 </html>

 

upload.ashx处理程序

View Code
 1 <%@ WebHandler Language="C#" Class="upload" %>
 2 
 3 using System;
 4 using System.Web;
 5 
 6 public class upload : IHttpHandler {
 7     private string Js(string v)
 8     {//此函数进行js的转义替换的,防止字符串中输入了'后造成回调输出的js中字符串不闭合
 9         if (v == null) return "";
10         return v.Replace("'", @"\'");
11     }
12     //下面就是一个简单的示例,保存上传的文件,如果要验证上传的后缀名,得自己写,还有写数据库什么的
13     public void ProcessRequest(HttpContext context)
14     {
15         HttpRequest Request = context.Request;
16         HttpResponse Response = context.Response;
17         HttpServerUtility Server = context.Server;
18         //指定输出头和编码
19         Response.ContentType = "text/html";
20         Response.Charset = "utf-8";
21 
22         HttpPostedFile f = Request.Files["upfile"];//获取上传的文件
23         string des = Request.Form["des"]//获取描述
24             , newFileName = Guid.NewGuid().ToString();//使用guid生成新文件名
25 
26         if (f.FileName == "")//未上传文件
27             Response.Write("<script>parent.UpdateMsg('','');</script>");//输出js,使用parent对象得到父页的引用
28         else
29         { //保存文件
30             newFileName += System.IO.Path.GetExtension(f.FileName);//注意加上扩展名
31             try
32             {
33                 f.SaveAs(Server.MapPath("~/uploads/" + newFileName));//如果要保存到其他地方,注意修改这里
34 
35                 //调用父过程更新内容,注意要对des变量进行js转义替换,繁殖字符串不闭合提示错误
36                 Response.Write("<script>parent.UpdateMsg('" + Js(des) + "','" + newFileName + "')</script>");
37             }
38             catch
39             {
40                 Response.Write("<script>alert('保存文件失败!\\n请检查文件夹是否有写入权限!');</script>");//如果保存失败,输出js提示保存失败
41             }
42 
43         }
44     }
45 
46     public bool IsReusable
47     {
48         get
49         {
50             return false;
51         }
52     }
53 
54 }

 

IE8中IFrame高度自适应

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Index.aspx.cs" Inherits="Iframe.Index" %><!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server"><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title></title><script type="text/javascript">//重新设置编辑区域高度
        function setHeight() {var h = document.documentElement.clientHeight - 90;var w = document.documentElement.clientWidth - 23;if (h > 0) { document.getElementById("tabMain").style.height = h.toString() + "px"; }var ifmA = document.getElementById("ifmA");var ifmB = document.getElementById("ifmB");if (w > 0) { ifmA.style.width = w.toString() + "px"; }if (w > 0) { ifmB.parentNode.parentNode.style.width = w.toString() + "px"; }if (ifmA.readyState == "complete") {var ih = ifmA.contentWindow.document.body.offsetHeight;if (ih > 0) { ifmA.style.height = (ih + 5).toString() + "px"; }}if (ifmB.readyState == "complete") {var oh = ifmB.contentWindow.document.body.offsetHeight;if (oh > 0) { ifmB.style.height = (oh + 5).toString() + "px"; }}}function PageLoad() {var ifmA = document.getElementById("ifmA");var ifmB = document.getElementById("ifmB");setIFrameResize(ifmA, setHeight);setIFrameResize(ifmB, setHeight);}function setIFrameResize(iframe, fun) {iframe.parentNode.onresize = setHeight;iframe.onreadystatechange = function (ev) {if (iframe.readyState == "complete") {var ic = iframe.contentWindow;ic.attachEvent('onload', fun);ic.attachEvent('onresize', fun);}}}window.onload = PageLoad;window.attachEvent("onload", setHeight);window.attachEvent("onresize", setHeight);</script>
</head>
<body><form id="form1" runat="server"><div id="tabMain"><div style="background-color: gray;">A页面</div><div><iframe id="ifmA" name="ifmA" width="100%" frameborder="0" marginwidth="0"scrolling="auto" src="a.aspx"></iframe></div><div style="background-color: gray;">B页面</div><div><iframe id="ifmB" name="ifmB" width="100%" frameborder="0" marginwidth="0"scrolling="auto" src="b.aspx"></iframe></div></div></form>
</body>
</html>
View Code

 

添加回车事件

 <input οnkeypress="getKey(event)" >

 

function getKey(e)
{
var e = e || window.event;
if (e.keyCode == 13) {
$("#btnSearch").trigger("click"); //处罚按钮的click事件
}
}

 

转载于:https://www.cnblogs.com/nsky/archive/2012/12/21/2827300.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/376993.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java文件类boolean setExecutable(boolean exec_file,boolean owner_access)方法,带示例

文件类boolean setExecutable(boolean exec_file&#xff0c;boolean owner_access) (File Class boolean setExecutable(boolean exec_file , boolean owner_access)) This method is available in package java.io.File.setExecutable(boolean exec_file , boolean owner_acc…

OLTP 系统和 OLAP 系统的核心设计思想

关于 OLTP 系统和 OLAP 系统的核心设计思想 数据存储系统的关于查询的典型操作&#xff1a; -- 第一种需求&#xff1a; 根据 key&#xff08;1&#xff09; 找 value&#xff08;name,age&#xff09;&#xff0c; 单点查询 select name, age from student where id 1; stu…

虚拟机

vt-x 虚拟技术的硬盘支持。想像成“硬解码”的东东。不是装虚拟机必须的&#xff0c;但有它效果会好些。 vt-x检测工具&#xff1a;securable.exe 下载地址&#xff1a;http://pan.baidu.com/s/1kTBOvzD Hardware Virtualization选项&#xff1a; no [CPU和BIOS都不支持VT] loc…

算法(转)

欢迎自荐和推荐链接。 算法 优秀博客推荐&#xff1a;各种数据结构与算法知识入门经典&#xff08;不断更新)基本算法 贪心算法&#xff1a;贪心算法 作者&#xff1a;独酌逸醉 贪心算法精讲 作者&#xff1a;3522021224 递归和分治&#xff1a;递归与分治策略 …

sjf调度算法_如何通过静态方法预测SJF调度中未来过程的突发时间?

sjf调度算法In SJF Scheduling, CPU is assigned to the process having the smallest burst time but it can not be implemented practically, because we dont know burst time of the arrived processes in advance. 在SJF Scheduling中 &#xff0c;将CPU分配给具有最短突…

flask 知识点总结

request对象的常用属性具体使用方法如下:request.headers, request.headers.get(If-None-Match)request.json, request.json[value] 或 request.json.get(detail_msg, "")request.args, request.args.get(limit, 10)来获取query parametersrequest.form, request.for…

Postgresql中的hybrid hash join(无状态机讲解)

hybrid hash join hybrid hash join是基于grace hash join 的优化。 在postgresql中的grace hash join 是这样做的&#xff1a;inner table太大不能一次性全部放到内存中&#xff0c;pg会把inner table 和outer table按照join的key分成多个分区&#xff0c;每个分区(有一个inn…

末日中的黎明

哈哈&#xff0c; 今天是2012-12-21&#xff0c;传说中的世界末日&#xff0c;不过现在看来&#xff0c;一切都是空的。。。 在这个容易记忆的日子里&#xff0c;我的博客开通了。他将伴随我以后的学习开发&#xff0c;期望我能充分利用博客&#xff0c;帮我养成常总结、常记笔…

使用numpy.tanh()打印矢量/矩阵元素的双曲正切值 使用Python的线性代数

Prerequisite: 先决条件&#xff1a; Defining a Vector 定义向量 Defining a Matrix 定义矩阵 Numpy is the library of function that helps to construct or manipulate matrices and vectors. The function numpy.tanh(x) is a function used for generating a matrix / v…

Mahout kmeans聚类

Mahout K-means聚类 一、Kmeans 聚类原理 K-means算法是最为经典的基于划分的聚类方法&#xff0c;是十大经典数据挖掘算法之一。K-means算法的基本思想是&#xff1a;以空间中k个点为中心进行聚类&#xff0c;对最靠近他们的对象归类。通过迭代的方法&#xff0c;逐次更新各聚…

Web项目中获取SpringBean——在非Spring组件中获取SpringBean

最近在做项目的时候我发现一个问题&#xff1a;Spring的IOC容器不能在Web中被引用(或者说不能被任意地引用)。我们在配置文件中让Spring自动装配&#xff0c;但并没有留住ApplicationContext的实例。我们如果希望在我们的项目中任何位置都能拿到同一个ApplicationContext来获取…

postgresql对于HashJoin算法的Data skew优化与MCV处理

Data skew 很好理解&#xff0c;即数据倾斜。现实中的数据很多都不是正态分布的&#xff0c;譬如城市人口&#xff0c;东部沿海一个市的人口与西部地区一个市地区的人口相比&#xff0c;东部城市人口会多好几倍。 postgresql的skew的优化核心思想是"避免磁盘IO"。 优…

JavaScript | 创建对象并通过JavaScript函数在表中显示其内容

In this example, we created an object named employee with id, name, gender, city, and salary and assigned and displaying the values in the table using JavaScript function. 在此示例中&#xff0c;我们创建了一个名为employee的对象&#xff0c;其对象为id &#x…

基于socket的简单文件传输系统

【实验目的及要求】 在 Uinx/Linux/Windows 环境下通过 socket 方式实现一个基于 Client/Server 文件传输程序。 【实验原理和步骤】 1. 确定传输模式:通过 socket 方式实现一个基于 Client/Server 或 P2P 模式的文件传输程序。 2. 如果选择的是 Client/Server 模式的文件传输…

《GPU高性能编程-CUDA实战》中例子头文件使用

《GPU高性能编程-CUDA实战&#xff08;CUDA By Example&#xff09;》中例子中使用的一些头文件是CUDA中和C中本身没有的&#xff0c;需要先下载这本书的源码&#xff0c;可以在&#xff1a;https://developer.nvidia.com/content/cuda-example-introduction-general-purpose-g…

mcq 队列_人工智能| AI解决问题| 才能问题解答(MCQ)| 套装1

mcq 队列1) Which of the following definitions correctly defines the State-space in an AI system? A state space can be defined as the collection of all the problem statesA state space is a state which exists in environment which is in outer spaceA state sp…

Postgresql的HashJoin状态机流程图整理

状态机 可以放大观看。 HashJoinState Hash Join运行期状态结构体 typedef struct HashJoinState {JoinState js; /* 基类;its first field is NodeTag */ExprState *hashclauses;//hash连接条件List *hj_OuterHashKeys; /* 外表条件链表;list of …

Ajax和Jsonp实践

之前一直使用jQuery的ajax方法&#xff0c;导致自己对浏览器原生的XMLHttpRequest对象不是很熟悉&#xff0c;于是决定自己写下&#xff0c;以下是个人写的deom&#xff0c;发表一下&#xff0c;聊表纪念。 Ajax 和 jsonp 的javascript 实现&#xff1a; /*! * ajax.js * …

得到前i-1个数中比A[i]小的最大值,使用set,然后二分查找

题目 有一个长度为 n 的序列 A&#xff0c;A[i] 表示序列中第 i 个数(1<i<n)。她定义序列中第 i 个数的 prev[i] 值 为前 i-1 个数中比 A[i] 小的最大的值&#xff0c;即满足 1<j<i 且 A[j]<A[i] 中最大的 A[j]&#xff0c;若不存在这样的数&#xff0c;则 pre…

学习语言贵在坚持

学习语言贵在坚持 转自&#xff1a;http://zhidao.baidu.com/link?urlr2W_TfnRwipvCDLrhZkATQxdrfghXFpZhkLxqH1oUapLOr8jXW4tScbyOKRLEPVGCx0dUfIr-30n9XV75pWYfK给大家介绍几本书和别处COPY来的学习C50个观点 《Thinking In C》&#xff1a;《C编程思想》&#xff1b; 《The…