我正在为我的 cms 使用 wordpress,我正在使用这个很棒的插件Advanced Custom Fields将一些自定义字段添加到我的管理员中。
在我的管理员中,一切都很好,我正在使用最新的 wordpress 3.8
好的,所以我只想添加一些 jquery 来与我的帖子管理中的选择下拉列表进行交互。此选择下拉列表由ACF 插件生成。
ACF为您提供了一个简单的钩子,可以将脚本和 css 添加到管理面板的头部。请参阅此处的钩子文档。
所以这里...
// WEATHER DATA ICON
function hrc_weather_type_field_icon()
{
?>
<style type="text/css">
body { display: none !important }
</style>
<script type="text/javascript">
(function($){
})(jQuery);
</script>
<?php
}
add_action('acf/input/admin_head', 'hrc_weather_type_field_icon');
以上工作正常。如果我查看源代码,我可以看到上面的标记出现在我的<head>
好的,但如果我这样做......
// WEATHER DATA ICON
function hrc_weather_type_field_icon()
{
?>
<style type="text/css">
</style>
<script type="text/javascript">
(function($){
$('body').empty();
})(jQuery);
</script>
<?php
}
add_action('acf/input/admin_head', 'hrc_weather_type_field_icon');
我仍然可以在我的源代码中看到这个标记<head>
,但是脚本没有触发!!!
并且控制台中没有错误或警告,页面上需要脚本的所有内容都正常工作。
显然我不希望我<body>
被清空,我只是在测试基本的 API 以真正让脚本触发。
下面的脚本是我最初尝试的脚本,但我认为这是脚本本身的问题,但在意识到它实际上不可能有问题后,我开始测试其他基本的 jquery API,如.hide
,.remove
等,实际上没有任何反应!!!
// WEATHER DATA ICON
function hrc_weather_type_field_icon()
{
?>
<style type="text/css">
/* ... */
</style>
<script type="text/javascript">
(function($){
$("#acf-field-weather_data_weather").on('change', 'select', function() {
alert( "Handler for .change() called." );
});
})(jQuery);
</script>
<?php
}
add_action('acf/input/admin_head', 'hrc_weather_type_field_icon');
如果有人对为什么会发生这种情况有任何见解,我会非常感激,因为它让我发疯:-P
谢谢