Chrome说我正在使用非法的函数调用
Chrome says I am using illegal function invocation
我正在尝试编写一些涉及调用另一个函数的函数的Javascript代码。出于某种原因,我在Chrome开发工具中的第6行收到一条错误消息,上面写着"Uncaught TypeError:非法调用"。然而,函数getRequest似乎仍然在执行,并将"h"记录到控制台。这是怎么回事?
$(document).ready(function(){});
$(function(){
$('#search').click(function(event){
event.preventDefault();
var searchTerm = $('#query').val();
getRequest();
});
});
function getRequest(searchTerm){
console.log("h");
var params = {
part: 'snippet',
key: 'AIzaSyC7oHGfvlIMoEnboos6LZ2b2h_KpPu0u1Q',
q: $('#searchbox') //searchTerm
};
url = 'https://www.googleapis.com/youtube/v3/search';
$.getJSON(url, params, function(data){
showResults(data.Search);
//console.log("x");
});
}
您正在传递一个JQuery对象作为参数,而JQuery无法序列化它:
key: 'AIzaSyC7oHGfvlIMoEnboos6LZ2b2h_KpPu0u1Q',
q: $('#searchbox') //searchTerm
};
如果是输入,可以使用.val()
传递其值
key: 'AIzaSyC7oHGfvlIMoEnboos6LZ2b2h_KpPu0u1Q',
q: $('#searchbox').val() //searchTerm
};
或
只需使用您在方法中接收的参数(这就是您创建它的原因,不是吗?)
getRequest(searchTerm);
然后
key: 'AIzaSyC7oHGfvlIMoEnboos6LZ2b2h_KpPu0u1Q',
q: searchTerm
};
您的函数"getRequest"有一个"searchTerm"属性,您在调用函数时没有传递任何属性。
$(function(){
$('#search').click(function(event){
event.preventDefault();
var searchTerm = $('#query').val();
getRequest(); // Here is the problem
});
});
相关文章:
- 是否可以将一个函数输入连接到另一个函数调用的文本
- 在输入字段上有两个函数调用,一个在Blur上,一个不在Angular中
- 如何在Javascript函数调用中循环变量
- Javascript:应为赋值或函数调用,但实际看到的却是表达式
- 如何远程检查JavaScript应用程序的函数调用堆栈
- javascript函数调用不起作用
- 为什么这个函数调用会破坏程序并导致未定义的变量
- 如何通过函数调用设置图像的src
- 从全局函数调用Ember控制器上的方法
- 为什么Jquery$.ajax在函数调用中触发所有statusCode,即使调用成功
- JavaScript函数调用(arg1)(arg2)
- 打印链接时,将javascript函数调用到链接中
- 在函数调用中封装数据除了隐藏数据之外还有什么优点
- 无法从JavaScript中的函数调用对象属性
- 对中的函数调用进行排序是回调的唯一方法
- 函数调用方法有什么用
- Javascript:JSHint:应为赋值或函数调用,但实际看到的却是表达式
- Chrome说我正在使用非法的函数调用
- 为什么某些函数调用在 JavaScript 中被称为“非法调用”
- SyntaxError:函数调用中意外令牌非法