我有一个班级,其中包含用户搜索功能:
PHP:
private function searchUsers() {
if (isset($_REQUEST['term'])) {
$params = array( ':searchQ' => $_REQUEST['term'] . '%' );
$sql = "SELECT distinct username as suggest, user_id
FROM login_users
WHERE username LIKE :searchQ
OR name LIKE :searchQ
OR user_id LIKE :searchQ
ORDER BY username
LIMIT 0, 5";
$stmt = parent::query($sql, $params);
if ( $stmt->rowCount() > 0 ) {
while($suggest = $stmt->fetch(PDO::FETCH_ASSOC)) {
$data[] = array(
'label' => $suggest['name'] . '(' . $suggest['user_id'] . ')',
'value' => $suggest['user_id']
);
}
echo json_encode($data);
flush();
exit();
}
}
}
在另一页上:
JS:
<script>
$(function () {
jQuery.ajaxSetup({
beforeSend: function() {
$('#loader').show();
},
complete: function(){
$('#loader').hide();
},
success: function() {}
});
$('#search-input').autocomplete({
source:'classes/add_user.class.php',
minLength:3,
select: function(event, ui) {
AutoCompleteSelectHandler(event, ui)
}
});
function AutoCompleteSelectHandler(event, ui) {
var selectedObj = ui.item;
window.location.href = 'users.php?uid=' + selectedObj.value;
}
});
/* Disable autocomplete */
var flag = 1;
function disAutoComplete(obj){
if(flag){
obj.setAttribute("autocomplete","off");
flag = 0;
}
obj.focus();
}
</script>
HTML:
<form method="post" id="search-users-form" action="classes/add_user.class.php" class="pull-right">
<div class="control-group">
<div class="controls">
<div class="input-prepend">
<button id="add_new_user_btn" class="btn"><?php _e('Add new user'); ?></button>
<input type="number" class="input-mini" min="0" id="showUsers" name="showUsers" placeholder="<?php _e('Show'); ?>" value="<?php echo !empty($_SESSION['jigowatt']['users_page_limit']) ? $_SESSION['jigowatt']['users_page_limit'] : 10; ?>">
<span class="add-on">
<label for="search-input"><a href="#" data-rel="tooltip-bottom" title="<?php _e('Search by Username, Name, or ID!'); ?>"><i class="icon-search"></i></a></label>
</span>
<input name="search-input" type="text" style="margin:0" class="span2" id="search-input" onclick="disAutoComplete(this);" placeholder="<?php _e('User search'); ?>">
<!--
<input class="span2" style="margin:0" id="username-search" type="text" name="searchUsers" placeholder="<?php _e('User search'); ?>">
-->
</div>
</div>
</div>
</form>
通常情况下,我会在控制器php页面上拥有php逻辑,然后选择isset。但是我必须将该函数放入一个类才能访问parent::query
函数。使用jquery autcomplete,我如何访问此函数,和/或我必须进行哪些修改才能使该术语起作用?
答案 0 :(得分:1)
在 add_user.class.php 中,您应该call
function
喜欢,
if (isset($_REQUEST['term'])) {
$classObj->searchUsers($_REQUEST['term']);//$classObj of your class
}
// your class
private function searchUsers($term='') {
$params = array( ':searchQ' => $term . '%' );
$sql = "SELECT distinct username as suggest, user_id
FROM login_users
WHERE username LIKE :searchQ
OR name LIKE :searchQ
OR user_id LIKE :searchQ
ORDER BY username
LIMIT 0, 5";
$stmt = parent::query($sql, $params);
if ( $stmt->rowCount() > 0 ) {
while($suggest = $stmt->fetch(PDO::FETCH_ASSOC)) {
$data[] = array(
'label' => $suggest['name'] . '(' . $suggest['user_id'] . ')',
'value' => $suggest['user_id']
);
}
echo json_encode($data);
flush();
exit();
}
}