onclick填充输入框与文本

时间:2013-10-13 06:41:25

标签: javascript jquery

我几乎从this Stackoverflow question/answer复制并粘贴了它,似乎不想在我的页面上工作。我也尝试创建一个空白的PHP页面来尝试它,但它仍然不起作用。

我在标题中包含的jQuery库也是Google的库之一,也是jQuery的官方库:http://code.jquery.com/jquery-latest.min.js

它必须是编码或其他东西,因为代码在我的浏览器JSFiddle上运行良好: http://jsfiddle.net/kn3Qu/


这是我个人使用的代码:

<input id="dam" type="text" />

<div id="dam_return">
    <a href="#">DLH Victoria</a>
    <a href="#">DLH Sam</a>
    <a href="#">Studly</a>
</div>

和Javascript:

$('#dam_return a').click(function() {
    var value = $(this).html();
    var input = $('#dam');
    input.val(value);
    return false;
});

如果有人能帮助我,那就太棒了!

编辑:我认为我的问题是因为每次在“dam”输入上按下键时都会发生SQL查询。

以下是发生的EXACT SQL查询:

<div id="dam_return_search"><a href="#">Maybe this one works? (but no, it doesn't)</a><br />
<?php

$connect = // blahblahaa

if (isset($_GET['dam_text'])) {
    getSuggest($text);
}

function getSuggest($text) {

    $dam = $_GET['dam_text'];

    $sqlCommand = "SELECT `name` FROM `alpacas1` WHERE `name` LIKE '%$dam%'";

    $query = mysql_query($sqlCommand);

    $result_count = mysql_num_rows($query);

    while ($row = mysql_fetch_assoc($query)) {
        echo '<a href=#>'.$row['name'].'</a><br />';
    }

}

?>
</div>

这是DAM输入框和与之关联的代码:

<script type="text/javascript">
function suggest1() {
    var dam_text = document.getElementById('dam').value;

    if (window.XMLHttpRequest) {
        xmlhttp = new XMLHttpRequest();
    } else {
        xmlhttp = new ActiveXObject('MicrosoftXMLHTTP');
    }
    xmlhttp.onreadystatechange = function() {
        if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
            document.getElementById('dam_return').innerHTML = xmlhttp.responseText;
        }
    }
    var target = 'dam_search.php?dam_text=' + dam_text;
    xmlhttp.open('GET', target, true);
    xmlhttp.send();
}
</script>


<script type="text/javascript">
$(document).ready(function(){
    $("#dam_return_search a").click(function(){
        var value = $(this).html();
        var input = $('#dam');
        input.val(value);
    });
});
</script>


<tr>
  <td id="label">Dam:</td> 
  <td id="option">
    <input type="text" name="dam" id="dam" value="<?php echo "$dam"; ?>" onkeyup="suggest1();"><br />
    <div id="dam_return"></div>
  </td>
</tr>

3 个答案:

答案 0 :(得分:2)

在启动.click()事件侦听器之前,您需要完全加载页面的DOM。您可以使用$(document).ready()

执行此操作

以下是JSFiddle

<script type="text/javascript" src="jquery.min.js"></script>
<script type="text/javascript">
$(document).ready(function(){
    $("#dam_return a").click(function(){
        var value = $(this).html();
        var input = $('#dam');
        input.val(value);
    });
});
</script>

<input id="dam" type="text" />

<div id="dam_return">
    <a href="#" class="test">DLH Victoria</a>
    <a href="#" class="test">DLH Sam</a>
    <a href="#" class="test">Studly</a>
</div>

答案 1 :(得分:1)

我认为您应该考虑使用此代码,坦率地说我认为您不应该使用.html() jquery方法来获取文本,您应该使用text()方法,我试过这段代码离线和在线,它的工作原理

请使用preventDefault()方法停止事件,而不是返回false

$(document).ready(function () {
    $('.tags_select a').click(function(evt) {
        var value = $(this).text();
        var input = $('#text_tag_input');
        input.val(input.val() + value);
        evt.preventDefault();
    });
});

你也可以阅读return false和preventDefault()here

之间的区别

答案 2 :(得分:0)

而不是在初始文件中使用Javascript更改输入框“dam”我更改了它,以便dam_search.php文件将其更改为“onclick”。

这是我的代码:

<div id="dam_return_search"><a href="#">Maybe this one works? (but no, it doesn't)</a><br />
<?php

$connect = // blahblahaa

if (isset($_GET['dam_text'])) {
    getSuggest($text);
}

function getSuggest($text) {

    $dam = $_GET['dam_text'];

    $sqlCommand = "SELECT `name` FROM `alpacas1` WHERE `name` LIKE '%$dam%'";

    $query = mysql_query($sqlCommand);

    $result_count = mysql_num_rows($query);

    while ($row = mysql_fetch_assoc($query)) {
        echo '<a href=#>'.$row['name'].'</a><br />';
    }

}

?>
</div>

以下是我将其更改为:

<?php

$connect = // blahblahaa

if (isset($_GET['dam_text'])) {
    getSuggest($text);
}

function getSuggest($text) {

    $dam = $_GET['dam_text'];

    $sqlCommand = "SELECT `name` FROM `alpacas1` WHERE `name` LIKE '%$dam%'";

    $query = mysql_query($sqlCommand);

    $result_count = mysql_num_rows($query);

    while ($row = mysql_fetch_assoc($query)) {
    echo '<a href=# onclick="document.getElementById(\'dam\').value=\''.$row['name'].'\';">'.$row['name'].'</a><br />';
    }

}

?>
</div>