javascript版本的ajax發送請求
(1)、創建XMLHttpRequest對象,這個對象就是ajax請求的核心,是ajax請求和響應的信息載體,單是不同瀏覽器創建方式不同
(2)、請求路徑
(3)、使用open方法綁定發送請求
(4)、使用send() 方法發送請求
(5)、取得伺服器回傳的字串 xmlhttpRequest.responseText;
(6)、取得服務端回傳的值,以xml物件的形式儲存 xmlhttpRequest.responseXML;
(7)、使用W3C DOM節點樹方法和屬性對此XML文件物件進行檢查和解析。
序言:
最近隨著專案的上線實施,稍微有點空閒,閒暇之時偶然發現之前寫的關於javascript原生xmlHttp ajax方法以及後來jquery插件ajax方法,於是就行了一些總結,因時間原因,並未在所有瀏覽器上進行測試,目前測試的IE8,9,10,Google Chrome,Mozilla Firefox,Opera常用幾款,如大家在進行驗證測試發現有問題,請及時回饋與我,謝謝大家。
言歸正傳,直接上代碼:
前端程式碼
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>Ajax练习</title> <script src="/Scripts/jquery-1.4.1.min.js" type="text/javascript"></script> <style type="text/css"> label{width:50px;display:inline-block;} </style> </head> <body> <div id="contentDiv"> <h2 id="html-表单元素">html5表单元素</h2> <label>E-mail</label><input type="email" name="UserEmail" id="UserEmail" value="251608027@qq.com" /><br /> <label>URL:</label><input type="url" name="UserURL" id="UserURL" value="http://www.baidu.com" /><br /> <label>Number:</label><input type="number" name="UserNumber" id="UserNumber" min="1" max="100" value="87" /><br /> <label>Range:</label><input type="range" name="UserRange" min="1" max="100" value="78" /><br /> <label>Date:</label><input type="date" name="UserDate" id="UserDate" value="2015-12-01" /><br /> <label>Search:</label><input type="search" name="UserSearch" id="UserSearch" value="search" /><br /> <label id="lblMsg" style="color:Red; width:100%;"></label><br /> <input type="button" id="btnXmlHttp" value="提 交" onclick="return xmlPost();" /> <input type="button" id="btnAjax" value="Ajax提 交" onclick="return Ajax();" /> <input type="button" id="btnPost" value="Post提 交" onclick="return Post();" /> <input type="button" id="btnGet" value="Get提 交" onclick="return Get();" /> <input type="button" id="btnGetJSON" value="GetJSON提 交" onclick="return GetJSON();" /> <input type="button" id="btnCustom" value="Custom提 交" onclick="return Custom();" /> <br /><label id="lblAD" style="color:Red; width:100%;">.NET技术交流群:70895254,欢迎大家</label> <script type="text/javascript"> //基础数据 var jsonData = { UserEmail: $("#UserEmail").val(), UserURL: $("#UserURL").val(), UserNumber: $("#UserNumber").val(), UserRange: $("#UserRange").val(), UserDate: $("#UserDate").val(), UserSearch: $("#UserSearch").val() }; //统一返回结果处理 function Data(data, type) { if (data && data.length > 0) { var lblMsg = ""; for (i = 0; i < data.length; i++) { for (var j in data[i]) { lblMsg += j + ":" + data[i][j]; if (j != "Name" && j != "UserSearch") { lblMsg += "," } } if (i != data.length) { lblMsg += ";"; } } $("#lblMsg").html(type + "请求成功,返回结果:" + lblMsg); } } </script> <script type="text/javascript"> //javascript 原生ajax方法 function createXMLHttp() { var XmlHttp; if (window.ActiveXObject) { var arr = ["MSXML2.XMLHttp.6.0", "MSXML2.XMLHttp.5.0", "MSXML2.XMLHttp.4.0", "MSXML2.XMLHttp.3.0", "MSXML2.XMLHttp", "Microsoft.XMLHttp"]; for (var i = 0; i < arr.length; i++) { try { XmlHttp = new ActiveXObject(arr[i]); return XmlHttp; } catch (error) { } } } else { try { XmlHttp = new XMLHttpRequest(); return XmlHttp; } catch (otherError) { } } } function xmlPost() { var xmlHttp = createXMLHttp(); var queryStr = "Ajax_Type=Email&jsonData=" + JSON.stringify(jsonData); var url = "/Handler/AjaxHandlerHelper.ashx?no.=" + Math.random(); xmlHttp.open('Post', url, true); xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); xmlHttp.send(queryStr); xmlHttp.onreadystatechange = function () { if (xmlHttp.readyState == 4 && xmlHttp.status == 200) { var data = eval(xmlHttp.responseText); Data(data, "javascript原生xmlHttp"); } } } </script> <script type="text/javascript"> //jquery $.ajax方法 function Ajax() { $.ajax({ url: "/Handler/AjaxHandlerHelper.ashx?no.=" + Math.random(), type: "Post", async: false, data: { Ajax_Type: "Email", jsonData: JSON.stringify(jsonData) }, dataType: "json", beforeSend: function () { //发送请求前 $("#btnPost").attr('disabled', "true"); }, complete: function () { //发送请求完成后 $("#btnPost").removeAttr("disabled"); }, error: function (XMLHttpRequest, textStatus, errorThrown) { alert("error!" + errorThrown); //alert("请求错误,请重试!"); }, success: function (data) { Data(data, "Jquery $.ajax"); } }); } //jquery $.post方法 function Post() { $.post("/Handler/AjaxHandlerHelper.ashx?no.=" + Math.random(), { Ajax_Type: "Email", jsonData: JSON.stringify(jsonData) }, function (data) { Data(data, "Jquery $.post"); } ); } //jquery $.getJSON方法 function GetJSON() { $.getJSON("/Handler/AjaxHandlerHelper.ashx?no.=" + Math.random(), { Ajax_Type: "Email", jsonData: JSON.stringify(jsonData) }, function (data) { Data(data, "Jquery $.getJSON"); } ); } //jquery $.get方法 function Get() { $.get("/Handler/AjaxHandlerHelper.ashx?no.=" + Math.random(), { Ajax_Type: "Email", jsonData: JSON.stringify(jsonData) }, function (data) { Data(data, "Jquery $.get"); } ); } </script> <script type="text/javascript"> //javascript原生脚本自定义jquery $.ajax方法 var CustomAjax = function (custom) { // 初始化 var type = custom.type; //type参数,可选 var url = custom.url; //url参数,必填 var data = custom.data; //data参数可选,只有在post请求时需要 var dataType = custom.dataType; //datatype参数可选 var success = custom.success; //回调函数可选 var beforeSend = custom.beforeSend; //回调函数可选 var complete = custom.complete; //回调函数可选 var error = custom.error; //回调函数可选 if (type == null) {//type参数可选,默认为get type = "get"; } if (dataType == null) {//dataType参数可选,默认为text dataType = "text"; } var xmlHttp = createXMLHttp(); // 创建ajax引擎对象 xmlHttp.open(type, url, true); // 打开 // 发送 if (type == "GET" || type == "get" || type == "Get") {//大小写 xmlHttp.send(null); } else if (type == "POST" || type == "post" || type == "Post") { xmlHttp.setRequestHeader("content-type", "application/x-www-form-urlencoded"); xmlHttp.send(data); } xmlHttp.onreadystatechange = function () { if (xmlHttp.readyState == 4 && xmlHttp.status == 200) { if (dataType == "text" || dataType == "TEXT") { if (success != null) { //普通文本 success(xmlHttp.responseText); } } else if (dataType == "xml" || dataType == "XML") { if (success != null) { //接收xml文档 success(xmlHttp.responseXML); } } else if (dataType == "json" || dataType == "JSON") { if (success != null) { //将json字符串转换为js对象 success(eval("(" + xmlHttp.responseText + ")")); } } } }; }; //自定义方法 function Custom() { CustomAjax({ type: "Post", url: "/Handler/AjaxHandlerHelper.ashx?no.=" + Math.random(), data: "Ajax_Type=Email&jsonData=" + JSON.stringify(jsonData), dataType: "json", success: function (data) { Data(data, "Custom自定义"); } }); } </script> </div> </body> </html>
.ashx後端程式碼
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Script.Serialization; using System.Runtime.Serialization.Json; using System.IO; using System.Text; namespace WebHTML5.Handler { /// <summary> /// AjaxHandlerHelper 的摘要说明 /// </summary> public class AjaxHandlerHelper : IHttpHandler { public void ProcessRequest(HttpContext context) { context.Response.ContentType = "application/json"; //context.Response.Charset = "utf-8"; var Ajax_Type = context.Request.QueryString["Ajax_Type"] == null ? context.Request.Form["Ajax_Type"] : context.Request.QueryString["Ajax_Type"]; switch (Ajax_Type) { case "Email": context.Response.Write(PostEmail(context)); break; default: context.Response.Write("[{\"Age\":28,\"Name\":\"张鹏飞\"}]"); break; } } public static string PostEmail(HttpContext context) { string semail = string.Empty; if (context.Request.HttpMethod == "GET") { semail = "[" + context.Request.QueryString["jsonData"] + "]"; } else { semail = "[" + context.Request.Form["jsonData"] + "]"; } return semail; } /// <summary> /// JSON序列化 /// </summary> public static string JsonSerializer<T>(T t) { DataContractJsonSerializer ser = new DataContractJsonSerializer(typeof(T)); MemoryStream ms = new MemoryStream(); ser.WriteObject(ms, t); string jsonString = Encoding.UTF8.GetString(ms.ToArray()); ms.Close(); return jsonString; } /// <summary> /// JSON反序列化 /// </summary> public static T JsonDeserialize<T>(string jsonString) { DataContractJsonSerializer ser = new DataContractJsonSerializer(typeof(T)); MemoryStream ms = new MemoryStream(Encoding.UTF8.GetBytes(jsonString)); T obj = (T)ser.ReadObject(ms); return obj; } public bool IsReusable { get { return false; } } } }
Jquery 方法擴充
關於Jquery的方法擴充大家自行google或百度;
結束語
說明一下狀況:案例中出現的html5 range標籤的值問題,寫的不對,大家不要在意這些,關於range標籤如何取值大家自行google或百度;

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

本教程向您展示瞭如何將自定義的Google搜索API集成到您的博客或網站中,提供了比標準WordPress主題搜索功能更精緻的搜索體驗。 令人驚訝的是簡單!您將能夠將搜索限制為Y

本文系列在2017年中期進行了最新信息和新示例。 在此JSON示例中,我們將研究如何使用JSON格式將簡單值存儲在文件中。 使用鍵值對符號,我們可以存儲任何類型的

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

增強您的代碼演示文稿:10個語法熒光筆針對開發人員在您的網站或博客上共享代碼段的開發人員是開發人員的常見實踐。 選擇合適的語法熒光筆可以顯著提高可讀性和視覺吸引力。 t

利用輕鬆的網頁佈局:8 ESTISSEL插件jQuery大大簡化了網頁佈局。 本文重點介紹了簡化該過程的八個功能強大的JQuery插件,對於手動網站創建特別有用

核心要點 JavaScript 中的 this 通常指代“擁有”該方法的對象,但具體取決於函數的調用方式。 沒有當前對象時,this 指代全局對象。在 Web 瀏覽器中,它由 window 表示。 調用函數時,this 保持全局對象;但調用對象構造函數或其任何方法時,this 指代對象的實例。 可以使用 call()、apply() 和 bind() 等方法更改 this 的上下文。這些方法使用給定的 this 值和參數調用函數。 JavaScript 是一門優秀的編程語言。幾年前,這句話可

本文介紹了關於JavaScript和JQuery模型視圖控制器(MVC)框架的10多個教程的精選選擇,非常適合在新的一年中提高您的網絡開發技能。 這些教程涵蓋了來自Foundatio的一系列主題


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

WebStorm Mac版
好用的JavaScript開發工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!