← Alle Beispiele

JavaScript Navigation gitlab.com

GitLab: zwischen Diff-Dateien mit J/K springen

Fügt J- und K-Kürzel hinzu, um schnell zwischen geänderten Dateien einer Merge Request zu wechseln.

Code zum Kopieren

// Use J and K keys to jump between diff files in a merge request
function files() {
  return Array.prototype.slice.call(document.querySelectorAll('.diff-file'));
}
function jump(dir) {
  const list = files();
  if (!list.length) { return; }
  const y = window.scrollY + 80;
  let idx = list.findIndex(function (f) { return f.offsetTop > y; });
  if (dir < 0) { idx = idx <= 0 ? 0 : idx - 1; }
  else if (idx === -1) { idx = list.length - 1; }
  const target = list[Math.max(0, Math.min(idx, list.length - 1))];
  if (target) { window.scrollTo({ top: target.offsetTop - 60, behavior: 'smooth' }); }
}
document.addEventListener('keydown', function (e) {
  const tag = (e.target.tagName || '').toLowerCase();
  if (tag === 'input' || tag === 'textarea' || e.target.isContentEditable) { return; }
  if (e.key === 'j') { jump(1); }
  else if (e.key === 'k') { jump(-1); }
});

So verwendest du dieses Beispiel

  1. Kopiere den Code mit der Schaltfläche oben.
  2. Installiere JustZix (2 Minuten) und öffne die Erweiterung auf der Zielseite.
  3. Füge eine neue Regel hinzu, die zu dieser Seite passt.
  4. Füge den Code in das JavaScript-Panel der Regel ein und speichere — er läuft bei jedem Seitenbesuch.

Bewerte dieses Beispiel

Noch keine Bewertungen — sei der Erste.

Funktioniert dieses Beispiel?

Snippets sind nutzlos, wenn du sie nirgendwo einfügen kannst.

JustZix ist in 2 Minuten installiert und führt deinen Code auf jeder passenden Seite aus. Kein Konto, keine Zahlung.

Kostenlos herunterladen Anwendungsfälle ansehen