Accessibility / Screen Readers / VoiceOver / VoiceOver Helper

The VoiceOver Helper bookmarklet displays a quick reference guide for testing with Apple's VoiceOver screen reader. Shows a modal panel with essential VoiceOver commands including start/stop, navigation, rotor usage, and element interaction. Explains the VoiceOver modifier (Ctrl+Alt), rotor navigation for element types, and basic commands like entering/escaping sections and interacting with controls. References Apple's official documentation and Deque University. Useful for testers learning VoiceOver or needing quick reference during audits. Close with X, clicking outside, or pressing Escape.

WCAG SC 2.1.1: KeyboardWCAG SC 2.4.1: Bypass Blocks
Run VoiceOver Helper

Test run or drag to
bookmarklets bar to install

javascript:%21function()%7B%22use%20strict%22%3B%21function()%7Bfunction%20t()%7Be%26%26e.remove()%2Co%26%26o.remove()%7Dvar%20e%3Ddocument.createElement(%22div%22)%3Be.id%3D%22voiceover-helper-modal%22%2Ce.style.position%3D%22fixed%22%2Ce.style.top%3D%2250%25%22%2Ce.style.left%3D%2250%25%22%2Ce.style.transform%3D%22translate(-50%25%2C%20-50%25)%22%2Ce.style.zIndex%3D%2210000%22%2Ce.style.background%3D%22%23fff%22%2Ce.style.color%3D%22%23111%22%2Ce.style.boxShadow%3D%220%204px%206px%20rgba(0%2C%200%2C%200%2C%200.1)%22%2Ce.style.borderRadius%3D%228px%22%2Ce.style.width%3D%2290%25%22%2Ce.style.maxWidth%3D%22600px%22%2Ce.style.maxHeight%3D%2280%25%22%2Ce.style.overflowY%3D%22auto%22%2Ce.style.padding%3D%221em%22%2Ce.style.fontFamily%3D%22-apple-system%2C%20BlinkMacSystemFont%2C%20%27Segoe%20UI%27%2C%20Roboto%2C%20Helvetica%2C%20Arial%2C%20sans-serif%2C%20%27Apple%20Color%20Emoji%27%2C%20%27Segoe%20UI%20Emoji%27%2C%20%27Segoe%20UI%20Symbol%27%22%3Bvar%20n%3Ddocument.createElement(%22button%22)%3Bn.innerHTML%3D%22%26times%3B%22%2Cn.style.position%3D%22absolute%22%2Cn.style.top%3D%220.5em%22%2Cn.style.right%3D%220.5em%22%2Cn.style.background%3D%22none%22%2Cn.style.border%3D%22none%22%2Cn.style.fontSize%3D%221.5em%22%2Cn.style.cursor%3D%22pointer%22%2Cn.style.color%3D%22%23666%22%2Cn.addEventListener(%22click%22%2Cfunction()%7Bt()%7D)%2Ce.appendChild(n)%2Ce.insertAdjacentHTML(%22beforeend%22%2C%27%5Cn%5Ct%5Ct%5Ct%3Cstyle%3E%5Cn%5Ct%5Ct%5Ct%5Ct%23voiceover-helper-modal%3Etable%20%7B%5Cn%5Ct%5Ct%5Ct%5Ct%5Ctborder-collapse%3A%20collapse%3B%5Cn%5Ct%5Ct%5Ct%5Ct%5Ctwidth%3A%20100%25%3B%5Cn%5Ct%5Ct%5Ct%5Ct%7D%5Cn%5Ct%5Ct%5Ct%5Ct%23voiceover-helper-modal%20td%20%7B%5Cn%5Ct%5Ct%5Ct%5Ct%5Ctpadding%3A%208px%3B%5Cn%5Ct%5Ct%5Ct%5Ct%5Ctborder%3A%201px%20solid%20%23ddd%3B%20%2F*%20Optional%3A%20adds%20borders%20for%20clarity%20*%2F%5Cn%5Ct%5Ct%5Ct%5Ct%7D%5Cn%5Ct%5Ct%5Ct%5Ct%23voiceover-helper-modal%20a%20%7B%5Cn%5Ct%5Ct%5Ct%5Ct%5Cttext-decoration%3A%20underline%3B%5Cn%5Ct%5Ct%5Ct%5Ct%7D%5Cn%5Ct%5Ct%5Ct%3C%2Fstyle%3E%5Cn%5Ct%5Ct%5Ct%3Ch1%3EVoiceOver%20guide%3C%2Fh1%3E%5Cn%5Ct%5Ct%5Ct%3Cp%3EThe%20default%20VoiceOver%20(VO)%20button%20is%20%3Cstrong%3Ectrl%20%2B%20alt%3C%2Fstrong%3E.%3C%2Fp%3E%5Cn%5Ct%5Ct%5Ct%3Ctable%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3Ctr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Ecmd%20%2B%20F5%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Estart%20or%20stop%20VoiceOver%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3C%2Ftr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3Ctr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3EVO%20%2B%20A%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Estart%20reading%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3C%2Ftr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3Ctr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3EVO%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Estop%20reading%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3C%2Ftr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3Ctr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3EVO%20%2B%20Shift%20%2B%20%5Cu25bc%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Ego%20into%20a%20section%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3C%2Ftr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3Ctr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3EVO%20%2B%20Shift%20%2B%20%5Cu25b2%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Eexit%20a%20section%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3C%2Ftr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3Ctr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3EVO%20%2B%20%5Cu25b6%5Cufe0e%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Enext%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3C%2Ftr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3Ctr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3EVO%20%2B%20%5Cu25c0%5Cufe0e%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Eprevious%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3C%2Ftr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3Ctr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3EEnter%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Eclick%20a%20link%20or%20button%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3C%2Ftr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3Ctr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3ESpace%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Eselect%20a%20checkbox%2C%20radio%20or%20dropdown%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3C%2Ftr%3E%5Cn%5Ct%5Ct%5Ct%3C%2Ftable%3E%5Cn%5Ct%5Ct%5Ct%3Ch2%3EThe%20rotor%3C%2Fh2%3E%5Cn%5Ct%5Ct%5Ct%3Cp%3EThe%20rotor%20lets%20you%20navigate%20by%20element%20type%2C%20for%20example%20headings%20and%20links.%3C%2Fp%3E%5Cn%5Ct%5Ct%5Ct%3Ctable%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3Ctr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3EVO%20%2B%20U%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Eopen%20the%20rotor%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3C%2Ftr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3Ctr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3E%5Cu25c0%5Cufe0e%20%5Cu25b6%5Cufe0e%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Eswitch%20between%20element%20types%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3C%2Ftr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3Ctr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3E%5Cu25b2%20%5Cu25bc%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Eselect%20an%20element%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3C%2Ftr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3Ctr%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3ESpace%20or%20Enter%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%5Ct%3Ctd%3Ego%20to%20selected%20element%3C%2Ftd%3E%5Cn%5Ct%5Ct%5Ct%5Ct%3C%2Ftr%3E%5Cn%5Ct%5Ct%5Ct%3C%2Ftable%3E%5Cn%5Ct%5Ct%5Ct%3Cp%3EFor%20more%20shortcuts%2C%20visit%20%3Ca%20href%3D%22https%3A%2F%2Fsupport.apple.com%2Fguide%2Fvoiceover%2Fgeneral-commands-cpvokys01%2Fmac%22%3EApple%3C%2Fa%3E%20or%20%3Ca%20href%3D%22https%3A%2F%2Fdequeuniversity.com%2Fscreenreaders%2Fvoiceover-keyboard-shortcuts%22%3EDeque%20University%3C%2Fa%3E.%3C%2Fp%3E%5Cn%5Ct%5Ct%27)%2Cdocument.body.appendChild(e)%3Bvar%20o%3Ddocument.createElement(%22div%22)%3Bo.id%3D%22voiceover-helper-overlay%22%2Co.style.position%3D%22fixed%22%2Co.style.top%3D%220%22%2Co.style.left%3D%220%22%2Co.style.width%3D%22100%25%22%2Co.style.height%3D%22100%25%22%2Co.style.background%3D%22rgba(0%2C%200%2C%200%2C%200.4)%22%2Co.style.zIndex%3D%229999%22%2Co.addEventListener(%22click%22%2Cfunction()%7Bt()%7D)%2Cdocument.body.appendChild(o)%2Cdocument.addEventListener(%22keydown%22%2Cfunction%20e(n)%7B%22Escape%22%3D%3D%3Dn.key%26%26(t()%2Cdocument.removeEventListener(%22keydown%22%2Ce))%7D)%7D()%7D()%2Cconsole.log(%22%5CnSource%3A%20https%3A%2F%2Fgithub.com%2Fjoelanman%2Fvoiceover-helper%5CnBookmarklet%20name%3A%20VoiceOver%20Helper%5Cn%22)%3B
← Back to all bookmarklets