jQuery UI自动完成功能无法在WordPress定制器中使用

时间:2018-03-01 11:04:29

标签: jquery wordpress

我很难在WordPress定制器中使用jQuery UI自动完成功能。

我构建了以下自定义控件以将其集成到WordPress定制器。

<?php

namespace MailOptin\Core\Admin\Customizer\CustomControls;

use WP_Customize_Control;

class WP_Customize_Autocomplete_Input_Control extends WP_Customize_Control
{
    public $type = 'mailoptin_autocomplete';

    public $field_id = 'mo-autocomplete';

    public $options = [];

    public $input_type = 'text';

    public $sub_description;

    public function enqueue()
    {
        wp_enqueue_script(
            'mailoptin-autocomplete-init',
            MAILOPTIN_ASSETS_URL . 'js/customizer-controls/autocomplete-init.js',
            array('jquery', 'customize-base', 'jquery-ui-core', 'jquery-ui-widget', 'jquery-ui-autocomplete'),
            false,
            true
        );
    }

    public function render_content()
    {
        ?>
        <div>
            <label>
                <?php if (!empty($this->label)) : ?>
                    <span class="customize-control-title"><?php echo esc_html($this->label); ?></span>
                <?php endif;
                if (!empty($this->description)) : ?>
                    <span class="description customize-control-description"><?php echo $this->description; ?></span>
                <?php endif; ?>
                <input id="<?php echo $this->field_id; ?>" class="mo-autocomplete" value="<?php echo esc_attr($this->value()); ?>" <?php $this->link(); ?> />
                <?php if (!empty($this->sub_description)) : ?>
                    <span class="description customize-control-description"><?php echo $this->sub_description; ?></span>
                <?php endif; ?>
            </label>
        </div>
        <?php
    }
}

以下是自定义控件的附带JS文件

wp.customize.controlConstructor['mailoptin_autocomplete'] = wp.customize.Control.extend({
    ready: function () {
        var control = this;

        jQuery( function() {
            var availableTags = [
                "ActionScript",
                "AppleScript",
                "Asp",
                "BASIC",
                "C",
                "C++",
                "Clojure",
                "COBOL",
                "ColdFusion",
                "Erlang",
                "Fortran",
                "Groovy",
                "Haskell",
                "Java",
                "JavaScript",
                "Lisp",
                "Perl",
                "PHP",
                "Python",
                "Ruby",
                "Scala",
                "Scheme"
            ];
            jQuery( ".mo-autocomplete" ).autocomplete({
                source: availableTags
            });
        } );
    }
});

但它不起作用。

假设我在字段中输入“PHP”,标记会更改为下面的代码,但它不起作用。没有显示建议的下拉列表。

<input class="mo-autocomplete ui-autocomplete-input" value="" data-customize-setting-link="mo_optin_campaign[98][subscriber_tag]" autocomplete="off">

1 个答案:

答案 0 :(得分:0)

在Wordpress中使用jQuery UI有一些简单的方法。

  

首先将此行添加到主题或子主题中的function.php中:

function theme_enqueue_scripts()
{
    // Enqueue jQuery UI and autocomplete
    wp_enqueue_script('jquery-ui-core');
    wp_enqueue_script('jquery-ui-autocomplete');
}

add_action('wp_enqueue_scripts', 'theme_enqueue_scripts');
  

Seconde制作要使用的字符串列表,在同一文件夹中创建名为&#34; list.php&#34; 的新文件   并将下面的代码与您的数据放在一起(我在这里有一些存储在php数组 associative 中的一些海港的名称,地址和位置):

    <?php
    $ports=array(
    array(
        'country' => 'Albania',
        'port' => 'Durres (Durazzo)',
        'code' => 'AL DRZ',
        'lat/long' => "41° 19' N / 19° 28' E"
    ),
    array(
        'country' => 'Albania',
        'port' => 'Sarande',
        'code' => 'AL SAR',
        'lat/long' => "39° 53' N / 20° 0' E"
    ),
    array(
        'country' => 'Albania',
        'port' => 'Shengjjin',
        'code' => 'AL SHG',
        'lat/long' => "41° 49' N / 19° 36' E"
    ),
    array(
        'country' => 'Albania',
        'port' => 'Vlore (Vlora, Vlone)',
        'code' => 'AL VOA',
        'lat/long' => "40° 29' N / 19° 29' E"
    )
);
    ?>

在使用物品之前还有两点: 1:在您的页面中,您必须包含&#34; list.php&#34;并创建您需要的项目数组。 (在此示例中,我需要端口名称)。 2:将项目设为 json 以供jQuery使用。

  

最终任务:将此代码添加到您的页面。我使用了输入的   在jQuery中命名,这样你就可以处理多个输入。

    //php code
    <?php
    include("list.php");
    $x = 0;
    foreach ($ports as $key => $value) {
        $portName[$x][value] = $value['port'];
        $x += 1;
    }
    ?>
    //html code
    <label for="auto-c">
    <input class="auto-c" id="auto-c" value="">

    //scripts

        <script type="text/javascript">

            jQuery(document).ready(function ($) {
                var items = <?php echo json_encode(array_values($portName), JSON_UNESCAPED_UNICODE); ?>;
        jQuery('input.auto-c').autocomplete({
                        source: items,
                        minLength: 2,
                        select: function (event, ui) {
                            var permalink = ui.item.value; // Get item from the datasource


                        }
                    });
</script>

这不是你的案例的答案,但你可以找到它的工作方式并以你的方式使用它......