实现刷新的方法主要是Ajax,本文档实现Ajax有两个方法Jquery W3CJS方法);其次,使用JS也可以实现刷新数据不刷新页面(详见其他刷新页面方法JS实现);对于CallbackRefresh的方法也可以实现刷新。

      上面的方法都是在页面不刷新情况下刷新数据,Iframe实现的刷新会刷新页面,此方法可以借鉴。

 Ajax的实现:

Javascript方式:

<script type="text/javascript">

        function loadXMLDoc(str) {

            var xmlhttp;

            var txt, x, i;

            if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari

                xmlhttp = new XMLHttpRequest();

            }

            else {// code for IE6, IE5

                xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");

            }

            xmlhttp.onreadystatechange = function() {

                if (xmlhttp.readyState ==  && xmlhttp.status == ) {

                    xmlDoc = xmlhttp.responseXML;

                    //xmlDoc = xmlhttp.responseText;

                    txt = "";

                    x = xmlDoc.getElementsByTagName("TagName");

                    for (i = ; i < x.length; i++) {

            if (x[i].childNodes[].nodeValue.contains(str)) {

                            txt = txt + x[i].childNodes[].nodeValue;

                        }

                    }

                    document.getElementById("txtHint").innerHTML = txt;

                }

            }

            xmlhttp.open("GET", "url", true);

            xmlhttp.send();

        }

jquery:

<script type="text/javascript">

        function loadXMLDoc(str) {

$("div").ajaxError(function(){

     alert("An error occurred!");

  });

  $("#txt").ajaxStart(function(){

     alert("AJAX 请求已成功完成");

  });

  $("div").ajaxSuccess(function(){

    alert("AJAX 请求已成功完成");

  });

  $("#txt").ajaxComplete(function(){

     alert("AJAX 请求已成功完成");

  });

  $("button").click(function(){

    $("#txt").load("url");

  });

 }

URL的使用:

Txt:

如果是 e.txt

xmlDoc = xmlhttp.responseText;

XML:

如果是e.xml

xmlDoc = xmlhttp.responseXML;

x = xmlDoc.getElementsByTagName("TagName");

x[i].childNodes[].nodeValue

asp页面:

如果是Asp页面   可以用下面方法调用方法获取返回值:

URL:"WebForm1.aspx?city=" + "beijing"

页面方法一:

在被请求页面的WebForm1.aspx.cs 的Page_Load 里面写:

protected void Page_Load(object sender, EventArgs e)

    {

        //获取传递过来的参数

        string city =Request.QueryString["city"];

        Response.Clear();

        //判断城市名

        switch (city)

        {

            case "beijing":

                //填充相关的区域

                Response.Write("朝阳,海淀,东城,西城");

                break;

            case "shanghai":

                Response.Write("浦东,静安,虹口,徐汇");

                break;

            case "jinan":

                Response.Write("历下,历城,市中,天桥");

                break;

        }

    }

页面方法二:

直接在被请求页面WebForm1.aspx 页面写代码

<%

response.write("<table>")

    response.write("<tr><td><b>" & "asda" & "</b></td>")

    response.write("<td>" & "asdad" & "</td></tr>")

response.write("</table>")

%>

其他的刷新页面方法:

方法1:

CallbackRefresh:

页面调用方法

<script type="text/javascript">

        function FillData()

        {

           var city=document.getElementById("TextBox1").value;

            <% =this.ClientScript.GetCallbackEventReference(this,"city","FillDll",null)  %>;

        }

        function FillDll(strcity)

        {

           document.getElementById("DropDownList1").options.length=;

           var indexofcity;

           var city;

           //切割传递来的字符串

           while(strcity.length>)

           {

           //判断是否是最后一个字符串

            indexofcity=strcity.indexOf(",");

            if(indexofcity >)

            {

            city=strcity.substring(,indexofcity);

            strcity=strcity.substring(indexofcity+);

            //填充下拉框

            document.getElementById("DropDownList1").add(new Option(city,city));

            }

            else

            {

            // 如果是最后一个字符串

               document.getElementById("DropDownList1").add(new Option(strcity,strcity));

               break;

            }

           };

        }

    </script>

后台代码:要继承ICallbackEventHandler  (重要)

public partial class _Default : System.Web.UI.Page,ICallbackEventHandler

{

    private string _data;

    protected void Page_Load(object sender, EventArgs e)

    {

    }

    #region ICallbackEventHandler 成员

    public string GetCallbackResult()

    {

        //返回处理后的数据

        return _data;

    }

    public void RaiseCallbackEvent(string eventArgument)

    {

        //判断传递过来的参数

        switch (eventArgument)

        {

            case "北京":

                _data = "朝阳,海淀,东城,西城";

                break;

            case "上海":

                _data = "浦东,静安,徐汇,虹口";

                break;

            case "济南":

                _data = "历城,历下,市中,天桥";

                break;

        }

    }

    #endregion

}

JS 实现局部刷新: 后台代码如下:

protected void Page_Load(object sender, EventArgs e)

    {

        //创建字符串连接对象

        StringBuilder myscript = new StringBuilder();

        //使用字符串组织一个JavaScript脚本方法

        myscript.Append("function seekCity()    {\n");

        myscript.Append("var city=document.getElementById('TextBox1').value; \n");

        myscript.Append("switch(city)       {\n");

        myscript.Append("case '北京': \n");

        myscript.Append("FillData('" + GetCityStr("北京") +"'); \n");

        myscript.Append("break; \n");

        myscript.Append("case '上海': \n");

        myscript.Append("FillData('" + GetCityStr("上海") + "'); \n");

        myscript.Append("break; \n");

        myscript.Append("case '济南': \n");

        myscript.Append("FillData('" + GetCityStr("济南") + "'); \n");

        myscript.Append("break; }\n");

        myscript.Append(" }\n");

        //使用注册脚本方法在页面的客户端,注册这个字符串编写的脚本方法。

        Page.ClientScript.RegisterClientScriptBlock(typeof(string), "seekCity", myscript.ToString(),true);

}

    //通过获取城市名,返回城市的区县字符串

    private string GetCityStr(string INcity)

    {

       string city="";

        switch (INcity)

        {

            case "北京":

                city = "朝阳,海淀,东城,西城";

                break;

            case "济南":

                city = "历城,历下,市中,天桥";

                break;

        }

        //返回包含区县的 字符串连接        return city;

    }

页面层直接调用:

onclick="seekCity()"

切割字符:

function FillData(strcity)

        {

           document.getElementById("DropDownList1").options.length=;

           var indexofcity;

           var city;

           //切割传递来的字符串

           while(strcity.length>)

           {

           //判断是否是最后一个字符串

            indexofcity=strcity.indexOf(",");

            if(indexofcity >)

            {

            city=strcity.substring(,indexofcity);

            strcity=strcity.substring(indexofcity+);

            //填充下拉框

            document.getElementById("DropDownList1").add(new Option(city,city));

            }

            else

            {

            // 如果是最后一个字符串

               document.getElementById("DropDownList1").add(new Option(strcity,strcity));

               break;

            }

           };

        }

Iframe实现局部刷新:

要求刷新页面JS代码:

<script language="javascript">

       function Search()

       {

            var city=document.getElementById("TextBox1").value;

            if(city !="")

            {

               document.getElementById("iframe1").src="myframe.aspx?city=" +city;

            }

       }

被请求页面代码:

<asp:DropDownList ID="DropDownList1" runat="server" Width="154px">

protected void Page_Load(object sender, EventArgs e)

    {

        //获取传递过来的参数

        string city = Request.QueryString["city"];

        //判断城市名

        switch (city)

        {

            case "北京":

                //填充相关的区域

                DropDownList1.Items.Clear();

                DropDownList1.Items.Add("朝阳");

                DropDownList1.Items.Add("海淀");

                DropDownList1.Items.Add("东城");

                DropDownList1.Items.Add("西城");

                break;

        }

    }

Ajax与C#应用详细实例的更多相关文章

  1. jQuery Ajax方法调用 Asp.Net WebService、WebMethod 的详细实例代码

    将以下html存为ws.aspx <%@ Page Language="C#" AutoEventWireup="true" %> <scri ...

  2. 原生AJAX入门讲解(含实例)

    相对于jQuery.YUI以及其他一些类库的AJAX封装,原生JS的AJAX显得那么的尴尬,兼容性不好,要记很多的方法属性,调用不便捷,代码臃肿...但我还是想说,原生JS才是最根本最底层的知识(虽然 ...

  3. [Linux]Linux下安装和配置solr/tomcat/IK分词器 详细实例二.

    为了更好的排版, 所以将IK分词器的安装重启了一篇博文,  大家可以接上solr的安装一同查看.[Linux]Linux下安装和配置solr/tomcat/IK分词器 详细实例一: http://ww ...

  4. Truffle3.0集成NodeJS并完全跑通(附详细实例,可能的错误)

    Truffle3.0集成NodeJS并完全跑通(附详细实例,可能的错误) Truffle3.0集成NodeJS并完全跑通(附详细实例,可能的错误) 升级到Truffle3.0 如果之前安装的是Truf ...

  5. SpringCloud+MyBatis+Redis整合—— 超详细实例(二)

    2.SpringCloud+MyBatis+Redis redis①是一种nosql数据库,以键值对<key,value>的形式存储数据,其速度相比于MySQL之类的数据库,相当于内存读写 ...

  6. Ajax跨域:Jsonp实例--百度搜索框下拉提示

    Ajax跨域:Jsonp实例--百度搜索框下拉提示 一.总结 一句话总结:a.找好接口:b.用script标签的src引入文件(json数据):c.定义及实现上一步引入文件中的函数 1.如何找到一个网 ...

  7. SQL的7种连接查询详细实例讲解

    SQL的7种连接查询详细实例讲解 原文链接:https://mp.weixin.qq.com/s/LZ6BoDhorW4cSBhaGy8VUQ 在使用数据库查询语句时,单表的查询有时候不能满足项目的业 ...

  8. jquery ajax php+mysql 无刷新分页 详细实例

    最近在接触jquery和ajax,当前项目也会用到分页,为了用户体验更好一些,就准备用无刷新分页,这个demo很适合新手学习查看,写的比较清晰,话不多说,直接上代码吧. 首先是html页面,index ...

  9. jquery ajax jsonp跨域调用实例代码

    今天研究了AJAX使用JSONP进行跨域调用的方法,发现使用GET方式和POST方式都可以进行跨域调用,这里简单分享下,方便需要的朋友 客户端代码 复制代码 代码如下: <%@ Page Lan ...

随机推荐

  1. php5.6解决curl扩展不生效的问题

    最近在本机安装PHP环境,遇到一个奇粑问题,本地安装的php5.2.php5.3.php5.4都需要做常规设置,即可正常使用.安装php5.5.php5.6时php_curl按各种方法进行配制,都无法 ...

  2. 也谈js函数节流

    1.什么是js函数节流 其本质就是不让某些代码(函数)在没有间断的情况下连续重复执行,目的就是让执行函数的请求停止了一段时间后才执行. 2.函数节流运用的场景 窗口大小的改变(resize事件),滚动 ...

  3. vs2012 发布网站丢失文件

    问题描述 在发布网站时,发现上线的网站总是功能缺失,而本地代码确实没问题. 到发布网站的磁盘去查看,发现丢失了很多静态页面文件. 这是一个很奇怪的问题:mvc的网站,丢失了很多View(大部分的csh ...

  4. easyui的datagrid删除一条记录后更新出问题

    1.问题 如果先删除一条记录,然后不选中一条记录,去更新一条,默认是有选中的记录的,就是被删除的那条记录. 2.解决方法 $("#dg").datagrid('uncheckAll ...

  5. 初学swift笔记字典、数组(四)

    import Foundation //字典 元素顺序是无序的 //1.字典元素是键值对 (key:value) //key 一定是可哈希的 string\int\bool var dic1=[&qu ...

  6. jsp九九乘法表

    <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding= ...

  7. WPS Office手机版调用接口代码指导帖之一(Android)

    经常会有一些喜欢开发鼓捣的童鞋问我们,WPS Office手机版是否提供调用接口,希望在android中使用一个调用命令,直接调用WPS手机版来打开指定的DOC文件,而不用弹出一个程序可选列表(如果用 ...

  8. hdu 1078(记忆化搜索)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1078 //dp[i][j]表示从点i,j处开始能获得的最多cheese #include <io ...

  9. ceph for openstack快速部署实施

    for el6 即centos6 1,添加ceph 官方yum源 [root@ruiy ~]# cat /etc/yum.repos.d/ceph.repo[ceph-noarch]name=Ceph ...

  10. db2 for linux

    https://www6.software.ibm.com/sdfdl/v2/regs2/db2pmopn/db2_v101/expc/Xa.2/Xb.aA_60_-idYiSFeSuWlF5-w4v ...