2016-04-22 214 views
0

我正在写我的第一个WP插件,所以我开始简单。我想我会创建一个简单的插件,将一个Google Analytics代码片段插入页头。一切似乎工作,除了插件设置页面是空白的。应该有一个简单的表单,可以在其中输入Analytics UA,但该页面完全空白。我一遍又一遍地查看了代码,但我没有看到问题。WordPress插件设置页面

<?php 
    /* 
    Plugin Name: Analytics 
    Plugin URI: https://chriscather.wordpress.com 
    Description: Plugin for adding Google Analytics to website 
    Author: C. Cather 
    Version: 1.0 
    Author URI: https://chriscather.wordpress.com 
    */ 

add_action('admin_menu', 'cc_analytics_menu'); 

function cc_analytics_menu() { 
    add_menu_page('CC Analytics', 'CC Analytics', 'administrator', 'cc_analytics_settings_page', 'cc_analytics_menu', plugins_url('analytics/images/analytics.png')); 
} 

add_action('admin_init', 'cc_analytics_settings'); 

function cc_analytics_settings() { 
    register_setting('cc_analytics_settings_group', 'accountant_name'); 
} 

function cc_analytics_settings_page(){?> 
    <div class="wrap"> 
     <h2>Staff Details</h2> 
     <form method="post" action="options.php"> 
      <?php settings_fields('cc_analytics_settings_group'); ?> 
      <?php do_settings_sections('cc_analytics_settings_group'); ?> 
      <table class="form-table"> 
       <tr valign="top"> 
       <th scope="row">Accountant Name</th> 
       <td><input type="text" name="accountant_name" value="<?php echo esc_attr(get_option('accountant_name')); ?>" /></td> 
       </tr> 
      </table> 
      <?php submit_button(); ?> 
     </form> 
    </div> 
<?php } 

add_action('wp_head', 'cc_analytics'); 
    function cc_analytics() { ?> 
     <script> 
      (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ 
      (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o), 
      m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m) 
      })(window,document,'script','https://www.google-analytics.com/analytics.js','ga'); 

      ga('create', "<?php cc_analytics_settings_group('accountant_name') ?>", 'auto'); 
      ga('send', 'pageview'); 

     </script> 
    <?php } 

回答

0

我的,而不是使用PHP变量在谷歌Analytics(分析)代码来调用解决了这个问题,从Settings页面的表单中调用该函数。

ga('create', '<?php echo get_option('accountant_name', ''); ?>', 'auto'); 
0

add_menu_page只需重命名cc_analytics_menu说法。

代码:

add_menu_page('CC Analytics', 'CC Analytics', 'administrator', 'cc_analytics_settings_page', 'cc_analytics_menu', plugins_url('analytics/images/analytics.png')); 

修改代码:

更名为cc_analytics_menucc_analytics_menu_function

还重命名回调函数:

add_menu_page('CC Analytics', 'CC Analytics', 'administrator', 'cc_analytics_settings_page', 'cc_analytics_menu_function', plugins_url('analytics/images/analytics.png')); 

function cc_analytics_menu_function(){?> 
    <div class="wrap"> 
     <h2>Staff Details</h2> 
     <form method="post" action="options.php"> 
      <?php settings_fields('cc_analytics_settings_group'); ?> 
      <?php do_settings_sections('cc_analytics_settings_group'); ?> 
      <table class="form-table"> 
       <tr valign="top"> 
       <th scope="row">Accountant Name</th> 
       <td><input type="text" name="accountant_name" value="<?php echo esc_attr(get_option('accountant_name')); ?>" /></td> 
       </tr> 
      </table> 
      <?php submit_button(); ?> 
     </form> 
    </div> 
<?php } 

全部插件代码:

<?php 
    /* 
    Plugin Name: Analytics 
    Plugin URI: https://chriscather.wordpress.com 
    Description: Plugin for adding Google Analytics to website 
    Author: C. Cather 
    Version: 1.0 
    Author URI: https://chriscather.wordpress.com 
    */ 

add_action('admin_menu', 'cc_analytics_menu'); 

function cc_analytics_menu() { 
    add_menu_page('CC Analytics', 'CC Analytics', 'administrator', 'cc_analytics_settings_page', 'cc_analytics_menu_function', plugins_url('analytics/images/analytics.png')); 
} 

add_action('admin_init', 'cc_analytics_settings'); 

function cc_analytics_settings() { 
    register_setting('cc_analytics_settings_group', 'accountant_name'); 
} 

function cc_analytics_menu_function(){?> 
    <div class="wrap"> 
     <h2>Staff Details</h2> 
     <form method="post" action="options.php"> 
      <?php settings_fields('cc_analytics_settings_group'); ?> 
      <?php do_settings_sections('cc_analytics_settings_group'); ?> 
      <table class="form-table"> 
       <tr valign="top"> 
       <th scope="row">Accountant Name</th> 
       <td><input type="text" name="accountant_name" value="<?php echo esc_attr(get_option('accountant_name')); ?>" /></td> 
       </tr> 
      </table> 
      <?php submit_button(); ?> 
     </form> 
    </div> 
<?php } 

add_action('wp_head', 'cc_analytics'); 
    function cc_analytics() { ?> 
     <script> 
      (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){ 
      (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o), 
      m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m) 
      })(window,document,'script','https://www.google-analytics.com/analytics.js','ga'); 

      ga('create', "<?php cc_analytics_settings_group('accountant_name') ?>", 'auto'); 
      ga('send', 'pageview'); 

     </script> 
    <?php } 
+0

该表格现在出现在后端,万岁!但是,我只是意识到我在JavaScript中使用PHP调用会导致页面中断。瘸。我想出了这个调用,但我不知道如何创建变量:''“。$ trackerCode。”''我尝试了一些简单的'$ trackerCode = cc_analytics_menu_function(accountant_name)';但是这打破了页面。 –