2

我正在尝试在Wordpress中为我的一个小部件创建一个复选框选项,以便在选中它时显示/显示一些内容。

问题是选中复选框时它不会显示内容。

    <p>
        <input type="checkbox" id="tcheckbox" class="checkbox" name="<?php echo $this->get_field_name('checkbox'); ?>" value="1" <?php checked( '1', $checkbox ); ?>/>
        <label for="<?php echo $this->get_field_id('checkbox');?>"><?php _e('My Checkbox.'); ?></label>

        <div id="tcheckboxdiv" style="display:none">
            <p>T One:</p>
            <p><input type="text" class="widefat" name="one" placeholder="1" readonly></p>
            <p>T Two:</p>
            <p><input type="text" class="widefat" name="two" placeholder="2" readonly></p>
        </div>
    </p>            

    <script type="text/javascript">
    jQuery(window).load(function() {
        jQuery("#tcheckbox").change(function() {
            jQuery("#tcheckboxdiv").fadeToggle("slow");
        });
    });
    </script>

由于我对 javaScript 和 PHP 还很陌生,我想知道上面是否有任何冲突的脚本,因为它在这里似乎工作得很好:http: //jsfiddle.net/GhZDP/

谢谢你。

4

3 回答 3

1

这个问题很难重现,因为它实际上在您提供的 Fiddle 中工作。

在您的情况下,我会做的是检查代码是否通过alert()jQuery(window).load()

之后,尝试不同的方法来监听DOM ready

jQuery(function () {
    // Code here
});

jQuery(document).ready(function() {
    // Code here
});

这并不是您的解决方案的真正答案,而是帮助您调试此问题的支持。不过,它太大(并且变得难以阅读)无法在评论中发布。

您也可以尝试这样的委托事件侦听器(这需要您将“widgetForm”ID 添加到您的<form>标签中):

jQuery(function () {
    jQuery("#widgetForm").on("change", "#logocheckbox", function () {
        // Your code goes here; e.g. $("#logocheckboxdiv").fadeToggle("slow");
    });
});

但同样,我只是猜测并帮助您调试,因为我无法真正重现您的问题。

于 2013-03-26T13:59:09.140 回答
0

$由于 WP 在 noConflict 模式下运行,因此您的 jQuery 对象将无法在 WordPress 上运行。您应该将 jQuery 称为 as jQuery,而不是 as $

<script type="text/javascript">
jQuery(window).load(function() {
    jQuery('#logocheckbox').change(function() {
        jQuery("#logocheckboxdiv").fadeToggle("slow");
    });
});
</script>

另外,请不要发布重复的问题

于 2013-03-27T14:56:01.317 回答
0

尽管 jsFiddle 运行良好,但上面的脚本无法正常工作,因为它没有在Wordpress的源代码中正确输出。

Wordpress管理页面也使用 javaScript,这会导致编码冲突。

于 2013-03-30T18:18:41.473 回答