css自学框架之ajax获取提交数据

本小结主要自学了ajax,页面部分刷新,实现动态提交数据到服务器;动态从服务区获取数据。get,post两种传递数据方法,Json、html、text、xml等多种数据格式。

展示效果如下图:

一、Javascript代码,具体代码如下:

javascript 复制代码
ajax:function(prop){
			if(!prop.url) prop.url = document.location.
			href;
			if(!prop.method) prop.method = "GET";
			if(prop.method === "POST"){
				var data = new FormData();
				for(var d in prop.data){
				    data.append(d, prop.data[d]);
				}
			}
			else if(prop.method === "GET"){
			    var url = prop.url + "?";			
			    for(var d in prop.data){
			        url += d + "=" + prop.data[d] + "&";
			    }			
			    prop.url = url.substr(0, url.length - 1);
			}
			var request = new XMLHttpRequest();
			request.open(prop.method, prop.url);
			if(prop.crossDomain){ request.setRequestHeader("X-Requested-With", "XMLHttpRequest"); }
			//X-Requested-With请求头用于在服务器端判断request来自Ajax请求还是传统请求。两种请求在请求的Header不同,Ajax 异步请求比传统的同步请求多了一个头参数			
			if(prop.header){
			    for(var i in prop.header){
			        request.setRequestHeader(prop.header[i][0], prop.header[i][1]);
			    }
			}			
			request.send(data);
			request.onreadystatechange = function () {				
			    if(request.readyState === 4){
					// 0:请求未初始化,即尚未调用open()方法。
					// 1:服务器连接已建立,但是尚未发送请求。open()方法已经调用了。
					// 2:请求已接收,但是尚未开始处理。send()方法已经调用了,并且头部和状态已经可获得。
					// 3:请求处理中,通常响应体部分已经被接收。
					// 4:请求已完成,且响应已就绪。此时可以获取响应数据。
			        if(request.status === 200 || request.status === 304){
						//200------提交成功;304状态码是对客户端有缓存情况下服务端的一种响应
			            if(prop.type){
			                switch(prop.type){
			                    case "text": prop.success(request.responseText); break;
			                    case "json": prop.success(JSON.parse(request.response)); break;
			                }
			            }
			            else{
			                prop.success ? prop.success(request) : console.log(prop.method + " 请求发送成功");
			            }
			        }
			        else{
			            prop.failed ? prop.failed(request) : console.log(prop.method + " 请求发送失败");
			        }
			
			        request = null;
			    }
			};			
			return request;
		}

二、Html调用ajax的方法,具体代码如下:

html 复制代码
<div class="mythBox mid" id="ajax">
		<br/>
		<button class="btn red" id="btnget">获取数据</button>
		<button class="btn blue" id="btnpost">提交数据</button>
		<div id="resultbox"></div>
	</div>	
		<script type="text/javascript">		
			myth('#btnget').click(function(){
				myth('').ajax({
					method: "GET",
					    data: {
					        id: "newid"
					    },
					    url: "http://www.yuanziyu.com",
					    success: function (req){
							myth('#resultbox').html("================"+req.responseText);				       
					    },
					    failed: function (req){
					        console.log("失败了");
					        console.log(req); // 返回的 XHR 对象
					    }
				});	
			});
			
			myth('#btnpost').click(function(){
				myth('').ajax({
					method: "POST",
					    data: {
					        id: "newid"
					    },
					    url: "http://www.yuanziyu.com",
					    success: function (req){
							//myth('#resultbox').html("================"+req.responseText);				       
					    },
					    failed: function (req){
					        console.log("失败了");
					        console.log(req); // 返回的 XHR 对象
					    }
				});	
			});
					
		</script>

这部分依然是两部分代码,一部分是Html代码,页面展示连个按钮,一个是Get获取数据,一个市Post提交数据;另一部分是Javascript,ajax调用获取服务器数据。

三、代码下载

源代码下载:请单击

相关推荐
小彭努力中1 小时前
194.Vue3 + OpenLayers 实战:动态位置 + 高度 + 角度,模拟卫星地面覆盖范围
前端·css·vue.js·openlayers·animate
Luna-player7 小时前
Vue 组件,用来实现一个响应式图标网格布局,核心是用 CSS 实现固定宽高比的正方形容器,并在里面放置图片和文字。
前端·css·vue.js
96778 小时前
AJAX和Axios理解和关系
前端·ajax·okhttp
Greg_Zhong9 小时前
Css知识之伪类和伪元素
前端·css
余瑜鱼鱼鱼10 小时前
css常用功能总结(三)(Chrome 调试工具 -- 查看 CSS 属性)
前端·css·chrome
Dxy123931021610 小时前
HTML常用CSS样式推荐:打造高效、美观的网页设计
前端·css·html
Predestination王瀞潞10 小时前
6.5.1 软件->W3C HTML5、CSS3标准(W3C Recommendation):CSS(Cascading Style Sheet)
css·css3·html5
xiaotao13120 小时前
什么是 Tailwind CSS
前端·css·css3
xiaotao1311 天前
03. 原子化 CSS 思想
前端·css·tailwind
爱宇阳1 天前
Nuxt4 + Tailwind CSS v4 自定义响应式断点完整指南
前端·css·nuxt4