这是w3c给出的解释:
提示:请注意 encodeURIComponent() 函数 与 encodeURI() 函数的区别之处,前者假定它的参数是 URI 的一部分(比如协议、主机名、路径或查询字符串)。因此 encodeURIComponent() 函数将转义用于分隔 URI 各个部分的标点符号。
这句话很能说明问题,encodeURIComponent()会比encodeURI() 多编码一些字符。
今天我用ajax post提交数据的时候,丢失了数据中的‘+’。
原来如果‘+’没有经过处理会解码为‘ ’(空格),而‘+’解码之后才是‘+’
必须要用encodeURIComponent(),用encodeURI()无法处理这些字符。
如果是post提交表单的或者用jQuery的serizlize()就不会出现这种问题。
PS:年轻的时候多踩踩坑
转载请注明原文地址: https://ju.6miu.com/read-676497.html