javascript – 仅在右键单击以“Story”开头的类时显示上下文菜单按钮
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 仅在右键单击以“Story”开头的类时显示上下文菜单按钮,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含6224字,纯文字阅读大概需要9分钟。
内容图文
![javascript – 仅在右键单击以“Story”开头的类时显示上下文菜单按钮](/upload/InfoBanner/zyjiaocheng/710/7898a3d3ab36448fa89355c3253a4f7a.jpg)
有没有办法显示上下文菜单操作,只有当用户右键单击以“story”开头的类时.
例如:如果用户右键单击类“story ….”页面中的对象,则应显示上下文菜单按钮,否则不会发生任何事情.
这是我的代码(尽管它不起作用):
var divs = document.querySelectorAll("[class^=story]"); //get all classes that start with "Story"
window.oncontextmenu = function() {
for(var i=0; i < divs.length; i++)
{
divs[i].onclick = function() {
chrome.contextMenus.create
(
{"id": "butto1", "title": "1", "contexts":["all"], "onclick": genericOnClick}
);
chrome.contextMenus.create
(
{"id": "button2", "title": "2", "contexts":["all"], "onclick": genericOnClick}
);
chrome.contextMenus.create
(
{"id": "button3", "title": "3", "contexts":["all"], "onclick": genericOnClick}
);
};
}
return true;
};
function genericOnClick(info, tab) {
//do some crap here
chrome.contextMenus.removeAll();
}
解决方法:
在this related answer中,我解释了无法动态创建上下文菜单项,因为contextmenu事件和上下文菜单项外观之间的时间不足以在其间进行chrome.contextMenus.create调用.
另一个答案解释了如何确保上下文菜单条目显示所选文本.这是通过监听selectionchange事件完成的.为了您的目的,我们希望使用具有所需时间的事件.
我将使用mouseover和mouseout事件.通过依赖鼠标事件,当您使用键盘时,上下文菜单将不起作用,例如:通过使用JavaScript或Tab键聚焦元素,然后按上下文菜单键.我没有在下面的解决方案中实现它.
该演示包含三个文件(以及一个用于测试它的HTML页面).我将所有文件放在一个zip文件中,可在https://robwu.nl/contextmenu-dom.zip获得.
的manifest.json
每个Chrome扩展程序都需要此文件才能运行.对于此应用程序,使用后台页面和内容脚本.此外,contextMenus权限是必需的.
{
"name": "Contextmenu based on activated element",
"description": "Demo for https://stackoverflow.com/q/14829677",
"version": "1",
"manifest_version": 2,
"background": {
"scripts": ["background.js"]
},
"content_scripts": [{
"run_at": "document_idle",
"js": ["contentscript.js"],
"matches": ["<all_urls>"]
}],
"permissions": [
"contextMenus"
]
}
background.js
后台页面将代表内容脚本创建上下文菜单.这是通过将事件侦听器绑定到chrome.runtime.onConnect来实现的,它提供了一个简单的接口来替换上下文菜单条目.
只要通过此端口(从内容脚本)接收到消息,就会调用chrome.contextMenus.create.除了onclick之外的所有属性都是JSON可序列化的,因此只有“onclick”处理程序需要特殊处理.我已经使用字符串来识别字典中的预定义函数(var clickHandlers).
var lastTabId;
// Remove context menus for a given tab, if needed
function removeContextMenus(tabId) {
if (lastTabId === tabId) chrome.contextMenus.removeAll();
}
// chrome.contextMenus onclick handlers:
var clickHandlers = {
'example': function(info, tab) {
// This event handler receives two arguments, as defined at
// https://developer.chrome.com/extensions/contextMenus#property-onClicked-callback
// Example: Notify the tab's content script of something
// chrome.tabs.sendMessage(tab.id, ...some JSON-serializable data... );
// Example: Remove contextmenus for context
removeContextMenus(tab.id);
}
};
chrome.runtime.onConnect.addListener(function(port) {
if (!port.sender.tab || port.name != 'contextMenus') {
// Unexpected / unknown port, do not interfere with it
return;
}
var tabId = port.sender.tab.id;
port.onDisconnect.addListener(function() {
removeContextMenus(tabId);
});
// Whenever a message is posted, expect that it's identical to type
// createProperties of chrome.contextMenus.create, except for onclick.
// "onclick" should be a string which maps to a predefined function
port.onMessage.addListener(function(newEntries) {
chrome.contextMenus.removeAll(function() {
for (var i=0; i<newEntries.length; i++) {
var createProperties = newEntries[i];
createProperties.onclick = clickHandlers[createProperties.onclick];
chrome.contextMenus.create(createProperties);
}
});
});
});
// When a tab is removed, check if it added any context menu entries. If so, remove it
chrome.tabs.onRemoved.addListener(removeContextMenus);
contentscript.js
该脚本的第一部分创建了用于创建上下文菜单的简单方法.
在最后5行中,定义上下文菜单条目并将其绑定到与给定选择器匹配的所有当前和未来元素.就像我在上一节中所说的那样,参数类型与createProperties argument of chrome.contextMenus.create相同,除了“onclick”,这是一个映射到后台页面中的函数的字符串.
// Port management
var _port;
var getPort = function() {
if (_port) return _port;
_port = chrome.runtime.connect({name: 'contextMenus'});
_port.onDisconnect.addListener(function() {
_port = null;
});
return _port;
}
// listOfCreateProperties is an array of createProperties, which is defined at
// https://developer.chrome.com/extensions/contextMenus#method-create
// with a single exception: "onclick" is a string which corresponds to a function
// at the background page. (Functions are not JSON-serializable, hence this approach)
function addContextMenuTo(selector, listOfCreateProperties) {
// Selector used to match an element. Match if an element, or its child is hovered
selector = selector + ', ' + selector + ' *';
var matches;
['matches', 'webkitMatchesSelector', 'webkitMatches', 'matchesSelector'].some(function(m) {
if (m in document.documentElement) {
matches = m;
return true;
}
});
// Bind a single mouseover+mouseout event to catch hovers over all current and future elements.
var isHovering = false;
document.addEventListener('mouseover', function(event) {
if (event.target && event.target[matches](selector)) {
getPort().postMessage(listOfCreateProperties);
isHovering = true;
} else if(isHovering) {
getPort().postMessage([]);
isHovering = false;
}
});
document.addEventListener('mouseout', function(event) {
if (isHovering && (!event.target || !event.target[matches](selector))) {
getPort().postMessage([]);
isHovering = false;
}
});
}
// Example: Bind the context menus to the elements which contain a class attribute starts with "story"
addContextMenuTo('[class^=story]', [
{"id": "butto1", "title": "1", "contexts":["all"], "onclick": 'example'},
{"id": "button2", "title": "2", "contexts":["all"], "onclick": 'example'},
{"id": "button3", "title": "3", "contexts":["all"], "onclick": 'example'}
]);
前面的代码假定所有上下文菜单点击都由后台页面处理.如果要改为处理内容脚本中的逻辑,则需要在内容脚本中绑定消息事件.我在background.js示例中显示了一个(注释的)chrome.tabs.sendMessage实例,以显示应该触发此事件的位置.
如果您需要识别触发事件的元素,请不要使用我的示例中所示的预定义函数(在字典中),而是使用内联函数或工厂函数.要识别元素,需要将消息与唯一标识符配对.我将把这个实现的任务留给读者(这并不困难).
内容总结
以上是互联网集市为您收集整理的javascript – 仅在右键单击以“Story”开头的类时显示上下文菜单按钮全部内容,希望文章能够帮你解决javascript – 仅在右键单击以“Story”开头的类时显示上下文菜单按钮所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。