問題描述

任何人都可以解釋為什麼會有不斷的通知

JQMIGRATE: Migrate is installed, version 1.4.0

當我將主題更新為 WordPress 4.5 時,我的控制枱中指向 load-scripts.php,它如何被刪除?

這不是一個錯誤,但它總是存在於我的控制枱中,我真的不明白它的意義在哪裏?我應該更新一些東西,對我的代碼進行一些修改嗎?

也許我有一點 ocd,但通常當我檢查的網站,我喜歡看錯誤和真實的通知,指出我的控制枱中的一個問題…

最佳解決方案

WordPress 使用 jQuery 遷移腳本確保您可能正在使用哪些使用從較新版本的 jQuery 中刪除功能的任何插件或主題的向後兼容性。

隨着 WordPress 4.5 的發佈,它似乎已經升級了從 v1.2.1v1.4.0 的 jQuery 遷移的版本 – 快速掃描通過代碼顯示 v1.4.0 日誌腳本被加載,無論 migrateMute 選項是否設置並且在未壓縮和最小化的版本中。

刪除通知的唯一方法是確保您的所有插件/主題代碼不依賴任何舊的 jQuery 功能,然後刪除遷移腳本。有一個 plugin 在這裏做,但這是一個很簡單的方法,可以放在你的主題的功能文件或類似的:

add_action( 'wp_default_scripts', function( $scripts ) {
    if ( ! empty( $scripts->registered['jquery'] ) ) {
        $scripts->registered['jquery']->deps = array_diff( $scripts->registered['jquery']->deps, array( 'jquery-migrate' ) );
    }
} );

請注意,這不是 WordPress 開發的最佳做法,在我看來,遷移腳本不應該僅僅是為了保持開發者控制枱的清潔。

次佳解決方案

您可以在 jquery-migrate.min.js 中將日誌消息文本更改為空白,但是在核心更新時不會保留該文本。

另一種方法是將 console.log 的直通/過濾功能副本添加到遷移腳本加載之前,並將其忽略包含 「Migrate is installed」 的日誌記錄消息。這樣做會保留其他遷移警告:

// silencer script
function jquery_migrate_silencer() {
    // create function copy
    $silencer = '<script>window.console.logger = window.console.log; ';
    // modify original function to filter and use function copy
    $silencer .= 'window.console.log = function(tolog) {';
    // bug out if empty to prevent error
    $silencer .= 'if (tolog == null) {return;} ';
    // filter messages containing string
    $silencer .= 'if (tolog.indexOf("Migrate is installed") == -1) {';
    $silencer .= 'console.logger(tolog);} ';
    $silencer .= '}</script>';
    return $silencer;
}

// for the frontend, use script_loader_tag filter
add_filter('script_loader_tag','jquery_migrate_load_silencer', 10, 2);
function jquery_migrate_load_silencer($tag, $handle) {
    if ($handle == 'jquery-migrate') {
        $silencer = jquery_migrate_silencer();
        // prepend to jquery migrate loading
        $tag = $silencer.$tag;
    }
    return $tag;
}

// for the admin, hook to admin_print_scripts
add_action('admin_print_scripts','jquery_migrate_echo_silencer');
function jquery_migrate_echo_silencer() {echo jquery_migrate_silencer();}

結果是添加到前端和後端的一行 HTML 腳本實現了所需的效果 (防止已安裝的消息) 。

第三種解決方案

這裏只是一點點測試。

我偷看了 jquery-migrate.js,注意到這部分:

// Set to true to prevent console output; migrateWarnings still maintained
// jQuery.migrateMute = false;

所以我用新的 wp_add_inline_script()測試了以下版本,在 4.5 版本中引入:

add_action( 'wp_enqueue_scripts', function()
{
    wp_add_inline_script(
        'jquery-migrate', 'jQuery.migrateMute = true;',
        'before'
    );
} );

這將改變:

JQMIGRATE: Migrate is installed with logging active, version 1.4.0

至:

JQMIGRATE: Migrate is installed, version 1.4.0

所以它實際上並沒有阻止所有的控制枱輸出,像 jquery-migrate.js 這樣的部分:

// Show a message on the console so devs know we're active
if ( window.console && window.console.log ) {
    window.console.log( "JQMIGRATE: Migrate is installed" +
        ( jQuery.migrateMute ? "" : " with logging active" ) +
        ", version " + jQuery.migrateVersion );
}

參考文獻

注:本文內容整合自 Google/Baidu/Bing 輔助翻譯的英文資料結果。如果您對結果不滿意,可以加入我們改善翻譯效果:薇曉朵技術論壇。