javascript - Javascript 和 AJAX 问题 - 选择表单的事件监听器在更改时不起作用?

标签 javascript ajax forms xmlhttprequest addeventlistener

我对 javascript 相当陌生,我正在构建一个基本网站,人们可以通过一个小型汽车数据库进行搜索,该网站会在用户选择搜索条件时更新搜索结果。

我尝试通过在 html 中创建一个表单来实现此目的,其中包含多个选择(代码 1),以及带有用于选择的事件监听器的 JavaScript,以及通过 PHP 文件搜索数据库的 ajax(代码 2)。

代码 1 - HTML

<div class="intro">
        <p>Enter your search criteria:</p>

            <div id="formbox">
                <form>
                    <!-- MAKE SELECTION -->
                    <select name="make" id="selectmake">
                    <option value="test">Car Make:</option>
                    <option value="Aston Martin">Aston Martin</option>
                    <option value="Ford">Ford</option>
                    <option value="Lotus">Lotus</option>
                    <option value="Vauxhall">Vauxhall</option>
                    </select>&emsp;

                    <!-- MODEL SELECTION -->
                    <select name="model" id="selectmodel">
                    <option value="">Car Model:</option>
                    <option value="DB9 Coupe">DB9 Coupe</option>
                    <option value="Vanquish">Vanquish</option>
                    <option value="Fiesta Hatchback">Fiesta Hatchback</option>
                    <option value="Focus Hatchback">Focus Hatchback</option>
                    <option value="Mondeo Estate">Mondeo Estate</option>
                    <option value="Elise">Elise</option>
                    <option value="Exige">Exige</option>
                    <option value="Astra Hatchback">Astra Hatchback</option>
                    <option value="Corsa D">Corsa D</option>
                    <option value="Frontera 4x4">Frontera 4x4</option>
                    </select>&emsp;

                    <!-- YEAR SELECTION -->
                    <select name="year" id="selectyear">
                    <option value="">Car Year:</option>
                    <option value="1998">1998</option>
                    <option value="2000">2000</option>
                    <option value="2001">2001</option>
                    <option value="2004">2004</option>
                    <option value="2007">2007</option>
                    <option value="2009">2009</option>
                    <option value="2010">2010</option>
                    </select>&emsp;

                    <!-- CC SELECTION -->
                    <select name="cc" id="selectcc">
                    <option value="">Car CC:</option>
                    <option value="1250">1250</option>
                    <option value="1400">1400</option>
                    <option value="1600">1600</option>
                    <option value="1800">1800</option>
                    <option value="2000">2000</option>
                    <option value="3200">3200</option>
                    <option value="5900">5900</option>
                    <option value="6000">6000</option>
                    </select>&emsp;

                    <!-- COLOUR SELECTION -->
                    <select name="colour" id="selectcolour">
                    <option value="">Car Colour:</option>
                    <option value="Black">Black</option>
                    <option value="Blue">Blue</option>
                    <option value="Red">Red</option>
                    <option value="Silver">Silver</option>
                    </select>&emsp;

                    <!-- RESET SELECTIONS -->
                    <input type="reset" />
                </form>
            </div>
        </div>

        <!-- SEARCH RESULTS -->
        <div id="results">
            Your results will be displayed here
        </div>

代码 2 - JavaScript 文件

function initialise() {
//assign selection fields to variables
var i=0;
var make=document.getElementById("selectmake");
make.addEventListener('change', setmake(this.value), false);
var model=document.getElementById("selectmodel");
model.addEventListener('change', setmodel(this.value), false);
var year=document.getElementById("selectyear");
year.addEventListener('change', setyear(this.value), false);
var cc=document.getElementById("selectcc");
cc.addEventListener('change', setcc(this.value), false);
var colour=document.getElementById("selectcolour");
colour.addEventListener('change', setcolour(this.value), false);

//assign results area to a variable
var results=document.getElementById("results");

//setting search criteria to return all results by default
var makesearch="make=make";
var modelsearch="model=model";
var yearsearch="year=year";
var ccsearch="cc=cc";
var coloursearch="colour=colour";
results.innerHTML="initiate works";

//function to set the search to search make if set to an existent value
function setmake (makevar) {
    i=i+1;
    results.innerHTML=i;
    if (makevar.length>0) {
        makesearch="make='"+makevar+"'";
        results.innerHTML="EVENTIFFUNCTIONworks";
        constructsearch();
    }
}

function constructsearch() {
    var searchstring="WHERE "+makesearch+" AND "+modelsearch+" AND "+yearsearch+" AND "+ccsearch+" AND "+coloursearch;
    results.innerHTML="construct works";
    sendsearch(searchstring);
}
}

//function to update search results
function sendsearch(searchstring) {
//update search results with an XMLHttpRequest
if (window.XMLHttpRequest) {
  // code for IE7+, Firefox, Chrome, Opera, Safari
  xmlhttp=new XMLHttpRequest();
}
else {
  // code for IE6, IE5
  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}

xmlhttp.onreadystatechange=function() {
  if (xmlhttp.readyState==4 && xmlhttp.status==200) {
    document.getElementById("results").innerHTML="XMLworks";
    //xmlhttp.responseText;
  }
}

xmlhttp.open("GET","results.php?search="+searchstring,true);
xmlhttp.send();
}

window.onload=initialise;

变量“i”已创建,其所有用途都是为了测试...我最初确实有这样的工作,当页面加载时,结果 div 将显示“i”变量,但它没有当在“make”选择框中做出新选择时发生更改。

由于某种原因,我的代码现在根本无法工作,它甚至不会显示“启动工作”

非常感谢任何帮助,并提前致谢。

最佳答案

addEventListener 将函数作为第二个参数,因为您没有传递函数而是调用函数。您可以使用匿名函数表达式来包装对 addEventListener 的调用中的代码。对于每个对 addEventListener 的调用,请执行以下操作

make.addEventListener('change', function(){
    setmake(this.value)
}, false);

关于javascript - Javascript 和 AJAX 问题 - 选择表单的事件监听器在更改时不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14178296/

相关文章:

php - 提交表单后保留文本区域内容

javascript - 如何改进这个包含基本重复逻辑的 toggleClass 函数?

javascript - 为计时器添加开始、停止、重置按钮

javascript - 从 SCEditor 获取值

javascript - jQuery - 将 html 响应加载到整个页面

jquery - 使用 jQuery ajax 时如何向用户显示 JSON HTTP 422 响应?

typescript - 如何允许 `null` 作为 Yup 模式中的默认值,同时仍然不允许提交 `null`?

javascript - 在 JavaScript 中缓存对象

javascript - 克隆循环问题

javascript - 如何从水平方向设置 html 的 Tab 键顺序?