- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要创建以下 URL 来通过 jQuery 的 .ajax() 函数调用 API:
https://www.airnowapi.org/aq/forecast/zipCode/?format=application/json&zipCode=02144&date=2016-11-26&distance=25&API_KEY=API_KEY
我知道如何通过将字符串单独组合在一起来形成它,但这似乎是一个不必要的解决方法,并且不允许我使用 .ajax()
。我必须手动做很多这个函数应该为我做的工作。
问题在于这部分:format=application/json
,因为当我将其作为设置对象中的参数传递给.ajax()
时,它将斜杠转义为 %2F
,并且 API 不接受该请求。我也尝试过省略格式参数,但收到 500 服务器错误。如果我只是将其输入到网络浏览器中,则该请求可以完美运行,但如果此参数丢失或不包含斜杠(无法转义),则该请求将无法正常运行。我需要阻止 .ajax()
以这种方式对斜杠进行编码,或者在它到达 API 服务器之前以某种方式再次对其进行解码。
我已经在 Google 和 StackOverflow 上搜索过答案,但没有任何运气。我了解如何编码和解码转义字符,但我无法在我没有编写的 jQuery 函数中拦截它。除非我尝试根据 jQuery 源代码重写该函数,但这似乎是解决一个简单问题的一个大解决方法。作为引用,这是我的代码的相关部分:
function getData(query, callback) {
var settings = {
url: state.apis.airNow.BASE_URL,
dataType: 'json',
type: 'GET',
success: callback,
data: {
format: "application/json",
zipCode: query,
distance: 25,
API_KEY: state.apis.airNow.API_KEY
}
};
$.ajax(settings);
}
如何让 .ajax()
以 API 期望的确切形式提交 format=application/json
,或者我应该使用另一个类似的函数相反?
感谢您的帮助!
最佳答案
使用processData:false
并手动构造查询字符串。值得注意的是,我的 makeQS 函数不会处理当前状态下的嵌套对象或数组。除此之外唯一的选择是传递 url 上的参数或拦截 AJAX 请求并更改 URL
处理数据解决方案:
function makeQS(obj){
var params = [];
for(var key in obj){
params.push(key + '=' + obj[key]);
}
return params.join('&');
}
function getData(query, callback) {
var settings = {
url: state.apis.airNow.BASE_URL,
dataType: 'json',
type: 'GET',
success: callback,
processData: false,
data: makeQS({
format: "application/json",
zipCode: query,
distance: 25,
API_KEY: state.apis.airNow.API_KEY
})
};
$.ajax(settings);
}
如果您想通过 URL 传递它们,您可以将 settings.url 更改为如下内容:
settings.url = state.apis.airNow.BASE_URL + '?' + makeQS({
format: "application/json",
zipCode: query,
distance: 25,
API_KEY: state.apis.airNow.API_KEY
})
可能还值得注意的是,由于根本没有对参数进行编码,因此任何参数中的 & 和 = 之类的字符很可能会导致 API 端点出现意外行为,这也是像这样的端点的原因之一这通常应该采用 URI 编码的 GET 参数`
关于javascript - 如何通过 jQuery 的 .ajax() 方法在 GET 请求中发送包含斜杠的参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40825683/
我想了解 Ruby 方法 methods() 是如何工作的。 我尝试使用“ruby 方法”在 Google 上搜索,但这不是我需要的。 我也看过 ruby-doc.org,但我没有找到这种方法。
Test 方法 对指定的字符串执行一个正则表达式搜索,并返回一个 Boolean 值指示是否找到匹配的模式。 object.Test(string) 参数 object 必选项。总是一个
Replace 方法 替换在正则表达式查找中找到的文本。 object.Replace(string1, string2) 参数 object 必选项。总是一个 RegExp 对象的名称。
Raise 方法 生成运行时错误 object.Raise(number, source, description, helpfile, helpcontext) 参数 object 应为
Execute 方法 对指定的字符串执行正则表达式搜索。 object.Execute(string) 参数 object 必选项。总是一个 RegExp 对象的名称。 string
Clear 方法 清除 Err 对象的所有属性设置。 object.Clear object 应为 Err 对象的名称。 说明 在错误处理后,使用 Clear 显式地清除 Err 对象。此
CopyFile 方法 将一个或多个文件从某位置复制到另一位置。 object.CopyFile source, destination[, overwrite] 参数 object 必选
Copy 方法 将指定的文件或文件夹从某位置复制到另一位置。 object.Copy destination[, overwrite] 参数 object 必选项。应为 File 或 F
Close 方法 关闭打开的 TextStream 文件。 object.Close object 应为 TextStream 对象的名称。 说明 下面例子举例说明如何使用 Close 方
BuildPath 方法 向现有路径后添加名称。 object.BuildPath(path, name) 参数 object 必选项。应为 FileSystemObject 对象的名称
GetFolder 方法 返回与指定的路径中某文件夹相应的 Folder 对象。 object.GetFolder(folderspec) 参数 object 必选项。应为 FileSy
GetFileName 方法 返回指定路径(不是指定驱动器路径部分)的最后一个文件或文件夹。 object.GetFileName(pathspec) 参数 object 必选项。应为
GetFile 方法 返回与指定路径中某文件相应的 File 对象。 object.GetFile(filespec) 参数 object 必选项。应为 FileSystemObject
GetExtensionName 方法 返回字符串,该字符串包含路径最后一个组成部分的扩展名。 object.GetExtensionName(path) 参数 object 必选项。应
GetDriveName 方法 返回包含指定路径中驱动器名的字符串。 object.GetDriveName(path) 参数 object 必选项。应为 FileSystemObjec
GetDrive 方法 返回与指定的路径中驱动器相对应的 Drive 对象。 object.GetDrive drivespec 参数 object 必选项。应为 FileSystemO
GetBaseName 方法 返回字符串,其中包含文件的基本名 (不带扩展名), 或者提供的路径说明中的文件夹。 object.GetBaseName(path) 参数 object 必
GetAbsolutePathName 方法 从提供的指定路径中返回完整且含义明确的路径。 object.GetAbsolutePathName(pathspec) 参数 object
FolderExists 方法 如果指定的文件夹存在,则返回 True;否则返回 False。 object.FolderExists(folderspec) 参数 object 必选项
FileExists 方法 如果指定的文件存在返回 True;否则返回 False。 object.FileExists(filespec) 参数 object 必选项。应为 FileS
我是一名优秀的程序员,十分优秀!