牛腩新闻发布系统 整合类别管理页 笔记 ajax的使用

如果是使用 jquery的 get方式  那么一定要记得 对 传入的  中文 进行二次转码,是二次转码! 并且还要解决浏览器缓存的问题,需要用到一个随机时间,以便让浏览器认为是一个新的网址,而不至于对传送的数据进行缓存 一般是加一个  +"&t="+new Date().getTime(); 

 

记得:这里url的地址,是指你调用js的页面(例如:我们在 后台的 categoryManage.aspx页面引用了一个js,那么我们在js里面写代码的时候,是看CategoryManage.aspx相对于ashx的路径)

image

然后在ashx中再对该参数值进行解码context.Server.UrlDecode(context.request["caname"]

image

 

 

如果是post方式  则不用考虑转码和缓存  浏览器 认为 POST的提交 必定是 有改变的

 

$.post(url,[data],[callback],[type]):第234个参数为可选

url:为发送请求的地址,如上面的GetDate.ashx(注意,这里的ashx页面路径,是相对于页面的路径,而不是相对于JS文件的路径)

data:待发送的key/value参数,为字典数组,如{"id":idText , "name":nameText},也可把url写成"GetDate.ashx?id="+idText+"&name="+nameText形式,而省略改参数,该post方法会自动对传进来的中文参数进行编码

(★注意:如果用$.get()则必须解决缓存问题,可加参数"t":new Date().getTime();还必须考虑编码问题,如果传入的参数value是中文,存到数据库会有乱码,因此必须进行二次转码,如"name":encodeURI(encodeURI(nameText)),然后在ashx中再对该参数值进行解码context.Server.UrlDecode(context.request["name"],因此推荐使用$.post())

calback:发送成功时回调函数,如上面的function(data,status){},回调函数中data(可省略)为服务器返回的数据,status(可省略)为服务器返回状态码status = "success"表示返回成功

 

/*
*创建时间:2012年 2月 16日  
*点击类别名称->内容变为文本框 (并且类别名称显示在文本框中)->修改文本框的内容之后->点击页面其他地方,类别名称修改为 修改后的值,同事更新数据库
*/
$(function(){       //相当于是给页面的body加上一个 onload事件

    $(".caname").click(function(){  //给页面上有caname的类别 加上一个 click 函数
    
    
    var objSPAN=$(this);  //这个时候的this   实际上是指 span
    
    //先获得点击的里面的文本内容是什么
    var oldcaname=$(this).text();
    
    //去掉空的字符
    oldcaname=$.trim(oldcaname)
    
    
    var input=$("<input type='text' value='"+oldcaname+"'>")    //把旧的值  转换为一个 jquery 对象
    
    
    $(this).html(input);                    //然后把旧的类别 放到一个文本框里面
    
       
       input.click(function(){              // 接下来  设置文本框的点击失效
 
            return false;
       });
       
                                        //设置一下 input 里面的文字的 的样式
       input.css({   "font-size":"14px"});        
       
                                        //在每一个匹配的元素上触发某类事件。
                                        //type (String) : 要触发的事件类型
       input.trigger("focus").trigger("select")
       
                                        //文本框失去焦点时,文本框 消失  caname里面的值  重新变为文字
       input.blur(function(){
            var newText=$(this).val();   //这里是this  因为是当 input 失去焦点的时候的方法,所以这个this是指 input
 
            if (oldcaname != newText)     //如果值有改变,那么就开始远程更新数据库 并且将原来的 更新为 最新的文版
            {
                
                //如果值有改变  那么开始 ajax
                
                //获取ID
                var caid=$.trim(objSPAN.parent().prev().text())
               //使用 jquery 的ajax 的get方法  需要对字符进行二次转码,并且要考虑 IE缓存的问题  ,并且在服务器的 ashx 页面 要进行解码
               // var url="../handler/ChangeCaName.ashx?caname="+ encodeURI(encodeURI(newText)) +"&caid="+caid+"&t="+new Date().getTime();            
               // $.get(url)
               
               $.post("../handler/ChangeCaName.ashx", { caname: newText, caid: caid },function(data){
                    if(data=="类别已经存在,修改失败")
                    {
                        alert(data);
                        objSPAN.html(oldcaname);
                    }
                    else
                    {
                        objSPAN.html(newText);
                    }
                });
                
                
                
            }
            else
            {
                objSPAN.html(oldcaname);
            }  
       })
       
       //我们要用 keydown 来 做这个功能,当编辑的时候,按回车 ,就也开始传到数据库进行修改
       input.keydown(function(){
       var jianzhi=event.keyCode;
       $("#test").html("你按下的键值是"+jianzhi);
            
       })
       
    })
   

      
});

   $(document).keydown(function(event){
  switch(event.keyCode) {
    case 13:return false;
  }
});
 

 

后台代码

<%@ WebHandler Language="C#" Class="ChangeCaName" %>

using System;
using System.Web;
using BLL;
using Model;

public class ChangeCaName : IHttpHandler {
    
    public void ProcessRequest (HttpContext context) {
        
        
        
        
        //context.Response.ContentType = "text/plain";

       // string caname = context.Server.UrlDecode(context.Request.QueryString["caname"]);  ////获取用 juqry的get方式传来的字符串,需要解码

        string caname = context.Request.Form["caname"];

        bool b = new CategoryManager().IsExists(caname);
        if (!b)
        {
            //开始修改类别
            string id = context.Request.Form["caid"];

            Category ca = new Category(id, caname);

            new CategoryManager().Update(ca);

            context.Response.Write("类别修改成功");

        }
        else
        {
            context.Response.Write("类别已经存在,修改失败");
        }
        
    }
 
    public bool IsReusable {
        get {
            return false;
        }
    }

}
posted @ 2012-02-29 09:42  asp_net老友记  阅读(343)  评论(0编辑  收藏  举报