Javascript 从HTML文本输入到python脚本的数据传递
我正在使用Django创建一个web抓取应用程序,它抓取imdb网站,并根据用户在文本字段中键入的内容列出电影名称[假设用户键入“b”,它将列出以字母“b”开头的所有电影名称] 我有一个html文本输入和一个按钮Javascript 从HTML文本输入到python脚本的数据传递,javascript,jquery,python,ajax,django,Javascript,Jquery,Python,Ajax,Django,我正在使用Django创建一个web抓取应用程序,它抓取imdb网站,并根据用户在文本字段中键入的内容列出电影名称[假设用户键入“b”,它将列出以字母“b”开头的所有电影名称] 我有一个html文本输入和一个按钮 <body> <h1>The IMDB Scraper</h1> <form method="POST" action=""> <input type=&quo
<body>
<h1>The IMDB Scraper</h1>
<form method="POST" action="">
<input type="text" name="name" placeholder="Iron Man..">
<input type="submit" value="Search">
</form>
</body>
IMDB刮板
我还有一个python脚本,它使用硬编码关键字从网站上抓取数据
我想在按下按钮时将文本输入数据发送到此python脚本,并处理这些数据,然后将结果发送到同一HTML页面进行显示。是的,您可以轻松地执行此操作:
- 创建一个将
参数作为JSON获取的视图start
class MyJsonForAjaxView(generic.View):
def get(self, request, *args, **kwargs):
if my_scrape_is_finished:
return JsonResponse({'finished': True}, safe=False)
return JsonResponse({'finished': False}, safe=False)
- 使用POST方法在JavaScript(=AJAX调用)中调用该视图:
$.ajax({
method: 'post',
type: 'json',
cache: false,
url: 'my_json_url',
data: {'lat': your_lat, 'lgn': your_lgn}
}).done(function(data) {
alert('call successfull!!!');
/* data is filled with Django result, here {'finished': value} */
if (data.finished) {
/* handle finished */
} else {
/* do a small animation to show the user something is running */
}
/* todo: remember the call has been made and it s registered on Django side */
}).fail(function(data) {
alert('fatal error!');
}).always(function() {
/* whatever the result, always do something here */
});
您可以在后台执行此操作,禁用“发送”按钮,并在AJAX服务器中每隔3秒询问一次。到目前为止您尝试了什么?我已使用jQuery访问表单输入,当按下按钮时,现在,我想在访问文本输入之后立即运行一个python脚本,并在表单所在的页面上显示来自该脚本的响应。