使用enter键AJAX API进行JQuery表单提交

时间:2014-02-11 11:57:44

标签: javascript php jquery mysql ajax

我尝试了各种解决方案,但没有一种适合我的特殊情况! 我怎样才能这样做,以便当用户按下'Enter'时,表单提交&搜索。 我还想尝试从HTML文档中删除JavaScript,并将其移动到ajax.js文档&选择它。 我不确定这样做的正确语法。 顺便说一句,我正在使用带有AJAX的烂番茄API。

的search.php

<form name="myform" action="" method="GET"><h3>Search for a movie here:</h3><br> 
    <input type="text" id="inputbox" value="">&nbsp;
    <input type="button" id="button" value="Go!" onClick="filmlist(this.form)">
        </form>

ajax.js

function filmlist (form) {
$('#films table').empty(); //removes previous search results before adding the new ones.

var apikey = "frceg2d5djxezaedgm3qq94h";
var baseUrl = "http://api.rottentomatoes.com/api/public/v1.0";
var moviesSearchUrl = baseUrl + '/movies.json?apikey=' + apikey;
var query = form.inputbox.value;  //uses the value from the input box as the query search



  // sends the query
  $.ajax({
    url: moviesSearchUrl + '&q=' + encodeURI(query),
    dataType: "jsonp",
    success: searchCallback
  });


// receives the results

function searchCallback(data) {
 $('#films table').append('Found ' + data.total + ' results for ' + query);
 var movies = data.movies;
 $.each(movies, function(index, movie) {
    $('#films table').append('<tr><td width="70" rowspan="2"><a href="' + movie.links.alternate +
    '" title="Click here to view film information for ' + movie.title + '."><img class="ajaximage" src="'
    + movie.posters.thumbnail + '" /></a></td><td class="ajaxfilmlisttitle"><h3><a href="' + movie.links.alternate +
    '" title="Click here to view film information for ' + movie.title + '.">' + movie.title + '</a></h3>Release year: '
    + movie.year + '</td></tr><tr><td class="ajaxfilmlistinfo">Audience Score: ' + movie.ratings.audience_score +
    '%<br>' + 'Cinema Release Date: ' + movie.release_dates.theater +
    '<br>Runtime: ' + movie.runtime + ' minutes</td></tr>');
 });
}
}

2 个答案:

答案 0 :(得分:0)

$("form").submit(function(){
    $.ajax({
        url: moviesSearchUrl + '&q=' + encodeURI(query),
        dataType: "jsonp",
        success: searchCallback
    });
    return false;
});

或者您可以在电影列表功能结束时return false

答案 1 :(得分:-1)

您可以使用以下jQuery代码检测#inputbox元素中的回车键:

$('#inputbox').keyup(function(e) 
{
    if(e.keyCode == 13) 
    {
        //do your stuff
    }
});

您还可以使用$('#inputbox').change()在用户输入时直接加载电影。

不要忘记某些旧版或移动版浏览器没有JavaScript支持。始终构建服务器端解决方案作为后备。