mata teras
- Tutorial ini membimbing anda bagaimana untuk membuat plugin jQuery yang serasi dengan penyemak imbas yang mencapai kesan teks yang berkelip dan meningkatkan gaya laman web dan rayuan. Plug-in juga menganggap isu aksesibiliti dan menyediakan kesan berhenti
- .
stop()
Plugin ini dinamakan "Audero Flashing Text" dan dibangunkan mengikut amalan terbaik plugin jQuery. Ia mengandungi tetapan lalai, permulaan, permulaan, berhenti, dan - kaedah. Kaedah ini mengawal teks untuk dipaparkan, pudar, tempoh, memudar masa, dan urutan di mana pemilihan teks dipilih.
isRunning
Kaedah - adalah bahagian paling kritikal dari plugin kerana ia menjalankan kesannya. Ia melibatkan mewujudkan elemen yang terapung di dalam kawasan yang ditentukan, fungsi
start()
membuang elemen yang dibuat dari DOM, dan kemudian menjalankan kesannya semula berdasarkan konfigurasi semasa menggunakan rentetan seterusnya, sebelumnya, atau rawak.fadeOut()
Tutorial berakhir dengan contoh menggunakan plugin dan menyesuaikan tetapan seperti masa pudar dan pesanan pemilihan teks. Plugin "Audero Flashing Text" adalah percuma dan boleh diubah suai atau diperbaiki di bawah lesen dua MIT dan GPL-3.0.
untuk menghentikan kesannya. Plugin ini membolehkan pelbagai animasi pada halaman yang sama, dan setiap animasi sepenuhnya bebas daripada animasi lain. Hasil akhir akan menjadi fail JavaScript yang anda boleh dengan mudah disertakan di halaman anda. Untuk membuat plugin ini, saya akan mengikuti garis panduan yang dicadangkan oleh plugin jQuery, jadi ia akan dibangunkan menggunakan amalan terbaik plugin jQuery. Saya telah menggariskan topik ini dalam jawatan saya "Melaksanakan menu konteks silang pelayar sebagai plugin jQuery". Juga ambil perhatian bahawa mulai sekarang, saya merujuk kepada plugin sebagai "Audero Flashing Text". stop()
Mula
Sekarang saya telah menunjukkan kepada anda titik permulaan "Audero Flashing Text", anda perlu memahami kaedah yang akan disertakan. Tidak sukar untuk membayangkan bahawa anda memerlukan kaedah untuk memulakan plugin dan kaedah untuk memulakan kesannya. Fungsi permulaan akan mengambil kesempatan daripada beberapa nilai lalai, yang akan digunakan jika tiada nilai tertentu ditetapkan. Di samping itu, seperti yang dinyatakan dalam bahagian sebelumnya, keupayaan untuk memberi pengguna kesan berhenti akan menjadi baik. Akhir sekali, mempunyai cara untuk menguji sama ada kesannya berjalan boleh berguna. Oleh itu, plugin akan mengandungi perkara berikut:- Tetapan lalai
-
init()
kaedah -
start()
kaedah -
stop()
kaedah -
isRunning()
kaedah
Tetapan lalai
Ia sentiasa berguna untuk mempunyai konfigurasi lalai tertentu jika tiada pengguna menentukan tetapan tertentu. Harta utama "Audero Flashing Text" adalah set teks yang akan dipaparkan, yang boleh anda tentukan menggunakan array. Kerana kita akan mempunyai teks yang berkelip, tindakan yang akan dilakukan teks adalah: 1. Perlahan -lahan menjadi kelihatan, 2. Tetap kelihatan untuk seketika, dan 3. Perlahan -lahan hilang. Berdasarkan tingkah laku ini, tetapan berguna yang lain adalah masa, tempoh, dan masa pudar. Tetapan terakhir yang akan kami tambahkan ialah pemilihan, yang akan membolehkan pengguna memilih pesanan di mana pemilihan teks dipilih. Nilai yang mungkin untuk selection
adalah random
, ascending
dan descending
. Tukar semua teks ini ke dalam kod, dan hasilnya adalah seperti berikut:
var defaultValues = { strings: [], // 要顯示的字符串?dāng)?shù)組 fadeIn: 300, // 以毫秒為單位的時(shí)間 duration: 500, // 以毫秒為單位的時(shí)間 fadeOut: 300, // 以毫秒為單位的時(shí)間 selection: "random" // 文本選擇的順序??赡艿闹担骸皉andom”、“ascending”、“descending” };
init () kaedah
kami akan menggunakan kaedah init()
untuk menguji bagaimana plugin dipanggil dan gaya kawasan di mana kami akan menjalankan kesannya. Ia hanya menerima satu parameter, objek, yang mengandungi sekurang -kurangnya pelbagai rentetan yang akan dipaparkan, tetapi juga mengandungi nilai yang akan mengatasi nilai lalai. Sebagai alternatif, fungsi boleh dipanggil tanpa parameter, di mana nilai lalai akan digunakan. Dalam kes ini, set rentetan yang akan dipaparkan akan menggunakan teks nod kanak -kanak elemen yang dipilih. Kaedah yang terakhir membolehkan anda mula bereksperimen dengan plugin dengan segera. Selepas ujian, kaedah init()
akan menggunakan atribut CSS visibility
untuk menyembunyikan elemen kanak -kanak elemen yang dipilih, jadi ketinggian kawasan tidak berkurangan. Pada ketika ini, perkara terakhir yang perlu dilakukan ialah memanggil fungsi start()
untuk menjalankan animasi. Kod untuk init()
adalah seperti berikut:
init: function(options) { if (typeof options === "undefined" || options === null) { options = {}; } if (typeof options.strings === "undefined" || options.strings == null) { if (this.children().size() === 0) { $.error("如果您沒(méi)有指定要顯示的文本,則該元素必須至少有一個(gè)子元素"); return; } else { options.strings = this.children().map(function() { return $(this).text(); }); } } this.css("position", "relative"); this.children().css("visibility", "hidden"); methods.start($.extend({}, defaultValues, options), null, this.attr("id")); }
start () kaedah
Ini adalah bahagian paling penting dalam plugin kerana ia mengandungi kod yang sebenarnya menjalankan kesannya. Ia menerima tiga parameter berikut:
-
settings
- Konfigurasi objek. -
index
- rentetan yang akan dipaparkan. -
idElem
- ID kawasan di mana kesannya digunakan.
Sama seperti kaedah init()
, ia pertama kali menguji parameter. Selepas itu, ia mewujudkan elemen <span>
yang akan terapung di kawasan yang ditentukan. Selepas penciptaan, elemen tidak kelihatan (display: none
), jadi ia boleh kelihatan perlahan menggunakan kaedah pudar. Seperti yang akan anda lihat kemudian, fungsi fadeOut()
mempunyai fungsi panggil balik yang akan mengeluarkan elemen yang dibuat dari DOM dan kemudian menjalankan kesannya semula berdasarkan konfigurasi semasa menggunakan rentetan seterusnya, sebelumnya, atau rawak. Beberapa baris terakhir kaedah menetapkan kedudukan supaya elemen sesuai dengan saiz rantau ini.
var defaultValues = { strings: [], // 要顯示的字符串?dāng)?shù)組 fadeIn: 300, // 以毫秒為單位的時(shí)間 duration: 500, // 以毫秒為單位的時(shí)間 fadeOut: 300, // 以毫秒為單位的時(shí)間 selection: "random" // 文本選擇的順序??赡艿闹担骸皉andom”、“ascending”、“descending” };
stop () kaedah
Kaedah stop()
digunakan untuk menghentikan animasi, keluarkan elemen <span>
yang terakhir dibuat dari DOM, dan kemudian pulihkan atribut penglihatan biasa. Seperti yang anda lihat dalam kod sumber di bawah, teks akan dikeluarkan dengan lancar. Kaedah ini mula -mula menghentikan animasi (jQuery stop()
kaedah), kemudian memudar teks, menyebabkan ia perlahan -lahan hilang dari skrin (jQuery fadeOut()
kaedah), dan kemudian menghilangkannya dari kaedah DOM (jQuery remove()
) .
init: function(options) { if (typeof options === "undefined" || options === null) { options = {}; } if (typeof options.strings === "undefined" || options.strings == null) { if (this.children().size() === 0) { $.error("如果您沒(méi)有指定要顯示的文本,則該元素必須至少有一個(gè)子元素"); return; } else { options.strings = this.children().map(function() { return $(this).text(); }); } } this.css("position", "relative"); this.children().css("visibility", "hidden"); methods.start($.extend({}, defaultValues, options), null, this.attr("id")); }
isrunning () kaedah
Kaedah ini mudah difahami kerana ia hanya menguji sama ada elemen yang diberikan menjalankan kesan berkedip. Proses ujian menyemak elemen audero-flashing-text
kelas <span>
. Jika sekurang -kurangnya satu elemen dijumpai, kaedah pulangan true
, jika tidak, ia kembali false
. Kod yang dijelaskan adalah seperti berikut:
start: function(settings, index, idElem) { if (typeof idElem === "undefined") { idElem = this.selector; } if (typeof settings === "undefined") { $.error("無(wú)效的方法調(diào)用:未指定設(shè)置"); return; } if (index == null) { if (settings.selection === "ascending") index = 0; else if (settings.selection === "descending") index = settings.strings.length - 1; else index = Math.floor(Math.random() * settings.strings.length); } var $text = $("<span>") .text(settings.strings[index]) .addClass("audero-flashing-text") // 這用作書(shū)簽,以幫助停止方法 .css({ position: "absolute", display: "none", fontSize: (Math.random() * 2 + 0.5) + "em" }) .appendTo("#" + idElem) .fadeIn(settings.fadeIn) .animate({ opacity: 1 }, settings.duration) // 模擬延遲 .fadeOut(settings.fadeOut, function() { // 刪除當(dāng)前元素 $(this).remove(); var nextIndex; if (settings.selection === "ascending") nextIndex = (index + 1) % settings.strings.length; else if (settings.selection === "descending") nextIndex = (index === 0) ? settings.strings.length : index - 1; else nextIndex = Math.floor(Math.random() * settings.strings.length); // 再次啟動(dòng)效果 methods.start(settings, nextIndex, idElem); }); // 設(shè)置位置,以便元素適合區(qū)域的大小 var posX = Math.floor(Math.random() * ($("#" + idElem).width() - $text.outerWidth())); var posY = Math.floor(Math.random() * ($("#" + idElem).height() - $text.outerHeight())); // 設(shè)置文本的位置 $text.css({ left: posX + "px", top: posY + "px" }); }
Cara menggunakan plugin ini
Sekarang anda telah melihat semua kaedah, sudah tiba masanya untuk menyemak beberapa contoh. Katakan anda mempunyai yang berikut <div>
:
stop: function() { this.css("position", "inherit"); // 刪除浮動(dòng)文本 this .children("span.audero-flashing-text") .stop(true) .fadeOut(defaultValues.fadeOut) .remove(); // 恢復(fù)默認(rèn)可見(jiàn)性 this.children().css("visibility", "visible"); }
Untuk menggunakan teks yang menjalankan kesan perenggan, anda hanya perlu melakukan perkara berikut:
isRunning: function() { return (this.children("span.audero-flashing-text").size() > 0); }
Berikut adalah contoh menggunakan tag yang sama seperti sebelumnya tetapi dengan tetapan yang berbeza:
<div id="box"> <p>Lorem</p> <p>Ipsum</p> <p>Dolor</p> <p>Sit</p> <p>Amet</p> </div>
Kesimpulan
Artikel ini menunjukkan kepada anda bagaimana untuk membuat plugin jQuery yang menghasilkan kesan teks yang berkelip di kawasan tertentu. Untuk melihat bagaimana ia berfungsi, muat turun kod sumber dan lihat dokumentasi yang dimasukkan ke dalam repositori. Plugin "Audero Flashing Text" adalah percuma. Anda juga boleh mengubahnya atau memperbaikinya kerana ia mempunyai lesen dua untuk MIT dan GPL-3.0.
(Soalan Lazim) harus ditambah di sini untuk membuat kesan teks berkedip menggunakan jQuery, selaras dengan bahagian FAQ dari teks input, tetapi beberapa penulisan dan penyebaran dapat dilakukan untuk menjadikannya lebih ringkas dan jelas.
Atas ialah kandungan terperinci Membuat kesan teks berkedip dengan jQuery. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Mekanisme pengumpulan sampah JavaScript secara automatik menguruskan memori melalui algoritma pembersihan tag untuk mengurangkan risiko kebocoran ingatan. Enjin melintasi dan menandakan objek aktif dari objek akar, dan tidak bertanda dianggap sebagai sampah dan dibersihkan. Sebagai contoh, apabila objek tidak lagi dirujuk (seperti menetapkan pembolehubah kepada null), ia akan dikeluarkan dalam pusingan seterusnya kitar semula. Punca kebocoran memori yang biasa termasuk: ① Pemasa atau pendengar peristiwa yang tidak jelas; ② Rujukan kepada pembolehubah luaran dalam penutupan; ③ Pembolehubah global terus memegang sejumlah besar data. Enjin V8 mengoptimumkan kecekapan kitar semula melalui strategi seperti kitar semula generasi, penandaan tambahan, kitar semula selari/serentak, dan mengurangkan masa menyekat benang utama. Semasa pembangunan, rujukan global yang tidak perlu harus dielakkan dan persatuan objek harus dihiasi dengan segera untuk meningkatkan prestasi dan kestabilan.

Terdapat tiga cara biasa untuk memulakan permintaan HTTP dalam node.js: Gunakan modul terbina dalam, axios, dan nod-fetch. 1. Gunakan modul HTTP/HTTPS terbina dalam tanpa kebergantungan, yang sesuai untuk senario asas, tetapi memerlukan pemprosesan manual jahitan data dan pemantauan ralat, seperti menggunakan https.get () untuk mendapatkan data atau menghantar permintaan pos melalui .write (); 2.AXIOS adalah perpustakaan pihak ketiga berdasarkan janji. Ia mempunyai sintaks ringkas dan fungsi yang kuat, menyokong async/menunggu, penukaran JSON automatik, pemintas, dan lain -lain. Adalah disyorkan untuk memudahkan operasi permintaan tak segerak; 3.Node-Fetch menyediakan gaya yang serupa dengan pengambilan penyemak imbas, berdasarkan janji dan sintaks mudah

Jenis data JavaScript dibahagikan kepada jenis primitif dan jenis rujukan. Jenis primitif termasuk rentetan, nombor, boolean, null, undefined, dan simbol. Nilai -nilai tidak berubah dan salinan disalin apabila memberikan nilai, jadi mereka tidak mempengaruhi satu sama lain; Jenis rujukan seperti objek, tatasusunan dan fungsi menyimpan alamat memori, dan pembolehubah menunjuk objek yang sama akan mempengaruhi satu sama lain. Typeof dan Instanceof boleh digunakan untuk menentukan jenis, tetapi memberi perhatian kepada isu -isu sejarah TypeOfNull. Memahami kedua -dua jenis perbezaan ini dapat membantu menulis kod yang lebih stabil dan boleh dipercayai.

Helo, pemaju JavaScript! Selamat datang ke berita JavaScript minggu ini! Minggu ini kami akan memberi tumpuan kepada: Pertikaian tanda dagangan Oracle dengan Deno, objek masa JavaScript baru disokong oleh pelayar, kemas kini Google Chrome, dan beberapa alat pemaju yang kuat. Mari mulakan! Pertikaian tanda dagangan Oracle dengan percubaan Deno Oracle untuk mendaftarkan tanda dagangan "JavaScript" telah menyebabkan kontroversi. Ryan Dahl, pencipta Node.js dan Deno, telah memfailkan petisyen untuk membatalkan tanda dagangan, dan dia percaya bahawa JavaScript adalah standard terbuka dan tidak boleh digunakan oleh Oracle

Rangka kerja JavaScript mana yang terbaik? Jawapannya ialah memilih yang paling sesuai mengikut keperluan anda. 1. REACT adalah fleksibel dan bebas, sesuai untuk projek sederhana dan besar yang memerlukan penyesuaian tinggi dan keupayaan seni bina pasukan; 2. Angular menyediakan penyelesaian lengkap, sesuai untuk aplikasi peringkat perusahaan dan penyelenggaraan jangka panjang; 3. Vue mudah digunakan, sesuai untuk projek kecil dan sederhana atau perkembangan pesat. Di samping itu, sama ada terdapat timbunan teknologi sedia ada, saiz pasukan, kitaran hayat projek dan sama ada SSR diperlukan juga faktor penting dalam memilih rangka kerja. Singkatnya, tidak ada kerangka terbaik, pilihan terbaik adalah yang sesuai dengan keperluan anda.

IIFE (Segera Dilanjutkan FunctionExpression) adalah ekspresi fungsi yang dilaksanakan dengan segera selepas definisi, digunakan untuk mengasingkan pembolehubah dan mengelakkan mencemarkan skop global. Ia dipanggil dengan membungkus fungsi dalam kurungan untuk menjadikannya ungkapan dan sepasang kurungan segera diikuti olehnya, seperti (fungsi () {/code/}) ();. Penggunaan terasnya termasuk: 1. Elakkan konflik berubah -ubah dan mencegah pertindihan penamaan antara skrip berganda; 2. Buat skop peribadi untuk menjadikan pembolehubah dalaman tidak kelihatan; 3. Kod modular untuk memudahkan permulaan tanpa mendedahkan terlalu banyak pembolehubah. Kaedah penulisan biasa termasuk versi yang diluluskan dengan parameter dan versi fungsi anak panah ES6, tetapi perhatikan bahawa ungkapan dan ikatan mesti digunakan.

Janji adalah mekanisme teras untuk mengendalikan operasi tak segerak dalam JavaScript. Memahami panggilan rantaian, pengendalian ralat dan gabungan adalah kunci untuk menguasai aplikasi mereka. 1. Panggilan rantai mengembalikan janji baru melalui .then () untuk merealisasikan persamaan proses tak segerak. Setiap .then () menerima hasil sebelumnya dan boleh mengembalikan nilai atau janji; 2. Pengendalian ralat harus menggunakan .catch () untuk menangkap pengecualian untuk mengelakkan kegagalan senyap, dan boleh mengembalikan nilai lalai dalam tangkapan untuk meneruskan proses; 3. Gabungan seperti janji.all () (berjaya hanya berjaya selepas semua kejayaan), janji.race () (penyempurnaan pertama dikembalikan) dan janji.allsettled () (menunggu semua penyelesaian)

CACHEAPI adalah alat yang disediakan oleh penyemak imbas kepada permintaan rangkaian cache, yang sering digunakan bersempena dengan ServiceWorker untuk meningkatkan prestasi laman web dan pengalaman luar talian. 1. Ia membolehkan pemaju menyimpan sumber secara manual seperti skrip, helaian gaya, gambar, dan lain -lain; 2. Ia boleh memadankan tindak balas cache mengikut permintaan; 3. Ia menyokong memotong cache tertentu atau membersihkan seluruh cache; 4. Ia boleh melaksanakan keutamaan cache atau strategi keutamaan rangkaian melalui perkhidmatan pekerja yang mendengar acara mengambil; 5. Ia sering digunakan untuk sokongan luar talian, mempercepat kelajuan akses berulang, sumber utama dan kandungan kemas kini latar belakang; 6. Apabila menggunakannya, anda perlu memberi perhatian kepada kawalan versi cache, sekatan penyimpanan dan perbezaan dari mekanisme caching HTTP.
