開發 Internet Explorer 右鍵功能表(ContextMenu)

本文介绍如何为Internet Explorer浏览器开发右键菜单功能,并通过一个缩网址的实际案例进行详细讲解。主要内容包括注册表键值设置、快捷键配置、菜单显示时机定义及JavaScript脚本实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本篇介紹如何開發 Internet Explorer 右鍵功能表(ContextMenu),以 0rz.tw 縮短網址列為範例。

參考 MSDN Library【Adding Entries to the Standard Context Menu】開發 ContextMenu

1. IE 額外的 ContextMenu 是透過註冊機碼 HKEY_CURRENT_USER\Software\Microsoft\Internet Explorer\MenuExt 來建立

2. 所以只要在該位置下新增一個 Key 值,例如:新增【Make 0rz】則 IE 中按下右鍵就會出現相同名稱的功能

SNAG-0003

SNAG-0001

3. 如果我們想要在該功能上可以使用快捷鍵,就如同開發 Windows Form 一樣,只要在英文名稱前加上& 符號即可。

例如:我們把 Key 值從【Make 0rz】改為【&Make 0rz】,則當 ContextMenu 出現按下M 就是執行該項功能

 

4. 在該 Key 值底下,有一個重要鍵值是 Contexts,主要的功能是定義 ContextMenu 出現的時機

SNAG-0004

包含:Default(預設載入)、Images(在圖片上)、Control(任一控制項上)、Tables(在表格格上)、Text selection(純文字反白選擇時)、Anchor(在連結上)

如果 ContextMenu 要包含兩種以上的出現時機,則將 value 自行做 logic or 計算再帶入即可

例如:在本範例中,我們可以新增一個 DWORD 型態,名稱 Contexts、值為 23 的鍵值。則表示該 ContextMenu 【預設載入】、【在連結上】、【在圖片上】按下右鍵,就會出現【Make 0rz】的功能。

 

5. 另外還有 (Default) 這個鍵值,該鍵值填入的內容就是使用者執行 ContextMenu 功能時交給誰來處理,可能是 .html、.exe、.dll…. 等等。

例如本範例中,我想要呼叫 javascript 來執行功能,所以就填入【file://C:\Program Files\Make0rz.js

SNAG-0007

 

6. 這樣大致上,就算是完成註冊機碼的部份。我們透過製作 .reg 檔案方便讓使用者來進行安裝,以下是本範例 RegMake0rz.reg 檔案:

   1:  Windows Registry Editor Version 5.00
   2:   
   3:  [HKEY_CURRENT_USER\Software\Microsoft\Internet Explorer\MenuExt\&Make 0rz]
   4:  @="file://C:\\Program Files\\Make0rz.js"
   5:  "Contexts"=dword:00000023

 

 

 

 7. 以下是 Make0rz.js 的內容:

 

 

 

 由於,在 Contexts 的 value 設定為 0x23,所以表示【預設載入】、【在連結上】、【在圖片上】按下右鍵,就會出現【Make 0rz】的功能。

【預設載入】:在頁面空白處,按下右鍵執行 ContextMenu 的【Make 0rz】,表示目前頁面連結進行縮短網址。

【在連結上】:在文字連結上,按下右鍵執行 ContextMenu 的【Make 0rz】,表示該文字連結進行縮短網址。

【預設載入】:在圖片連結或是圖片上,按下右鍵執行 ContextMenu 的【Make 0rz】,表示圖片位置進行縮短網址。

 

在 javascript 當中,利用 external.menuArguments.event,來判斷使用者在何種時機按下右鍵並取得該元素

利用 external.menuArguments.event.srcElement.href 取得該元素的連結

利用 external.menuArguments.location.href 取得目前頁面的連結

 

然後利用 window.open 來開啟 0rz.tw 目標頁面,來顯是縮短網址後的結果。

如果是執行程式碼的 30 – 33 的話,表示有預覽畫面 (Preview);執行 35-38 則無預覽畫面。(可以依照需求自由調整)

 

8. 實際成果貼圖:

(1) 在空白處,按下右鍵執行 ContextMenu 的【Make 0rz】,表示目前頁面連結進行縮短網址。 (以 No Preview 功能呈現)

SNAG-0009

http://tw.msn.com/?ocid=iehp => http://0rz.tw/KR9Hf

SNAG-0010

 

(2) 在文字連結(新   聞)上,按下右鍵執行 ContextMenu 的【Make 0rz】,表示該文字連結進行縮短網址。(以 Preview 功能呈現)

SNAG-0008

http://news.msn.com.tw/ =>http://0rz.tw/7d2H6

SNAG-0011

 

(3) 在圖片連結或是圖片上,按下右鍵執行 ContextMenu 的【Make 0rz】,表示圖片位置進行縮短網址。

SNAG-0012

 http://sin.stb01.s-msn.com/i/53/79D3A7E9A23E21C6A510F09720CD2.jpg =>http://0rz.tw/JlTDN

 

本功能範例可點此下載,壓縮檔案包含:RegMake0rz.reg 註冊機碼安裝檔、Make0rz.js 功能執行檔、DelMake0rz.reg 註冊機碼反安裝檔

安裝:執行 RegMake0rz.reg,自行將 Make0rz.js 放置於 C:\Program Files 目錄下

反安裝:執行 DelMake0rz.reg,自行將 C:\Program Files\Make0rz.js 檔案刪除


使用 SpicIE 開發 Internet Explorer ContextMenu 實例

Internet Explorer 8 - InPrivate Browsing

Internet Explorer 8 - Automatic Crash Recovery(ACR)

Microsoft Code Analysis Tool .NET (CAT.NET) v1 CTP - 程式碼分析工具

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值