QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1858|回复: 0
打印 上一主题 下一主题

ajax对象常用属性,事件,方法大小写问题的总结

[复制链接]
字体大小: 正常 放大
拉克丝        

31

主题

9

听众

44

积分

升级  41.05%

  • TA的每日心情
    擦汗
    2015-4-30 14:17
  • 签到天数: 3 天

    [LV.2]偶尔看看I

    自我介绍
    德玛西亚
    跳转到指定楼层
    1#
    发表于 2015-4-16 16:14 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    最近发现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
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-5-27 02:59 , Processed in 0.464365 second(s), 54 queries .

    回顶部