single.php のループ内に、カスタム クエリを介して返される現在のカテゴリの投稿をオプションとする select タグがあります。
選択したオプションを変更すると、うまく機能している多くの JavaScript 関数がありますが、それらの最後の関数 ( function f_next-previous
) が機能していないようです。
この関数の目的は、ページをリロードせずに前後のリンクを更新することです。
テンプレートのナビゲーション リンク (次と前) のコードは次のとおりです。
<div id="nav-above" class="navigation">
<div class="nav-previous"><?php previous_post_link( '%link', '<img height="34" src="' . get_bloginfo("template_directory") . '/images/previous.png" />' ); ?></div>
<div class="nav-next"><?php next_post_link( '%link', '<img height="34" src="' . get_bloginfo("template_directory") . '/images/next.png" />' ); ?></div>
</div><!-- #nav-above -->
この関数の JavaScript コードは次のとおりです。
function f_next-previous(id)
{
$.ajax({
cache: true,
type: "GET",
timeout: 5000,
url: 'wp-content/themes/twentyten/pages/next-previous.php?p='+id,
success: function(msg)
{
$('#nav-above').html(msg);
},
error: function(msg)
{
alert("Your browser broke!");
return false;
}
});
}
ファイルのnext-previous.php
内容は次のとおりです。
<?php
$p=$_GET['p'];
require( '../../../wp-load.php' );
$my_query = new WP_Query();
$my_query->query(array( 'post__in' => array($p)));
if ($my_query->have_posts()) : while ($my_query->have_posts()) : $my_query->the_post(); ?>
<div class="nav-previous"><?php previous_post_link( '%link', '<img height="34" src="' . get_bloginfo("template_directory") . '/images/previous.png" />' ); ?></div>
<div class="nav-next"><?php next_post_link( '%link', '<img height="34" src="' . get_bloginfo("template_directory") . '/images/next.png" />' ); ?></div>
<?php
endwhile;
endif;
?>
p パラメータに値を指定してこの php ファイルをテストすると、ブラウザに論理的な結果が表示されます。Jquery と関数のスクリプトは十分に含まれており、私の Web サイトのすべての AJAX は問題ありません。この作品に足りないもの????
更新: AJAX 呼び出しのトリガーを担当する私の single.php ファイルの部分は次のとおりです。
<form method="post" action="">
<select class="select2" name="" id="" >
<option value="<?php the_ID();?>"><?php the_title();?></option>
<?php
global $post;
$paged = get_query_var( 'paged' ) ? get_query_var( 'paged' ) : 1;
$myposts = get_posts("paged=$paged&category=4");
foreach($myposts as $post) :?>
<option value="<?php the_ID();?>"><?php the_title();?></option>
<?php endforeach;
wp_reset_postdata(); ?>
</select>
</form>