var firstRule = document.styleSheets[0].cssRules[0];



Wie schreibe ich CSS-Animationen in JS? Wie schreibe ich CSS-Animationen in JS (Code)
Der Inhalt dieses Artikels befasst sich mit der Frage, wie man CSS-Animationen in JS schreibt. Die Methode (Code) zum Schreiben von CSS-Animationen in JS hat einen gewissen Referenzwert. Ich hoffe, dass sie für Sie hilfreich ist.
Verwenden Sie setTimeout() oder setInterval(), um einen Codeabschnitt regelmäßig mit diesen beiden Funktionen aufzurufen. Das ist das Prinzip.
Der Zweck besteht darin, den Inline-Stil wiederholt zu ändern, um den Effekt einer Animation zu erzielen
Indem gleichzeitig der Inhalt eines Frames erstellt und dann das CSS unter der Aktion kontinuierlich geändert wird des Funktionswerts, um den Effekt einer Animation zu erzielen
js schreibt CSS-Animation
// 将e转化为相对定位的元素,使得其可以左右移动 // 第一个参数为元素对象或者元素的id // 如果第二个参数是函数,以e为参数,它将在动画结束时调用 // 第三个参数指定e移动的距离,默认为5像素 // 第四个参数指定移动多久,默认500毫秒 function shake(e, oncomplete, distance, time) { // 句柄函数 if (typeof e === "string") e = document.getElemnentById(e); // 如果传入的是对象的id则获取对象的id,如果传入的为元素(元素为对象)则直接跳过这一句 if (!time) time = 500; // 如果time是空值,则直接使用默认值 if (!distance) distance = 5; // 如果未指定移动的距离,则默认为5像素 var originalStyle = e.style.cssText; // 获取元素e的css样式 e.style.position = "relative"; // 设置为相对定位 var start = (new Date()).getTime(); // 设置动画开始的时间,获取一个格林威治时间 animate(); // 动画开始 // 函数检查消耗时间,并更新e的位置 // 如果动画完成,它将e还原为原始状态 // 否则,将会更新e的位置,安排其自身重新运行 function animate() { var now = (new Date()).getTime(); // 获取现在的时间 var elapsed = now-start; // 从开始以来消耗了多长时间 var fraction = elapsed / time; // 为总时间的几分之几 if (fraction < 1) { // 如果动画未完成 // 作为动画完成比例的函数,计算e的x位置 // 使用正弦函数将完成比例乘以4pi // 所以,它将来回往返两次 var x = distance * Math.sin(fraction * 4 * Math.PI); // 使用正弦函数实现每秒四帧 e.style.left = x + "px"; // 在25毫秒后或在总时间的最后尝试再次运行函数 // 目的是为了产生每秒40帧动画 setTimeout(animate, Math.min(25, time-elapsed)); // 使用天花板函数再次调用,再次移动 } else { // 否则动画完成 e.style.cssText = originalStyle; // 恢复原始样式 if (oncomplete) oncomplete(e); // 产生一个回调函数 } } } // 以毫秒级的时间将e从完全不透明淡出到完全透明 // 在调用函数时假设e是完全不透明的 // oncomplete 是一个可选函数,以e为参数,它将在动画结束的时调用 // 如果不指定time,默认为500毫秒 function fadeOut(e, oncomplete, time) { if (typeof e === "string") e = document.getElementById(e); if (!time) time = 500; // 使用Math.sqrt作为一个缓动函数创建动画 // 非线性函数,一开始淡出的较快,然后逐步的缓慢 var ease = Math.sqrt; var start = (new Date()).getTime(); // 动画开始的时间 animate(); // 动画开始 function animate() { var elapsed = (new Date()).getTime()-start; // 消耗的时间 var fraction = elapsed/time; // 总时间的几分之几 if (fraction < 1) { // 如果动画未完成 var opacity = 1 - ease(fraction); // 计算不透明度 即 完成一次变换,开方 e.style.opacity = String(opacity); // 设置透明度 setTimeout(animate, // 进行下一帧 Math.min(25, time-elapsed)); // 在25毫秒之后或者在总时间的最后再次调用 }else { e.style.opacity = "0"; // 使得e完全透明 if (oncomplete) oncomplete(e); // 在结束的时候回调 } } }
Fragen Sie den berechneten Stil ab
getComputedStyle(e)
275 Stile. . . O__O "…
Skriptfähige CSS-Klassen
Zusätzlich zur Skripterstellung für Inline-Stile können Sie auch Skript-CSS-Klassen erstellen
Klassen entfernen und hinzufügen
e.className = "attention"; // 添加类 e.className = ""; // 移除类
Klasse anzeigen list
classList
Schreibgeschütztes Attribut, gibt eine Echtzeitsammlung von Elementklassenattributen zurück
e.classList()
Skriptfähiges Stylesheet
Stile ein- und ausschalten Das CSSStyleSheet-Objekt der
Stil- und Linkelemente definiert ein deaktiviertes Attribut, das in js festgelegt und abgefragt werden kann.
In Bezug auf das deaktivierte Attribut ist dieses Attribut nicht Teil der Spezifikation in HTML und nicht Teil des HTML Die Spezifikation ist vorhanden, das Attribut ist jedoch im DOM vorhanden. Dieses Attribut kann nicht in einem Tag, aber in einem Skript festgelegt werden.Wenn der Wert wahr ist, wird das Stylesheet geschlossen, andernfalls ist das Stylesheet aktiviert 🎜>
e.disabled = true;
document.styleSheets[0].disabled;
cssText ist der CSS-Textstil
Regeln hinzufügen und löschen
Es gibt auch eine addRule()-Methode
insertRule()-Methode
var firstRule = document.styleSheets[0].cssRules[0];
Nach dem Login kopieren
Fügen Sie im SS-Stylesheet eine CSS-Regel im 0. cssRules hinzu, um die Schriftart des Klassennamens blau zu machen var firstRule = document.styleSheets[0].cssRules[0];
wenn hinzugefügt. Wenn der Index bereits vorhanden ist, wird er nicht um 1 erhöht und dann
deleteRule()-Methode
Löschen Sie den zuletzt eingefügten Index Stil
ss.insertRule(".name {color:blue}", 0);
Löschen Sie die 0. Regel und der Stil beginnt weiterhin bei 0
auf die gleiche Weise. Die Bedienung von dom und bom erfordert keinen Stylesheet-Inhalt
Verwandte Empfehlungen:
Was schneller ist, CSS oder JS animation_html/css_WEB- ITnoseNachdem die CSS-Animation beendet ist, kann js den übersetzten Wert nicht ändern._html/css_WEB-ITnose
Das obige ist der detaillierte Inhalt vonWie schreibe ich CSS-Animationen in JS? Wie schreibe ich CSS-Animationen in JS (Code). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Die Verwendung von Bootstrap in Vue.js ist in fünf Schritte unterteilt: Startstrap installieren. Bootstrap in main.js. Verwenden Sie die Bootstrap -Komponente direkt in der Vorlage. Optional: benutzerdefinierter Stil. Optional: Verwenden Sie Plug-Ins.

HTML definiert die Webstruktur, CSS ist für Stil und Layout verantwortlich, und JavaScript ergibt eine dynamische Interaktion. Die drei erfüllen ihre Aufgaben in der Webentwicklung und erstellen gemeinsam eine farbenfrohe Website.

Es gibt zwei Möglichkeiten, eine Bootstrap -Split -Zeile zu erstellen: Verwenden des Tags, das eine horizontale Split -Linie erstellt. Verwenden Sie die CSS -Border -Eigenschaft, um benutzerdefinierte Style Split -Linien zu erstellen.

WebdevelopmentRelieSonHtml, CSS und JavaScript: 1) HtmlStructuresContent, 2) CSSstylesit und 3) JavaScriptaddssinteraktivität, Bildung von TheBasisofModerernwebexperiences.

Es gibt verschiedene Möglichkeiten, Bilder in Bootstrap einzufügen: Bilder direkt mit dem HTML -IMG -Tag einfügen. Mit der Bootstrap -Bildkomponente können Sie reaktionsschnelle Bilder und weitere Stile bereitstellen. Legen Sie die Bildgröße fest und verwenden Sie die IMG-Fluid-Klasse, um das Bild anpassungsfähig zu machen. Stellen Sie den Rand mit der img-beliebten Klasse ein. Stellen Sie die abgerundeten Ecken ein und verwenden Sie die IMG-Rund-Klasse. Setzen Sie den Schatten, verwenden Sie die Schattenklasse. Größen Sie die Größe und positionieren Sie das Bild im CSS -Stil. Verwenden Sie mit dem Hintergrundbild die CSS-Eigenschaft im Hintergrund.

Um das Bootstrap -Framework einzurichten, müssen Sie die folgenden Schritte befolgen: 1. Verweisen Sie die Bootstrap -Datei über CDN; 2. Laden Sie die Datei auf Ihrem eigenen Server herunter und hosten Sie sie. 3.. Fügen Sie die Bootstrap -Datei in HTML hinzu; 4. Kompilieren Sie Sass/weniger bei Bedarf; 5. Importieren Sie eine benutzerdefinierte Datei (optional). Sobald die Einrichtung abgeschlossen ist, können Sie die Grid -Systeme, -Komponenten und -stile von Bootstrap verwenden, um reaktionsschnelle Websites und Anwendungen zu erstellen.

Um die Größe der Elemente in Bootstrap anzupassen, können Sie die Dimensionsklasse verwenden, einschließlich: Einstellbreite:.

Wie benutze ich die Bootstrap -Taste? Führen Sie Bootstrap -CSS ein, um Schaltflächenelemente zu erstellen, und fügen Sie die Schaltfläche "Bootstrap" hinzu, um Schaltflächentext hinzuzufügen
