var xhr = new XMLHttpRequest();
xhr.open('GET', 'send-ajax-data.php');
xhr.send(null);
xhr.onreadystatechange = function(){
var DONE = 4; // readyState 4 代表已向服务器发送请求
var OK = 200; // status 200 代表服务器返回成功
if(xhr.readyState === DONE){
if(xhr.status === OK){
console.log(xhr.responseText); // 这是返回的文本
} else{
console.log("Error: "+ xhr.status); // 在此次请求中发生的错误
}
}
}
// Ajax 方法
// 惰性载入创建 xhr 对象
function createXHR(){
if ( 'XMLHttpRequest' in window ){
createXHR = function(){
return new XMLHttpRequest();
};
} else if( 'ActiveXObject' in window ){
createXHR = function(){
return new ActiveXObject("Msxml2.XMLHTTP");
};
} else {
createXHR = function(){
throw new Error("Ajax is not supported by this browser");
};
}
return createXHR();
}
// Ajax 执行
function request(ajaxData){
var xhr = createXHR();
ajaxData.before && ajaxData.before();
// 通过事件来处理异步请求
xhr.onreadystatechange = function(){
if( xhr.readyState == 4 ){
if( xhr.status == 200 ){
if( ajaxData.dataType == 'json' ){
// 获取服务器返回的 json 对象
jsonStr = xhr.responseText;
json1 = eval('(' + jsonStr + ')'),
json2 = (new Function('return ' + jsonStr))();
ajaxData.callback(json2);
// ajaxData.callback(JSON.parse(xhr.responseText)); // 原生方法,IE6/7 不支持
} else
ajaxData.callback(xhr.responseText);
} else {
ajaxData.error && ajaxData.error(xhr.responseText);
}
}
};
// 设置请求参数
xhr.open(ajaxData.type, ajaxData.url);
if( ajaxData.noCache == true ) xhr.setRequestHeader('If-Modified-Since', '0');
if( ajaxData.data ){
xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
xhr.send( ajaxData.data );
} else {
? ?
xhr.setRequestHeader('X-Requested-With', 'XMLHttpRequest');
xhr.send( null );
}
return xhr;
}
function post(ajaxData){
ajaxData.type = 'POST';
var _result = request(ajaxData);
return _result;
}
function get(ajaxData){
ajaxData.type = 'GET';
ajaxData.data = null;
var _result = request(ajaxData);
return _result;
}
<!DOCTYPE HTML>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<title>原生 JavaScript 实现 Ajax</title>
<link rel="stylesheet" type="text/css" media="all" href="./common/common.css" />
<style>
#content {text-align: center; font-family: 'lucida Grande', 'Microsoft Yahei'}
#content .btn_ctr {display: block; width: 120px; height: 30px; margin: 0 auto 20px; background: #53a7bb; color: #fff; font-weight: bold; font-size: 14px; line-height: 30px; text-decoration: none;
border-radius: 4px;
}
#test {width: 280px; height: 130px; margin: 0 auto; padding: 15px; background: #fff; border-radius: 4px; text-align: left; }
</style>
</head>
<body>
<div id="header">
<div id="header-content">
<div id="header-inside">
<p class="go-to-article"><a href="http://kayosite.com/css3-animation.html" title="打开原文" target="_blank" >Back To Article</a></p>
<p class="go-to-blog"><a href="http://kayosite.com" title="进入我的博客 Kayo's Melody" target="_blank" >My Blog</a></p>
<p class="copyright">Demo By Kayo © Copyright 2011-2013</p>
</div>
<h1>CSS3 Animation</h1>
</div>
</div>
<div id="content">
<a class="btn_ctr" href="javascript:;" onclick="get({url: './ajax.html', callback: function(out){document.getElementById('test').innerHTML = out;}})">Ajax 获取内容</a>
<div id="test"></div>
</div>
<script>
// Ajax 方法,这里不在重复列出
</script>
</body>
</html>
<!DOCTYPE HTML> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>ajax</title> </head> <body> <p>成功获取到这段文本</p> </body> </html>
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有