gpt4 book ai didi

使用 AJAX 的 WordPress 自定义元框输入值

转载 作者:行者123 更新时间:2023-12-03 23:05:41 24 4
gpt4 key购买 nike

我使用的是 Wordpress 3.5,我有一个带有元框和一些输入字段的自定义帖子 (sp_product)。其中一个输入 (sp_title)。

我想通过在我的输入(sp_title)字段中输入来按自定义帖子标题名称进行搜索,当我按下添加按钮(也在我的自定义元框中)时,它将通过该标题名称找到该帖子并带来一些将元数据发布到此元框中并显示到其他字段中。

enter image description here

在这张图片中(示例)

  1. 搜索
  2. 点击按钮
  3. 通过 AJAX 从自定义帖子中获取一些值(value)。

请给我一个示例代码(简单)

  1. 我将搜索一个简单的自定义帖子标题,
  2. 点击按钮
  3. 通过 AJAX (jQuery-AJAX) 获取该帖子的标题(我搜索或匹配的)以及任何其他帖子元值。

请帮助我。

最佳答案

我之所以能够找到线索,是因为我的一个插件使用了类似于重新附加图像的功能。
因此,相关的 Javascript 函数是 findPosts.open('action','find_posts')

它似乎没有很好的记录,我只能找到两篇关于它的文章:

尝试实现两个代码示例,模式窗口打开,但转储 -1 错误。这是因为 Ajax 调用没有传递函数 wp_ajax_find_posts 中的 check_ajax_referer .

所以,以下内容是基于第二篇文章的。但它有一个必须解决的安全漏洞,即 wp_nonce_field --> check_ajax_referer。代码注释中已注明。
要打开帖子选择器,请双击文本字段。
需要解决 jQuery Select 问题。

插件文件

add_action( 'load-post.php', 'enqueue_scripts_so_14416409' );
add_action( 'add_meta_boxes', 'add_custom_box_so_14416409' );
add_action( 'wp_ajax_find_posts', 'replace_default_ajax_so_14416409', 1 );

/* Scripts */
function enqueue_scripts_so_14416409() {
# Enqueue scripts
wp_enqueue_script( 'open-posts-scripts', plugins_url('open-posts.js', __FILE__), array('media', 'wp-ajax-response'), '0.1', true );

# Add the finder dialog box
add_action( 'admin_footer', 'find_posts_div', 99 );
}

/* Meta box create */
function add_custom_box_so_14416409()
{
add_meta_box(
'sectionid_so_14416409',
__( 'Select a Post' ),
'inner_custom_box_so_14416409',
'post'
);
}

/* Meta box content */
function inner_custom_box_so_14416409( $post )
{
?>
<form id="emc2pdc_form" method="post" action="">
<?php wp_nonce_field( 'find-posts', '_ajax_nonce', false); ?>
<input type="text" name="kc-find-post" id="kc-find-post" class="kc-find-post">
</form>
<?php
}

/* Ajax replacement - Verbatim copy from wp_ajax_find_posts() */
function replace_default_ajax_so_14416409()
{
global $wpdb;

// SECURITY BREACH
// check_ajax_referer( '_ajax_nonce' );

$post_types = get_post_types( array( 'public' => true ), 'objects' );
unset( $post_types['attachment'] );

$s = stripslashes( $_POST['ps'] );
$searchand = $search = '';
$args = array(
'post_type' => array_keys( $post_types ),
'post_status' => 'any',
'posts_per_page' => 50,
);
if ( '' !== $s )
$args['s'] = $s;

$posts = get_posts( $args );

if ( ! $posts )
wp_die( __('No items found.') );

$html = '<table class="widefat" cellspacing="0"><thead><tr><th class="found-radio"><br /></th><th>'.__('Title').'</th><th class="no-break">'.__('Type').'</th><th class="no-break">'.__('Date').'</th><th class="no-break">'.__('Status').'</th></tr></thead><tbody>';
foreach ( $posts as $post ) {
$title = trim( $post->post_title ) ? $post->post_title : __( '(no title)' );

switch ( $post->post_status ) {
case 'publish' :
case 'private' :
$stat = __('Published');
break;
case 'future' :
$stat = __('Scheduled');
break;
case 'pending' :
$stat = __('Pending Review');
break;
case 'draft' :
$stat = __('Draft');
break;
}

if ( '0000-00-00 00:00:00' == $post->post_date ) {
$time = '';
} else {
/* translators: date format in table columns, see http://php.net/date */
$time = mysql2date(__('Y/m/d'), $post->post_date);
}

$html .= '<tr class="found-posts"><td class="found-radio"><input type="radio" id="found-'.$post->ID.'" name="found_post_id" value="' . esc_attr($post->ID) . '"></td>';
$html .= '<td><label for="found-'.$post->ID.'">' . esc_html( $title ) . '</label></td><td class="no-break">' . esc_html( $post_types[$post->post_type]->labels->singular_name ) . '</td><td class="no-break">'.esc_html( $time ) . '</td><td class="no-break">' . esc_html( $stat ). ' </td></tr>' . "\n\n";
}

$html .= '</tbody></table>';

$x = new WP_Ajax_Response();
$x->add( array(
'data' => $html
));
$x->send();
}

Javascript文件open-posts.js

jQuery(document).ready(function($) {
// Find posts
var $findBox = $('#find-posts'),
$found = $('#find-posts-response'),
$findBoxSubmit = $('#find-posts-submit');

// Open
$('input.kc-find-post').live('dblclick', function() {
$findBox.data('kcTarget', $(this));
findPosts.open();
});

// Insert
$findBoxSubmit.click(function(e) {
e.preventDefault();

// Be nice!
if ( !$findBox.data('kcTarget') )
return;

var $selected = $found.find('input:checked');
if ( !$selected.length )
return false;

var $target = $findBox.data('kcTarget'),
current = $target.val(),
current = current === '' ? [] : current.split(','),
newID = $selected.val();

if ( $.inArray(newID, current) < 0 ) {
current.push(newID);
$target.val( current.join(',') );
}
});

// Double click on the radios
$('input[name="found_post_id"]', $findBox).live('dblclick', function() {
$findBoxSubmit.trigger('click');
});

// Close
$( '#find-posts-close' ).click(function() {
$findBox.removeData('kcTarget');
});
});

关于使用 AJAX 的 WordPress 自定义元框输入值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14416409/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com