Во-первых, это очень ограниченно в рамках WPSE, это вообще.
Помимо шорткода для запуска исходного вывода HTML, это действительно просто AJAX.
Во всяком случае, как говорится, вот как это делается:
PHP
Предполагая, что приведенный выше фрагмент PHP работает, поместите в файл php следующее для вызова ajax:
/wp-content/themes/%your_theme%/js/ajax-load-quote.php
<?php
/* uncomment the below, if you want to use native WP functions in this file */
// require_once('../../../../wp-load.php');
$array = file( $_POST['file_path'] ); // file path in $_POST, as from the js
$r = rand( 0, count($array) - 1 );
return '<p>' . $array[$r] . '</p>';
?>
Для дальнейшего использования и для того, чтобы сделать этот ответ полезным для других: обратите внимание, что его wp-load.php
необходимо включить, чтобы использовать встроенную функциональность WordPress. Наиболее распространенным случаем, скорее всего, является необходимость WP_Query
или $wpdb
.
Структура HTML
В содержимом страницы, виджете или файле шаблона:
<div id="randomquotes">
<p>I would rather have my ignorance than another man’s knowledge,
because I have so much more of it.<br />
-- Mark Twain, American author & Playwright</p>
</div>
<a id="newquote" class="button" href="#" title="Gimme a new one!">New Quote</a>
Это вы, очевидно, можете настроить по своему вкусу, но ради этого примера, это то, что мы собираемся сделать.
Мы сгенерируем выше через шорткод позже.
JQuery
/wp-content/themes/%your_theme%/js/ajax-load-quote.js
function ajaxQuote() {
var theQuote = jQuery.ajax({
type: 'POST',
url: ajaxParams.themeURI+'js/ajax-load-quote.php',
/* supplying the file path to the ajax loaded php as a $_POST variable */
data: { file_path: ajaxParams.filePath },
beforeSend: function() {
ajaxLoadingScreen(true,'#randomquotes');
},
success: function(data) {
jQuery('#randomquotes').find('p').remove();
jQuery('#randomquotes').prepend(data);
},
complete: function() {
ajaxLoadingScreen(false,'#randomquotes');
}
});
return theQuote;
}
/* Loading screen to be displayed during the process, optional */
function ajaxLoadingScreen(switchOn,element) {
/* show loading screen */
if (switchOn) {
jQuery(''+element).css({
'position': 'relative'
});
var appendHTML = '<div class="ajax-loading-screen appended">
<img src="'+ajaxParams.themeURI+'images/ajax-loader.gif"
alt="Loading ..." width="16" height="16" /></div>';
if( jQuery(''+element).children('.ajax-loading-screen').length === 0 ) {
jQuery(''+element).append(appendHTML);
}
jQuery(''+element).children('.ajax-loading-screen').first().css({
'display': 'block',
'visibility': 'visible',
'filter': 'alpha(opacity=100)',
'-ms-filter': '"progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"',
'opacity': '1'
});
} else {
/* hide the loading screen */
jQuery(''+element).children('.ajax-loading-screen').css({
'display': '',
'visibility': '',
'filter': '',
'-ms-filter': '',
'opacity': ''
});
jQuery(''+element).css({
'position': ''
});
}
}
/* triggering the above via the click event */
jQuery('#newquotes').click( function() {
var theQuote = ajaxQuote();
return false;
});
Собираем это вместе в functions.php
Ниже приведенного выше фрагмента (который вы найдете включенным в измененный ниже) вставьте следующее:
function random_quote( $atts ) {
/* extracts the value of shortcode argument path */
extract( shortcode_atts( array(
'path' => get_template_directory_uri() . '/quotes.txt' // default, if not set
), $atts ) );
$array = file( $path );
$r = rand( 0, count($array) - 1 );
$output = '<div id="randomquotes">' .
'<p>' . $array[$r] . '</p>' .
'</div>' .
'<a id="newquote" class="button" href="#" title="Gimme a new one!">New Quote</a>';
/* enqueue the below registered script, if needed */
wp_enqueue_script( 'ajax-quote' );
/* supplying the file path to the script */
wp_localize_script(
'ajax-quote',
'ajaxParams',
array(
'filePath' => $path,
'themeURI' => get_template_directory_uri() . '/'
)
);
return $output;
}
add_shortcode( 'randomquotes', 'random_quote');
/* register the js */
function wpse72974_load_scripts() {
if ( ! is_admin() ) {
wp_register_script(
'ajax-quote',
get_template_directory_uri() . '/js/ajax-load-quote.js',
array( 'jquery' ),
'1.0',
true
);
}
}
add_action ( 'init', 'wpse72974_load_scripts' );
Дополнительно: CSS для экрана загрузки
.ajax-loading-screen {
display: none;
visibility: hidden;
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
width: 100%;
background: #ffffff; /* the background of your site or the container of the quote */
filter: alpha(opacity=0);
-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
opacity: 0;
-webkit-transition: opacity .1s;
-moz-transition: opacity .1s;
-ms-transition: opacity .1s;
-o-transition: opacity .1s;
transition: opacity .1s;
z-index: 9999;
}
.ajax-loading-screen img {
position: absolute;
top: 50%;
left: 50%;
margin: -8px 0 0 -8px;
}
Ресурсы / Чтение
function random_quote ($path) { $ array = file ("$ path");
<br/> ...[randomquote file = "http://exampe.com/file.txt"]
<br/> Так это будет работать? Я не слишком разбираюсь в программировании.[randomquotes path="path/to/file.txt"]
, передается в js, а оттуда в скрипт php.Вы можете зарегистрировать скрипт в шорткоде. Он будет напечатан в нижнем колонтитуле, учитывая, что тема содержит
wp_footer()
.Как это работает:
add_shortcode()
.admin_url( 'admin-ajax.php' )
и получить новые данные. Вставьте возвращенные данные в элемент с шорткодом.Вот пример сценария, который делает это. Два файла: класс PHP и файл JavaScript. Например, оба должны находиться в одном каталоге
ajax-shortcode-demo
.ajax-shortcode-demo.php
jquery-ajax-demo.js
Результат в блоге:
источник
define('WP_DEBUG', true);
в моем WP-config.php это решение генерируется сообщение об ошибке:Strict Standards: call_user_func_array() expects parameter 1 to be a valid callback, non-static method Ajax_Shortcode_Demo::get_instance() should not be called statically in /var/www/.../public_html/wp-includes/plugin.php on line 496
. Это критично? Я немного изменил это: wordpress.stackexchange.com/q/196332/25187static
. Я внес изменения в свой пост для этого. Спасибо за уведомление. Я бы больше не писал такой код. :)