【问题标题】:Populating second dropdown list depending on first one in a Wordpress page根据 Wordpress 页面中的第一个下拉列表填充第二个下拉列表
【发布时间】:2023-03-17 06:16:01
【问题描述】:

大家好,祝大家有个愉快的一天。 我不是真正的编码员,设法克服了基本 html 中的下拉列表问题,然后在 Dreamweaver 中使用 javascript 在 php 中。我什至使用 Ajax 实现了它而无需重新加载页面。感谢那些在 plus2net 中创建它的人。这是我从中受益的链接。 http://www.plus2net.com/php_tutorial/php_drop_down_list.php

我的问题在于 Wordpress 页面。 Wordpress 有一个内置函数,用于生成页面、帖子等的下拉列表。我使用了 wp_dropdown_pages 函数,其参考可以在这里找到:http://codex.wordpress.org/Function_Reference/wp_dropdown_pages

而在post-template.php文件中的功能是这样的:

function wp_dropdown_pages( $args = '' ) {
$defaults = array(
    'depth' => 0, 'child_of' => 0,
    'selected' => 0, 'echo' => 1,
    'name' => 'page_id', 'id' => '',
    'show_option_none' => '', 'show_option_no_change' => '',
    'option_none_value' => ''
);

$r = wp_parse_args( $args, $defaults );

$pages = get_pages( $r );
$output = '';
// Back-compat with old system where both id and name were based on $name    argument
if ( empty( $r['id'] ) ) {
    $r['id'] = $r['name'];
}

if ( ! empty( $pages ) ) {
    $output = "<select name='" . esc_attr( $r['name'] ) . "' id='" .  esc_attr( $r['id'] ) . "'>\n";
    if ( $r['show_option_no_change'] ) {
        $output .= "\t<option value=\"-1\">" . $r['show_option_no_change'] .  "</option>\n";
    }
    if ( $r['show_option_none'] ) {
        $output .= "\t<option value=\"" . esc_attr( $r['option_none_value']  ) . '">' . $r['show_option_none'] . "</option>\n";
    }
    $output .= walk_page_dropdown_tree( $pages, $r['depth'], $r );
    $output .= "</select>\n";
}

/**
 * Filter the HTML output of a list of pages as a drop down.
 *
 * @since 2.1.0
 *
 * @param string $output HTML output for drop down list of pages.
 */
$html = apply_filters( 'wp_dropdown_pages', $output );

if ( $r['echo'] ) {
    echo $html;
}
return $html;
}

使用这个函数及其参数,很容易填充下拉列表,并得到你想要的。但是,我的目标是使用第一个下拉列表的选定值生成第二个下拉列表。比如第一个是汽车品牌,第二个是车型。

为此,我如何使用 wp_dropdown_pages() 函数?如果必须,我如何使用 AJax 或仅使用 Javascript 来做到这一点?

提前谢谢大家。

【问题讨论】:

    标签: javascript php ajax wordpress html.dropdownlistfor


    【解决方案1】:

    一旦页面出现在屏幕上,您就不能使用 PHP,除非重新加载或 AJAX。

    您可以立即创建第二个下拉菜单并首先隐藏它们。然后在使用 jQuery 单击/更改第一个下拉菜单时使正确的菜单可见。

    或者使用 AJAX 调用返回正确的下拉菜单 HTML 的函数。

    更详细的:

    • 了解如何获取更改的信息 使用 jQuery 的下拉菜单(选择了一个选项)。
    • 了解如何在 WordPress 环境中使用 AJAX。创建要调用的 jQuery 将返回您的 HTML 的 PHP 函数。
    • 在您的 AJAX 调用中发送下拉菜单的抓取信息。
    • 在成功的 AJAX 函数上,您需要告诉 jQuery 回显输出。

    【讨论】:

    • 我注意到在这种情况下使用 Ajax 会很实用。但是我不知道如何实现它。我怎样才能设法获取选定索引的 id 并使用它来使用“child_of”参数填充第二个?
    猜你喜欢
    • 1970-01-01
    • 2013-12-06
    • 2012-01-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-05-06
    相关资源
    最近更新 更多