我公司的网站使用Metronic Horizontal Menu 管理面板,但它是使用 Gear 而不是用户个人资料图片和名称的旧版本。在 Firefox 30 之前,这个 Greasemonkey 脚本可以运行,并且会在用户配置文件/名称下移动“我的个人资料”和“注销”按钮,同时将“我的日历”、“我的收件箱”和“我的任务”保留在设备中图标下拉菜单。这是我的 Greasemonkey 代码:
// ==UserScript==
// @name Fix User Dropdown
// @description Fixes the user dropdown to match current version.
// @include mywebsite.com
// @version 2.0.0
// @require https://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js
// @require https://gist.github.com/raw/2625891/waitForKeyElements.js
// @grant GM_addStyle
// @grant GM.getValue
// ==/UserScript==
//- The @grant directives are needed to restore the proper sandbox.
waitForKeyElements (".topMenu1", addUserDropdown, true);
function addUserDropdown(jNode) {
$('#greetingName').remove();
var userSession = unsafeWindow.userSession;
var userId = userSession.id;
var firstName = userSession.firstName;
var lastName = userSession.lastName;
var fullName = firstName + ' ' + lastName;
var accountId = userSession.accountId;
$('.top-menu .nav').prepend(
'<li class="dropdown dropdown-user dropdown-dark">' +
'<a data-close-others="true" data-hover="dropdown" data-toggle="dropdown" class="dropdown-toggle username username-hide-mobile floatRight" href="#" style="padding:10px;border-right:1px solid #000;margin:5px;">' +
fullName +
'</a>' +
'<ul id="userPersonalMenu" class="dropdown-menu dropdown-menu-default">' +
'<li>' +
'<a href="/user/editor?id=' + userId + '&accountId=' + accountId + '" id="greetingNameLink">' +
'<i class="icon-settings"></i> My Profile </a>' +
'</li>' +
'<li>' +
'<a href="/logout">' +
'<i class="icon-key"></i> Log Out </a>' +
'</li>' +
'</ul>' +
'</li>');
$('.dropdown-toggle').dropdownHover({});
return null;
}
这就是发生的事情:
它永远不会打印“CANCEL FOUND”,就我而言,这违反了逻辑,因为调用堆栈仍然应该解析。然后它继续在屏幕上从右到左然后从上到下无限地绘制用户的名字(示例中的“Nick”)。
我希望将 bWaitOnce 设置为 true 可以解决此问题,但没有骰子。