Задать вопрос
@redesupar

Как правильно сделать ajax запрос в wp?

Делаю ajax фильтр на вп
filter.js

jQuery( function( $ ){
	$( '#filter' ).submit(function(){
		var filter = $(this);
		$.ajax({
			url : true_obj.ajaxurl, // обработчик
			data : filter.serialize(), // данные
			type : 'POST', // тип запроса
			beforeSend : function( xhr ){
				filter.find( 'button' ).text( 'Загружаю...' ); // изменяем текст кнопки
			},
			success : function( data ){
				filter.find( 'button' ).text( 'Применить фильтр' ); // возвращаеи текст кнопки
				$( '#response' ).html(data);
			}
		});
		return false;
	});
});

functions.php дочерней темы
add_action( 'wp_enqueue_scripts', 'truemisha_jquery_scripts' );
 
function truemisha_jquery_scripts() {
 

 
	wp_register_script( 'filter', get_stylesheet_directory_uri() . '/js/filter.js', array( 'jquery' ), time(), true );
	wp_enqueue_script( 'filter' );
  wp_localize_script('truescript', 'true_obj', array('ajaxurl' => admin_url('admin-ajax.php')));
}
add_action( 'wp_ajax_myfilter', 'true_filter_function' ); 
add_action( 'wp_ajax_nopriv_myfilter', 'true_filter_function' );
 
function true_filter_function(){
 
	$args = array(
		'orderby' => 'date', // сортировка по дате у нас будет в любом случае (но вы можете изменить/доработать это)
		'order'	=> $_POST[ 'date' ] // ASC или DESC
	);
 
	// для таксономий
	if( isset( $_POST[ 'categoryfilter' ] ) )
		$args[ 'tax_query' ] = array(
			array(
				'taxonomy' => 'bwf_events_date',
				'field' => 'id',
				'terms' => $_POST[ 'categoryfilter' ]
			)
		);
	
 
	 
	query_posts( $args );
 
	if ( have_posts() ) {
      		while ( have_posts() ) : the_post();
			// тут вывод шаблона поста, например через get_template_part()
          		echo '<a href="' . get_permalink() . '">' . get_the_title() . '</a>';
		endwhile;
	} else {
		echo 'Ничего не найдено';
	}
 
	die();
}


вот так вывожу в шаблоне
<?
echo '<form action="" method="POST" id="filter">';
 
// категории
if( $terms = get_terms( array( 'taxonomy' => 'bwf_events_date', 'orderby' => 'name' ) ) ) { // как я уже говорил, для простоты возьму рубрики category, но get_terms() позволяет работать с любой таксономией
	echo '<select name="categoryfilter"><option>Выберите категорию...</option>';
	foreach ( $terms as $term ) {
		echo '<option value="' . $term->term_id . '">' . $term->name . '</option>'; // в качестве value я взял ID рубрики
	}
	echo '</select>';
}
 
 

 
echo '<button>Применить фильтр</button><input type="hidden" name="action" value="myfilter">
</form>';

?>
        <div id="response"></div>

и получаю ошибку
Uncaught ReferenceError: true_obj is not defined

в чем может быть проблема?
  • Вопрос задан
  • 285 просмотров
Подписаться 1 Простой 5 комментариев
Решения вопроса 1
GrinMorg
@GrinMorg
Если ответ помог, отметь решением
Вот так должно работать

Тут изменил url:
jQuery( function( $ ){
  $( '#filter' ).submit(function(){
    var filter = $(this);
    $.ajax({
      url : ajax_script.ajaxurl, // обработчик
      data : filter.serialize(), // данные
      type : 'POST', // тип запроса
      beforeSend : function( xhr ){
        filter.find( 'button' ).text( 'Загружаю...' ); // изменяем текст кнопки
      },
      success : function( data ){
        filter.find( 'button' ).text( 'Применить фильтр' ); // возвращаеи текст кнопки
        $( '#response' ).html(data);
      }
    });
    return false;
  });
});


А в functions.php - wp_localize_script
add_action( 'wp_enqueue_scripts', 'truemisha_jquery_scripts' );
 
function truemisha_jquery_scripts() {

  wp_register_script( 'filter', get_stylesheet_directory_uri() . '/js/filter.js', array( 'jquery' ), time(), true );
  wp_enqueue_script( 'filter' );
  wp_localize_script(
    'function',
    'ajax_script',
    array( 'ajaxurl' => admin_url( 'admin-ajax.php' ) ) );
}
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы