我有一个带有课程名称的下拉列表(例如'php','c','c#'...)。
我还放置了一个onchange事件,以便我可以检查下拉菜单中的选项是否有效(在数据库中找到)-这似乎很愚蠢,因为我自己将这些值放在我的下拉列表中数据库,但是我这样做是为了防止SQL注入。

问题是我没有收到来自verifycourse.php的回复……所以这是我做错的事情。

function.js

function complete() {
    $.post("verifycourse/domain", {
        domain: $('#domain').val().toLowerCase()
    }).done(function (returnValue) {
        alert('after post'); //it does not alert
        var result = jQuery.parseJSON(returnValue);
        if (result['returnValue'] == 'ok') {
            alert('good domain');
        }
        else if (result['returnValue'] == 'wrong') {
            alert('wrong domain');
        }
    });
}


verifycourse.php

function index($param = 1)
  {
    parent::__construct();
    $this->load->model('user','',TRUE);
    $this->load->library( 'mysmarty' );
    $smarty = new Mysmarty ;

    if (isset($param) && $param == 'domain') {
        $this->isValidCourse($this->input->post('domain'));
    }
  }

    function isValidCourse($courseName)
    {
        $query = $this->db->get('admins');

        $arr = $this->user->getDomains($courseName);
        if(in_array($courseName, $arr))
            return json_encode(array('returnValue' => 'ok'));
        return json_encode(array('returnValue' => 'wrong'));
    }


user.php

function getDomains()
    {
        $query = $this->db->get('admins');

        $arr = array();
        foreach ($query->result() as $row) {
            if ($row->subject && !(in_array($row->subject, $arr)))
                $arr[] = $row->subject;
        }

        return $arr;
    }


home_view.tpl

<div class="modal-body">
                <form class="contact" name="contact">
                    <font color="red"><div id="errors"></div></font>
                    <input type="text" class="input-block-level" id="courseName" placeholder="Course name" name="courseName"/>
                    <br/>
                    <select class="input-block-level" id="domain" placeholder="Domain name" name="domain" onchange="complete();">
                      {foreach from=$myArray item=foo}
                          <option value="foo">{$foo}</option>
                      {/foreach}
                    </select>
                </form>
            </div>

最佳答案

将您的$.post更改为$.ajax以便捕获其他错误,如下所示:

$.ajax({
    type: "POST",
    url: "verifycourse/domain",
    data: {domain: $('#domain').val().toLowerCase()},
    success: function(msg){
        alert(  msg );
    },
    error: function(XMLHttpRequest, textStatus, error) {
        alert("some error");
        console.log(XMLHttpRequest);
        console.log(textStatus);
        console.log(error);
   }
});

09-18 08:55