首页
/ Vim Keybindings for Safari 技术文档

Vim Keybindings for Safari 技术文档

2024-12-20 09:30:27作者:齐添朝

1. 安装指南

安装步骤

  1. 打开Safari浏览器。
  2. 进入Safari扩展商店。
  3. 搜索“Vim Keybindings for Safari”扩展。
  4. 点击“安装”按钮进行安装。
  5. 安装完成后,重启Safari浏览器。

配置

  1. 安装完成后,点击Safari菜单栏中的“偏好设置”。
  2. 在“扩展”选项卡中,找到并启用“Vim Keybindings for Safari”扩展。
  3. 在扩展的偏好设置中,可以配置不需要加载扩展的网站列表,多个网站之间用逗号分隔。

2. 项目的使用说明

基本功能

  • 导航键gg(跳到页面顶部)、G(跳到页面底部)、h(左移)、j(下移)、k(上移)、l(右移)。
  • 页面滚动^D(向下滚动半页)、^U(向上滚动半页)、^F(向下滚动一页)、^B(向上滚动一页)。
  • 编辑模式esc(退出编辑模式)、i(进入编辑模式)、dd(删除当前行)。
  • 标签页操作gt(下一个标签页)、gT(上一个标签页)、<number>gt(跳转到指定编号的标签页)。

命令模式

  • 退出:q(退出当前标签页)、:q!(强制退出当前标签页)。
  • 新建标签页:tabnew
  • 标签页导航:tabn(下一个标签页)、:tabp(上一个标签页)、:tabfir:tabfirst(第一个标签页)、:tablast(最后一个标签页)。
  • 编辑URL:e @url:edit @url:tabe @url:tabedit @url
  • 查找替换:%s/@search/@replace

注意事项

  • @url 需要是一个有效的URL,如果未提供http://,扩展会自动添加。
  • @search@replace 需要是正则表达式,支持修饰符,但使用的是JavaScript引擎,而非Vim引擎。

3. 项目API使用文档

命令模式API

  • :q:退出当前标签页。
  • :q!:强制退出当前标签页。
  • :tabnew:新建一个标签页。
  • :tabn:切换到下一个标签页。
  • :tabp:切换到上一个标签页。
  • :tabfir:tabfirst:切换到第一个标签页。
  • :tablast:切换到最后一个标签页。
  • :e @url:edit @url:tabe @url:tabedit @url:在当前或新标签页中打开指定URL。
  • :%s/@search/@replace:在当前页面中查找并替换内容。

快捷键API

  • gg:跳到页面顶部。
  • G:跳到页面底部。
  • hjkl:页面导航。
  • ^D^U^F^B:页面滚动。
  • esc:退出编辑模式。
  • i:进入编辑模式。
  • dd:删除当前行。
  • gtgT<number>gt:标签页导航。

4. 项目安装方式

通过Safari扩展商店安装

  1. 打开Safari浏览器。
  2. 进入Safari扩展商店。
  3. 搜索“Vim Keybindings for Safari”扩展。
  4. 点击“安装”按钮进行安装。
  5. 安装完成后,重启Safari浏览器。

手动安装(适用于开发者)

  1. 克隆项目仓库到本地。
  2. 打开Safari的“开发”菜单,选择“显示扩展构建器”。
  3. 点击“+”按钮,选择“添加扩展”。
  4. 选择克隆的项目文件夹。
  5. 点击“安装”按钮进行安装。
  6. 安装完成后,重启Safari浏览器。

已知问题

  • 某些页面会接管键盘输入,导致扩展的覆盖层无法显示或接收键盘输入。
  • 某些页面会导致gtgT组合键跳过页面内容。

贡献者

  • Mutwin Kraus
  • Jason Green
  • Jannik Nielsen
登录后查看全文
热门项目推荐

项目优选

收起
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
53
468
kernelkernel
deepin linux kernel
C
22
5
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
7
0
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
878
517
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
336
1.1 K
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
180
264
cjoycjoy
一个高性能、可扩展、轻量、省心的仓颉Web框架。Rest, 宏路由,Json, 中间件,参数绑定与校验,文件上传下载,MCP......
Cangjie
87
14
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.08 K
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
349
381
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
612
60