JavaScripthttpput请求参数如何设置?

JavaScript016

JavaScripthttpput请求参数如何设置?,第1张

//使用

var url="http://lu.sohu.com/send/luport/get_psd.php?phone="+MobileNo.innerText

//alert(url)

send_request("GET",url,null,"TEXT",processTextResponse)

//定义XMLHttpRequest对象实例

var http_request = false

//定义可复用的http请求发送函数

function send_request(method,url,content,responseType,callback)

{//初始化、指定处理函数、发送请求的函数

http_request = false

//开始初始化XMLHttpRequest对象

if(window.XMLHttpRequest)

{ //Mozilla 浏览器

http_request = new XMLHttpRequest()

if (http_request.overrideMimeType)

{//设置MiME类别

http_request.overrideMimeType("text/xml")

}

}

else if (window.ActiveXObject)

{ // IE浏览器

try {

http_request = new ActiveXObject("Msxml2.XMLHTTP")

} catch (e) {

try {

http_request = new ActiveXObject("Microsoft.XMLHTTP")

} catch (e) {}

}

}

if (!http_request)

{ // 异常,创建对象实例失败

window.alert("不能创建XMLHttpRequest对象实例.")

return false

}

if(responseType.toLowerCase()=="text")

{

//http_request.onreadystatechange = processTextResponse

http_request.onreadystatechange = callback

}

else if(responseType.toLowerCase()=="xml")

{

//http_request.onreadystatechange = processXMLResponse

http_request.onreadystatechange = callback

window.alert("响应类别参数错误。")

return false

}

// 确定发送请求的方式和URL以及是否异步执行下段代码

if(method.toLowerCase()=="get")

{

http_request.open(method, url, true)

}

else if(method.toLowerCase()=="post")

{

http_request.open(method, url, true)

http_request.setRequestHeader("Content-Type","application/x-www-form-urlencoded")

http_request.setRequestHeader("Accept-Language","zh-cn")

}

else

{

window.alert("http请求类别参数错误。")

return false

}

http_request.send(content)

}

// 处理返回文本格式信息的函数

function processTextResponse()

{

var element = document.getElementById("main")

if (http_request.readyState == 4)

{

if (http_request.status == 200)

{

//alert(http_request.responseText)

var p = http_request.responseText

var errtd = document.getElementById("errtd")

errtd.innerHTML =""

errtd.style.display = ""

var returnstr = p.split("|")

errtd.innerHTML = returnstr[1]

//errtd.innerHTML = p

//if(p=="true"){

// //alert(p)

// var errtd = document.getElementById("errtd")

// errtd.innerHTML =""

// errtd.style.display = ""

// errtd.innerHTML = "已成功提交了您的订购,稍后您的手机会收到短信,请回复“好”完成订购"

//}else{

// //alert(p)

// var errtd = document.getElementById("errtd")

// errtd.innerHTML =""

// errtd.style.display = ""

// errtd.innerHTML = "您所在的地区没有上线"

//}

} else

{

alert("您所请求的页面有异常。")

}

}

else

{

//timervar p = document.getElementById("progress")

//p.innerText = "完成"

}

}

举个简单例子,希望你能明白,

1、下面输出结果是"jim",而不是"tom",

是因为数组中保存的都是指向json对象a的地址,

dd[0],dd[1],dd[2],dd[3]对象指向的内存地址相同,

当修改其中一个dd[0]的属性值的时候,数组所有元素指向的对象属性值都改变了。

var dd = []

var a = { "cname": "tom" }

for (var i = 0 i <4 i++) {

    dd[i] =a

}

dd[0].cname = "jim"

alert(dd[2].cname)

2、下面输出结果是0,而不是1,

是因为数组元素dd[0],dd[1],dd[2],dd[3]对应的内存地址都不同,互不干扰。

var dd = []

var a = 0

for (var i = 0 i <4 i++) {

    dd[i] =a

}

dd[0]=1

alert(dd[2])

希望对你有帮助!