问题5:  使用aspx 页面执行后台方法,总是要刷新整个页面?我想提交后台不刷新页面,同时返回参数 执行前台的js 脚本,就是说类似于像 ajax 的效果一样,那我们该怎么做呢?

大家是否已经看了前面的文章,下面我们来总结一下如何去实现?

首先我们要知道 ,我们的aspx 页面 默认情况下 执行后台 是通过 form1 表单提交到后台的,而我们前面 <from>  标签中,有一个属性叫做  target的属性,系统默认情况下是“-self”,就是说返回的数据是指向自己的,表示整个页面会刷新,我们想不 刷新整个页面,我们只需要 在 界面上 放置一个隐藏的 <iframe>标签,同时将id=‘from1’ 的表单的属性target 指向 <iframe> 的name 的值,然后我们就会发现 ,aspx页面 执行后台后,页面没有刷新了。

上面是对我前一堂课程的总结!!!下面我们来看一下 C# 后台如何传输参数到前台,同时让前台能够接收到后台传出的参数????

其实写过 一般处理程序的人都知道,如何传递参数的,使用 Response.Write(“我是好人”);这样会将 这个值输入到  iframe 中,但是iframe中我们只需要我们传入的值,但是我们看到 iframe 中 除了 传入 我们需要的值之外还有很多我们不要的元素,所以我们要将这些不要的清除掉,怎么清除掉呢?

我们可以这样写

 Response.ClearContent();
Response.Write("我是好人");
Response.End();

  大功告成,这样前台 iframe 只显示我们输出的值了。

现在出现了另外一个问题,我们的前台如何 判断  ,后台c# 代码执行完成后再执行  前台的js方法?

我曾经想过用 用 settimeout 去循环判断 iframe 中内容的值,虽然可以实现,但是容易陷入死循环,而且还有时间差,效果远不如 ajax 。

如果不能这么做,我们可以从另外一个方面来入手,我们知道 iframe 是有一个load 的事件,我们这里必须使用 jquery的 事件绑定的方法,使用前要先去除绑定,然后在重新绑定,不然的话  iframe上就会不停的绑定不同的 load事件,代码实例如下:

$("#_NofreshIframe").unbind("load");
$("#_NofreshIframe").bind("load", function () {   alert(1)  });

我们来测试一下,确实能在后台代码执行完成后能执行iframe的  load事件。

那我们需要获取iframe 中的值就很容易了,这里我们这样获取iframe中的值,

var result = $(window.frames["_NofreshIframe"].document).text();

这个方法能兼容所有的浏览器的所有版本,以及iframe 跨域的问题。

其实说了这么多,讲了这么多废话,其实离我们的最终目的快要达到,就是要  打造一个 类似于 ajax 的方法,能够传输到后台,并返回参数,我们需要做的就是对前面的这些东西进行 类似于  ajax  post 提交 的 封装,以及对 后期产生问题的展望!!!!

打造颠覆你想象中的高性能,轻量级的webform框架---无刷新提交后台并返回参数(第五天)的更多相关文章

  1. 打造颠覆你想象中的高性能,轻量级的webform框架---js直接调后台的封装(第三天)

    如果你没有看我第二天写的内容的,我想你是看不懂的!!!! 好了,废话不多说,怎么才能让我们的代码变得牛逼起来呢?怎么封装我们的代码呢?我们不可能 每个页面都需要那样写吧,那我们来一步一步来封装 我们的 ...

  2. 打造颠覆你想象中的高性能,轻量级的webform框架-----如何替换webform的垃圾控件(第一天)

    前文描述: 随着.net  推出 MVC框架以来,webform 与 mvc 的争论一直没有停止过,一直以来 mvc 的 拥护者远远高于 webform,但是webfrom的有些优势又是mvc而无法替 ...

  3. 打造 高性能,轻量级的 webform框架---js直接调后台(第二天)

    问题2: 每次与后台打交道 都需要写一些自己都看不太懂的事件,而且传参数很麻烦,这就是.net 封装的事件,如何解决呢?        首先以为webfrom事件,都需要写 服务器控件来绑定后台的事件 ...

  4. JQuery中ajaxSubmit,在ie或360兼容,提交后台不能获得参数

    问题描述:360兼容模式.IE浏览器,通过ajaxSubmit提交,后台不能获得参数值 解决办法:把options.semantic这个参数改成true 代码: var ajax_option={ s ...

  5. 又一个高性能轻量级的iOS模型框架YYModel

    前言 iOS的模型框架其实有很多了,去年研究过Mantle,也了解过JSONModel.MJExtension,最近的项目项目优化的时候,再次考虑,基于轻量级.高性能的考虑,最终选择了YYModel. ...

  6. 0930MySQL中实现高性能高并发计数器方案(例如文章点击数)

    转自http://www.jb51.net/article/56656.htm 这篇文章主要介绍了MySQL中实现高性能高并发计数器方案,本文中的计数器是指如文章的点击数.喜欢数.浏览次数等,需要的朋 ...

  7. 为WPF中DropShadowBitmapEffect提供轻量级的替代品

    原文:为WPF中DropShadowBitmapEffect提供轻量级的替代品 为WPF中DropShadowBitmapEffect提供轻量级的替代品                         ...

  8. std::string的Copy-on-Write:不如想象中美好(VC不使用这种方式,而使用对小字符串更友好的SSO实现)

    Copy-on-write(以下简称COW)是一种很重要的优化手段.它的核心思想是懒惰处理多个实体的资源请求,在多个实体之间共享某些资源,直到有实体需要对资源进行修改时,才真正为该实体分配私有的资源. ...

  9. 快速电路仿真器(FastSPICE)中的高性能矩阵向量运算实现

    今年10-11月份参加了EDA2020(第二届)集成电路EDA设计精英挑战赛,通过了初赛,并参加了总决赛,最后拿了一个三等奖,虽然成绩不是很好,但是想把自己做的分享一下,我所做的题目是概伦电子出的F题 ...

随机推荐

  1. Swift三元条件运算

    三元条件运算的特殊在于它是有三个操作数的运算符,它的原型是问题?答案1:答案2.它简洁地表达根据问题成立与否作出二选一的操作.如果问题成立,返回答案1的结果; 如果不成立,返回答案2的结果. 使用三元 ...

  2. 很好的复习资料: SQL语句到底怎么写 ?

    本文用到的数据库如下: CREATE DATABASE exam; /*创建部门表*/ CREATE TABLE dept( deptno INT PRIMARY KEY, dname VARCHAR ...

  3. Azure MySQL PaaS (3) 创建MySQL异地只读数据库 (Master-Slave)

    <Windows Azure Platform 系列文章目录> Azure MySQL PaaS服务提供异地只读的功能,我们可以在主站点,比如Azure上海数据中心,创建MySQL主节点. ...

  4. python 三级菜单 while循环三次,湖北省市-县-街道的选择,3个while的循环 -day2

    python编写一个三级while的循环菜单 1.定义字典,字典里面嵌套字典,内嵌字典的值为列表. 思路: 湖北省的市:字典中的定义3个字典,用于存储{序列-键:市名} shiqu_dir = {} ...

  5. 关于 静态页面布局 中的一些BUG

    作为一枚初级程序猿,难免在制作静态页面时会遇到一些BUG,在此,我从网上找了一些资料并且结合自己的项目开发经验,总结了一些在静态页面布局时可能会遇到的问题,希望能对初级程序猿有一定的帮助(资料请参考: ...

  6. Python系列教程(三):输入和输出

    1.1 raw_input() 在Python中,获取键盘输入的数据的方法是采用 raw_input 函数(至于什么是函数,咱们以后的章节中讲解),那么这个 raw_input 怎么用呢? 看如下示例 ...

  7. Sublime Text 3 注册码

    最近觉得Sublime Text3比Notepad++好使,可惜需要购买,于是网上搜了一下,屌丝的福音啊: Sublime Text Build 3065 License key复制如下三个任意一个正 ...

  8. PAT-1099(Build A Binary Search Tree)

    题目见这里 分析:分四步进行 1)根据给定的结点情况建二叉树  2)对输入的键值排序(asending) 3)对二叉树中序遍历,同时对应赋key值 4)层次遍历(队列应用) 题目并不困难,但是我误入了 ...

  9. file里的路径

    实例话file类的对象 File file=new File("d:/mydoc/hello.txt") 文件名:fileMethod.java 相对路径:fileMethod.j ...

  10. Oracle DECODE函数的用法详解

    Oracle DECODE函数使用方法: 1.比较大小select decode(sign(变量1-变量2),-1,变量1,变量2) from dual; --取较小值sign()函数根据某个值是0. ...