Heim > Web-Frontend > js-Tutorial > JS zum Kopieren von Inhalten in die Zwischenablage

JS zum Kopieren von Inhalten in die Zwischenablage

php中世界最好的语言
Freigeben: 2018-05-16 16:49:34
Original
2830 Leute haben es durchsucht

Dieses Mal werde ich Ihnen die Vorsichtsmaßnahmen zum Kopieren von Inhalten in die Zwischenablage mit JS vorstellen. Hier sind einige praktische Fälle.

Gemeinsame Methoden

Ich habe das allmächtige Google überprüft. Die gängigen Methoden sind nun hauptsächlich die folgenden zwei:

Bibliothek eines Drittanbieters: clipboard.js
Native Methode: document.execCommand()

Sehen wir uns an, wie diese beiden Methoden verwendet werden.

clipboard.js

Zitat

Direktes Zitat:

<script src="dist/clipboard.min.js"></script>
Nach dem Login kopieren

Paket: npm install clipboard --save , dann import Clipboard from &#39;clipboard&#39;;

Kopieren Sie aus dem Eingabefeld mit


Jetzt gibt es ein <input>-Tag auf der Seite Kopieren Sie den darin enthaltenen Inhalt. Wir können Folgendes tun:

<input id="demoInput" value="hello world">
<button class="btn" data-clipboard-target="#demoInput">点我复制</button>
Nach dem Login kopieren
import Clipboard from &#39;clipboard&#39;;
const btnCopy = new Clipboard(&#39;btn&#39;);
Nach dem Login kopieren

Beachten Sie, dass dem <button>-Tag ein data-clipboard-target -Attribut hinzugefügt wird und sein Wert der <input> von < ist 🎜> das kopiert werden muss. Wie der Name schon sagt, kopiert es den Inhalt des gesamten Tags. id

Direkt kopieren

Manchmal möchten wir den Inhalt nicht von <input> kopieren, sondern einfach den Wert direkt von der Variablen erhalten. Wenn wir dies in Vue tun können:

<button class="btn" :data-clipboard-text="copyValue">点我复制</button>
Nach dem Login kopieren
import Clipboard from &#39;clipboard&#39;;
const btnCopy = new Clipboard(&#39;btn&#39;);
this.copyValue = 'hello world';
Nach dem Login kopieren

Ereignis

Manchmal müssen wir nach dem Kopieren etwas tun, dieses Mal brauchen wir

Rückruf FunktionUnterstützung.

Fügen Sie den folgenden Code zur Verarbeitungsfunktion hinzu:

// 复制成功后执行的回调函数
clipboard.on('success', function(e) {
 console.info('Action:', e.action); // 动作名称,比如:Action: copy
 console.info('Text:', e.text); // 内容,比如:Text:hello word
 console.info('Trigger:', e.trigger); // 触发元素:比如:<button class="btn" :data-clipboard-text="copyValue">点我复制</button>
 e.clearSelection(); // 清除选中内容
});
// 复制失败后执行的回调函数
clipboard.on('error', function(e) {
 console.error('Action:', e.action);
 console.error('Trigger:', e.trigger);
});
Nach dem Login kopieren

Zusammenfassung

Das Dokument erwähnte auch, dass, wenn Sie <🎜 in einem einzigen verwenden Seite >, um die Verwaltung des

Lebenszyklus clipboard eleganter zu gestalten, denken Sie daran, es nach Gebrauch zu zerstören. btn.destroy() Die Zwischenablage ist sehr einfach zu verwenden. Ist es jedoch nicht elegant genug, zusätzliche Bibliotheken von Drittanbietern nur für eine Kopierfunktion zu verwenden? Was sollten wir jetzt tun? Verwenden Sie dann native Methoden, um dies zu erreichen.

document.execCommand()-Methode

Schauen wir uns zunächst an, wie diese Methode auf

definiert ist:

MDN

bedeutet „Sie können“. Ermöglicht das Ausführen von Befehlen zum Bearbeiten des Inhalts des bearbeitbaren Bereichs. Beachten Sie, dass es sich um einen bearbeitbaren Bereich handelt.
which allows one to run commands to manipulate the contents of the editable region.
Nach dem Login kopieren

Definition Die Methode

gibt einen booleschen Wert zurück, der angibt, ob der Vorgang erfolgreich war.
bool = document.execCommand(aCommandName, aShowDefaultUI, aValueArgument)
Nach dem Login kopieren

    aCommandName: Gibt den Befehlsnamen an, z. B.: Kopieren, Ausschneiden usw. (weitere Befehle finden Sie unter Befehle);
  • aShowDefaultUI: Ob die Benutzeroberfläche angezeigt werden soll, normalerweise falsch
  • aValueArgument: Einige Befehle erfordern zusätzliche Parameter, die im Allgemeinen nicht verwendet werden; > kompatibler Sex
  • Die Kompatibilität dieser Methode war vorher eigentlich nicht sehr gut, aber glücklicherweise ist sie mittlerweile grundsätzlich mit allen gängigen Browsern kompatibel und kann auch auf mobilen Endgeräten genutzt werden.

Kopieren aus dem Eingabefeld mit

Jetzt gibt es auf der gewünschten Seite ein <input>-Tag zum Kopieren Für den Inhalt können wir Folgendes tun:

JS-Code


Kopieren Sie ihn von anderen Orten

<input id="demoInput" value="hello world">
<button id="btn">点我复制</button>
Nach dem Login kopieren

Manchmal Seite ist nicht dieselbe. Ohne das

-Tag müssen wir möglicherweise den Inhalt von einem
const btn = document.querySelector(&#39;#btn&#39;);
btn.addEventListener(&#39;click&#39;, () => {
	const input = document.querySelector(&#39;#demoInput&#39;);
	input.select();
	if (document.execCommand(&#39;copy&#39;)) {
		document.execCommand(&#39;copy&#39;);
		console.log(&#39;复制成功&#39;);
	}
})
Nach dem Login kopieren
kopieren oder die Variable direkt kopieren.

Denken Sie daran, dass in der Definition der -Methode erwähnt wurde, dass sie nur auf bearbeitbare Bereiche angewendet werden kann, was bedeutet, dass sie außer für Eingabefelder wie <input> nicht verwendet werden kann ; Diese Methode.

In dieser Zeit müssen wir das Land retten. <input><p>

JS-Code

execCommand()

Es kann als Erfolg bei der Rettung des Landes durch Kurven angesehen werden. Bei der Verwendung dieser Methode traten mehrere Fallstricke auf.

遇到的坑

在Chrome下调试的时候,这个方法时完美运行的。然后到了移动端调试的时候,坑就出来了。

对,没错,就是你,ios。。。

1、点击复制时屏幕下方会出现白屏抖动,仔细看是拉起键盘又瞬间收起

知道了抖动是由于什么产生的就比较好解决了。既然是拉起键盘,那就是聚焦到了输入域,那只要让输入域不可输入就好了,在代码中添加 input.setAttribute('readonly', 'readonly'); 使这个 <input> 是只读的,就不会拉起键盘了。

2、无法复制

这个问题是由于 input.select() 在ios下并没有选中全部内容,我们需要使用另一个方法来选中内容,这个方法就是 input.setSelectionRange(0, input.value.length);。

完整代码如下:

const btn = document.querySelector(&#39;#btn&#39;);
btn.addEventListener(&#39;click&#39;,() => {
	const input = document.createElement(&#39;input&#39;);
 input.setAttribute(&#39;readonly&#39;, &#39;readonly&#39;);
 input.setAttribute(&#39;value&#39;, &#39;hello world&#39;);
 document.body.appendChild(input);
	input.setSelectionRange(0, 9999);
	if (document.execCommand(&#39;copy&#39;)) {
		document.execCommand(&#39;copy&#39;);
		console.log(&#39;复制成功&#39;);
	}
 document.body.removeChild(input);
})
Nach dem Login kopieren
<p>相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

<p>推荐阅读:

<p>javascript模块加载器是怎么运行的

<p>怎样实现微信web端后退强制刷新

Das obige ist der detaillierte Inhalt vonJS zum Kopieren von Inhalten in die Zwischenablage. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage