各地市:
周口电商网站分为哪些类型? 商丘网站建设怎么处理服务器漏洞安全? 开封免费搭建网站如何策划? 漯河数据分析如何策划? 开封logo设计的流程和注意事项有哪些? 周口logo设计怎么设计最好? 濮阳网站建设主页设计有什么要求? 南阳网站SEO中链轮模型如何建立? 济源SEO技术中更换IP后怎么做? 濮阳网站建设Linux服务器怎么配置SSH服务器? 开封域名注册的费用是多少? 济源网站优化SEO中快速排名有哪些应用场景? 安阳网站建设公司哪家专业可靠? 开封域名注册需要多少钱? 开封网站建设怎么定期Linux服务器备份数据? 平顶山响应式设计最新技术发展趋势分析? 洛阳SEO技术如何降低跳出率? 周口网站维护分为哪些类型? 三门峡网站建设Linux服务器怎么限制shell访问权限? 开封免费搭建网站的优势是什么? 濮阳电商网站需要注意什么事项? 济源网络安全有什么技巧? 周口网站建设Linux服务器通过哪些方式隐藏服务器? 洛阳免费搭建网站如何进行学习? 漯河定制化网站需要确认哪些功能? 商丘网站空间购买需要多长时间? 南阳域名注册需要多长时间? 洛阳网站建设导航设计有什么要求? 驻马店网页开发分为哪些类型? 信阳网站维护需要多少钱? 漯河网站优化中搜索引擎怎么操作? 焦作网络安全需要考虑什么因素? 许昌网站建设日常怎么检查服务器网络安全? 新乡seo中网站空间如何进行优化? 新乡免费搭建网站去哪儿找? 新乡网站设计去哪儿找? Linux服务器通过哪些方式发现未授权访问? 南阳网站建设Linux服务器怎么过滤流量? 南阳网站建设Linux服务器怎么记录未授权访问? 三门峡网站建设Linux服务器通过哪些方式拒绝服务攻击? 濮阳网站建设Linux服务器通过哪些方式限制流量? 安阳网站建设怎么处理服务器系统安全? 鹤壁网站建设404页面怎么开发?
您的位置: 主页 > 博客cms > WordPress 4.2后头部多出的Emoji表情的处

WordPress 4.2后头部多出的Emoji表情的处

发布时间:2023-08-04 11:06:33 | 发布者:往流科技

如果你更新到 wordpress 的 4.2 版本,查看网页源代码你会发现 WordPress 会自动在加载一段用于支持 emjo 表情的脚本(JS+CSS)。对于大部分人来说,这个是十分鸡肋的功能,再加上 GFW 的强大力量,反而影响加载速度。

我们有两种解决方法:启用或禁用。

原因分析

脚本就是类似下面的代码:

<script?type="text/javascript">?window._wpemojiSettings?=?{"baseUrl":"http://s.w.org/images/core/emoji/72x72/","ext":".png","source":{"concatemoji":"http://devework.com/wp-includes/js/wp-emoji-release.min.js?ver=4.2"}};?!function(a,b,c){function?d(a){var?c=b.createElement("canvas"),d=c.getContext&&c.getContext("2d");return?d&&d.fillText?(d.textBaseline="top",d.font="600?32px?Arial","flag"===a?(d.fillText(String.fromCharCode(55356,56812,55356,56807),0,0),c.toDataURL().length>3e3):(d.fillText(String.fromCharCode(55357,56835),0,0),0!==d.getImageData(16,16,1,1).data[0])):!1}function?e(a){var?c=b.createElement("script");c.src=a,c.type="text/javascript",b.getElementsByTagName("head")[0].appendChild(c)}var?f;c.supports={simple:d("simple"),flag:d("flag")},c.supports.simple&&c.supports.flag||(f=c.source||{},f.concatemoji?e(f.concatemoji):f.wpemoji&&f.twemoji&&(e(f.twemoji),e(f.wpemoji)))}(window,document,window._wpemojiSettings);?</script>?<style?type="text/css">?img.wp-smiley,?img.emoji?{?display:?inline?!important;?border:?none?!important;?box-shadow:?none?!important;?height:?1em?!important;?width:?1em?!important;?margin:?0?.07em?!important;?vertical-align:?-0.1em?!important;?background:?none?!important;?padding:?0?!important;?}?</style>

因为WordPress 更新 4.2 的一个新增功能就是支持 emjo 表情,但看部分加载源居然是 wp.org 的 js 文件。对于大部分人来说,这个是十分鸡肋的功能。

禁用:移除 WordPress 4.2 中前台自动加载的 emoji 脚本

既然功能鸡肋,不如直接移除掉来得更加快捷。代码提取自 Disable Emojis 插件,可以放在主题目录下的 functions.php 文件中:

/**?*?Disable?the?emoji's?*/?function?disable_emojis()?{?remove_action(?'wp_head',?'print_emoji_detection_script',?7?);?remove_action(?'admin_print_scripts',?'print_emoji_detection_script'?);?remove_action(?'wp_print_styles',?'print_emoji_styles'?);?remove_action(?'admin_print_styles',?'print_emoji_styles'?);?remove_filter(?'the_content_feed',?'wp_staticize_emoji'?);?remove_filter(?'comment_text_rss',?'wp_staticize_emoji'?);?remove_filter(?'wp_mail',?'wp_staticize_emoji_for_email'?);?add_filter(?'tiny_mce_plugins',?'disable_emojis_tinymce'?);?}?add_action(?'init',?'disable_emojis'?);/**?*?Filter?function?used?to?remove?the?tinymce?emoji?plugin.?*/?function?disable_emojis_tinymce(?$plugins?)?{?if?(?is_array(?$plugins?)?)?{?return?array_diff(?$plugins,?array(?'wpemoji'?)?);?}?else?{?return?array();?}?}

启用:转存至本地调用 Emoji 表情

WordPress 官方将此功能会写入正式版一定有其理由。但我们知道 WP 的 CDN 早就被*掉,唯一方法就是转存到本地,使 WP 识别本地 Emoji 表情。

Twitter Emoji 表情包下载,下载后直接解压至主题目录,文件夹名不变。将以下代码放在主题目录下的 functions.php 文件中:

//首先补全wp的表情库?function?smilies_reset()?{?global?$wpsmiliestrans,?$wp_smiliessearch;?//?don't?bother?setting?up?smilies?if?they?are?disabled?if?(!get_option('use_smilies'))?{?return;?}?$wpsmiliestrans_fixed?=?array(?':mrgreen:'?=>?"