您如何在通过append或 AJAX 加载的内容上运行 jQuery?我已经尝试过.live,.on但我所做的一切似乎都不起作用,而且我发现的大多数东西都是针对已删除的.live.
我正在尝试进行实时搜索,但我有它用于输入,您可以在页面上添加任意数量的这些输入。
JavaScript
$(document).ready(function() {
// ================================ live material search ============================ //
var obj;
//$('input[rel="m-live"]').focus(function(){
$('input[rel="m-live"]').on('focus',function(){
    if($(this).attr('name') == obj){} else { $('#live-search-result').html(""); }
    obj = $(this).attr('name');
    //if($(this).val !== null){ str = "t=s&v=" + $(this).val(); ajax(str); }
    var offset = $(this).offset(),
        height = $(this).height() + 10;
    offset.top = offset.top + height;
    $('#live-search-result').show();
    $('#live-search-result').css({"left":offset.left ,"top":offset.top})
});
$('input[rel="m-live"]').focusout(function(){
    $('#live-search-result').hide();
});
$('input[rel="m-live"]').keyup(function(){
    var str = "t=s&v=" + $(this).val();
    ajax(str);
});
function ajax (str) {
  $.ajax({
        url: '/esystem/pages/ajax/material.php',
        type: 'post',
        dataType: 'text',
        data: str,
        success: function(data)
        {
            $('#live-search-result').html(data);
        }
    });
}
});
附加代码:
function Add(){
$('#material-list').append("<div class='material'><div class='input'>" + 
    "<input type='text' rel='m-live' name='mat-"+curMat+"' placeholder='Material' />" +
    "<div class='logo'><i class='icon-inbox'></i></div></div> <div class='input'>" + 
    "<input type='text' rel='m-price' name='mat-p-"+curMat+"' placeholder='price 0.00' />" +
    "<div class='logo'><i class='smaller icon-gbp'></i></div></div></div>"
);
}
function Remove(){
$('#material-list .material:last-child').remove();
}
我已经.on进去了,但不适用于附加的输入。
旁注:空白输入的默认值是什么?正如您在代码中看到的那样,如果输入在焦点上不是空白,我试图再次运行 AJAX,但它会运行任何东西。
然后我希望能够在带有 ajaxed 内容的实时搜索框上运行 jQuery,以便在点击时自动填充名称和价格。
PHP 代码
<?php
include '../../core/php/config.php';
$n = $_POST['v'];
$t = $_POST['t'];
if(!empty($n) && $t == "s"){
    //$sql = "SELECT * FROM _materials WHERE name LIKE '$n'";
    $sql = "SELECT * FROM _materials";
    foreach ($dbh->query($sql) as $row){
        if (strpos($row['name'], $n) !== FALSE){
            echo $row['name'] .' - £'. $row['price'] . '<br />';
        }
        else{
            //echo "not found";
        }
    }
}
?>