- 在线时间
- 5 小时
- 最后登录
- 2015-5-13
- 注册时间
- 2015-4-8
- 听众数
- 9
- 收听数
- 0
- 能力
- 0 分
- 体力
- 96 点
- 威望
- 0 点
- 阅读权限
- 20
- 积分
- 44
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 31
- 主题
- 31
- 精华
- 0
- 分享
- 0
- 好友
- 2
升级   41.05% TA的每日心情 | 擦汗 2015-4-30 14:17 |
|---|
签到天数: 3 天 [LV.2]偶尔看看I
- 自我介绍
- 德玛西亚
 |
最近发现ajax版块好多问题都是属性,方法,事件大小写不区分,导致程序运行出问题,或者在不同浏览器下效果不出来或者出错。
+ e& \2 |/ ?! J, k7 u& y' p; O; W, p/ c: U& U' ~$ a$ H8 z' p% v
下面是ajax对象的一些常用属性,事件和方法4 k; _: k% y8 i4 j1 L1 b
1)标准的ajax对象的属性有readyState,status,responseText,responseXML6 u, w: g6 K4 z& ^0 M
: \' M$ u4 W( ]+ H- E! ?( f5 d7 M
2)非标准ajax对象属性,针对IE浏览器的,有responseBody,2进制数据流。如果不考虑浏览器兼容,这个属性+VBScript能很好的解决乱码问题。
: m" R$ h0 |" P$ Y! J9 ~[backcolor=white !important][size=1em]Visual Basic code: b" h& P/ Y" ^/ t% U: i! g
[color=white !important][size=1em] ? 9 m* T! v1 q9 y8 t: }
[size=1em]1 * g: H, f8 e: w7 A
[size=1em]2 $ R2 T/ d2 V7 y8 }* U
[size=1em]3 2 E0 b8 ~( c7 c9 [7 k# v9 f
[size=1em]4
4 x9 Z8 x- f; v) c[size=1em]5 " k% w4 K: b" N
[size=1em]6
. y- y" h, ]. L/ F. y, C/ F0 P[size=1em]7 . U! H: d/ Z$ G' T, h; T% Z$ M U
[size=1em]8 / x% L- R& o" W- e+ u; j
[size=1em]9 ' b+ P$ G3 j! B% c
[size=1em]10
6 e+ }- J" v/ Y* ^2 h[size=1em]11
! V0 D% ~: n* B* Z2 D# u+ r2 v1 r[size=1em]12
O9 ^# y2 J: n8 F[size=1em]13 , J. J: Y2 D6 L* J/ \* a
[size=1em]14
2 X+ p! j7 E- y2 Q0 f% R8 p1 h | [size=1em][size=1em]Function Bytes2BStr(vin)'二进制转字串
9 D! b, h0 i& o- C! B0 q[size=1em] strreturn = ""
0 P9 B3 r* A) C0 d u[size=1em] for i = 1 to lenb(vin); V% `' `6 k/ }" T, Z2 G
[size=1em] thischarcode = ascb(midb(vin,i,1))2 t" x: u M3 L7 s: B7 s1 q
[size=1em] if thischarcode < &h80 then
- Y! C- ]' \3 j" ^3 z* ~5 x; E[size=1em] strreturn = strreturn & chr(thischarcode)
t R" _8 w' L; c[size=1em] else
4 t4 f$ |* J3 V7 O- M[size=1em] nextcharcode = ascb(midb(vin,i+1,1))6 g1 {9 B; q8 V8 E* {% t9 R9 {
[size=1em] strreturn = strreturn & chr(clng(thischarcode) * &h100 + cint(nextcharcode)): D0 [4 \$ W7 `
[size=1em] i = i + 12 w* P1 Z! ~* Q, l, Q% f
[size=1em] end if* T; {+ k. b. R& c* M
[size=1em] next. ~6 H/ d2 }4 \- E6 e$ Q
[size=1em] Bytes2BStr = strreturn7 b; u0 Y) }) H& m1 l" Z' A
[size=1em]End Function
, N/ N/ z8 t+ u1 @/ V
7 ?, S# D8 Z9 y$ ?& k9 B |
! |5 j; J# U% \. e6 w- x
# F$ R; n; P v- A9 @, r. P; @/ j- U1 | Z
- n, U) [5 H& X# O# n& r
0 E; J4 `+ R2 f6 o( {9 k# h+ ` 3)事件onreadystatechange,状态转换函数
, H" C P1 O9 D2 U6 N! q6 v
$ Y1 F/ `- Y+ \ R- v9 e 4)方法有setRequestHeader,open,send,用于设置响应头的,当指定提交方法为POST的时候,需要设置content-type为application/x-www-form-urlencoded,如果未设置这个响应头,请求的动态页无法使用键值对的形式获取到值,不过可以从二进制流中生成提交的数据。
9 I- W: V5 p$ J& e+ J4 P参考, r, C) w6 f9 _# W- n
ajax指定为post但是未设置content-type或未指定键时时如何获取提交的内容
2 B6 d# x, f; L+ w) i8 d' d6 L n) Q
容易出现错误的问题
, G; V' K0 k6 q1 l1)对于使用XMLHttpRequest创建的对象,包括IE7+,属性是严格区分大小写的,一定要注意大小写的问题,要不不区分大小,属性值就是 undefined。如readyState写成readystate,responseText写成responsetext。
) w# Q9 }: ^0 s& |! R' L ~6 K" o4 s/ O" j1 D8 y& Y7 [
2)对于IE浏览器,如果是先判断activexobject,那么会执行activexobject创建xhr对象,使用acx创建的xhr对象,属性,事件,方法都不区分大小写
- c5 k" L5 e3 z" E, d4 r( _: i& t5 s# \
3)使用XMLHttpRequest创建时,onreadystatechange一定全部为小写,要不相当于给xhr对象赋值一个自定义属性,而不是实际的状态转换函数。这样永远都不执行回调。对于IE使用activexobject创建的xhr对象,不区分大小写
7 T; z' Z" n( m1 T# I
! T9 q0 s" K) n4)同2,3点,XMLHttpRequest创建时,调用方法一定要区分大小写,要不会出错,提示找不到方法。IE使用activexobject创建不会区分大小写。5 z0 ~7 `% e0 M& _4 H8 @) S: t
特别强调的是,一定要调用open方法后,才能执行setRequestHeader方法,要不会出错。
, f. N3 j' C- p: M/ a% d% m
* z1 A' l: H+ k* b9 P. j: I! T' y 对于手写ajax代码一些建议
4 c2 t6 W$ f( R( s. w1)为get提交时,不需要设置content-type了,除非请求的是一些需要检查content-type生成一些对应的数据格式的文件。如 asp.net的webservice会检查content-type,如果指定content-type为application/json,会生成对应的json格式的字符串。
- t3 F; E4 l* T参考webservice json8 c2 e" @( m% z) T! t3 r9 G1 F
% b8 X' y8 X; }0 U# m2)为get提交时,如果没有数据,调用send方法时最好添加一个null作为参数。xhr.send(null);1 a: D# E0 E9 j G0 i6 D2 @2 d, A
. [- w1 E# U/ Z# K. {$ i; \" _
3)为post提交时,一定不要忘记在调用open方法后,再调用setRequestHeader方法设置content-type为application/x-www-form-urlencoded
/ T3 P3 B7 X* S4 a$ L% K0 K1 f
: b4 v: ?( f& t! w1 ~" n4) 在使用responseText,responseXML和responseBody【IE only】,status属性时,需要在readyState==4,status状态==200【在线测试】或者status状态==0【本地测试】时再使用4 {5 L; ~" k8 g/ S+ a" S
0 b* |6 b, p9 H4 g5 V
[backcolor=white !important][size=1em]JavaScript code
" I- E) P2 R1 \" K: K7 s0 a# L[color=white !important][size=1em] ? 0 e. z; C+ ?, V1 y0 e
[size=1em]1
8 I$ P( `% @, Q) _' {[size=1em]2 ) n' j+ M, ?+ X; j7 [
[size=1em]3
- ], k8 Y! [" f) b[size=1em]4
: q# A$ u% c! T4 [[size=1em]5
6 k' c* v! v1 N: V# M: z5 x[size=1em]6 7 v5 R0 v7 q; I \ d+ n
[size=1em]7
6 j2 X% }) u& g; x+ }[size=1em]8 % |! O* Q# ]: j' A% ]) M: S6 x N
[size=1em]9 + l6 a3 N& _) z* v
[size=1em]10 4 j: x0 a) P* b, |
[size=1em]11 p# Y O0 b6 _
| [size=1em][size=1em] var xhr = window.XMLHttpRequest ? new XMLHttpRequest() : new ActiveXObject("microsft.xmlhttp");5 @+ P0 J8 {! ]
[size=1em] xhr.open('get', 'index.html', true);
, i1 d( c7 c4 ] Y1 Q! i. h1 d[size=1em] xhr.onreadystatechange = function () {
/ S, L1 U" R6 B8 a[size=1em] if (4 == xhr.readyState) {
2 X: d! b. C5 P; N+ V[size=1em] if (200 == xhr.status || 0 == xhr.status) {* u' }) m4 j1 I1 B/ o* n
[size=1em] //=========正常返回后的处理代码1 v$ E: z/ r5 _- F* z
[size=1em] }* i: V8 n8 m" E7 }5 M H
[size=1em] else alert('动态页出问题了~~');
# U l: u) ~, f; {" L" }5 `[size=1em] }
* a# b, ~ O- g v4 G* f[size=1em] }( \' ?7 s1 B5 [: L
[size=1em] xhr.send(null);
- h8 B% D7 j" D4 \
7 X# w; }4 h5 }6 a) J2 L9 a# m |
- S2 K- n& K+ g c/ ^" w, F% i2 C. y. `/ H
! k0 r6 r" i( n5 r8 i# V8 y. X4 \$ K k! z
0 p+ z. Z' H8 f- V) l: F" e4 T
5)如果为异步执行时,需要添加状态转换函数,然后在readyState位4时使用responseText或者responseXML属性。5 W' |- q. s" O$ p2 Z6 O9 Z
如果为同步执行时,可以在send完后,直接使用responseText或者responseXML属性,不需要添加onreadystatechange状态转换函数了。不过为同步时如果网速慢容易造成浏览器假死,用户体验不好。
' p" J3 H) t' @ |
zan
|