【发布时间】: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