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, // 以毫秒為單位的時間 duration: 500, // 以毫秒為單位的時間 fadeOut: 300, // 以毫秒為單位的時間 selection: "random" // 文本選擇的順序。可能的值:“random”、“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("如果您沒有指定要顯示的文本,則該元素必須至少有一個子元素"); 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, // 以毫秒為單位的時間 duration: 500, // 以毫秒為單位的時間 fadeOut: 300, // 以毫秒為單位的時間 selection: "random" // 文本選擇的順序。可能的值:“random”、“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("如果您沒有指定要顯示的文本,則該元素必須至少有一個子元素"); 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("無效的方法調(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") // 這用作書簽,以幫助停止方法 .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); // 再次啟動效果 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"); // 刪除浮動文本 this .children("span.audero-flashing-text") .stop(true) .fadeOut(defaultValues.fadeOut) .remove(); // 恢復(fù)默認(rè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

JavaScriptisidealForWebDevelopment, whersjavasuitslarge-scaleapplicationsandandroiddevelopment.1) javascriptexcelsincreatinginteractivewebexperiencesandfull-stackdevelopmentwithnode.js.2)

Dalam JavaScript, memilih satu-satunya komen (//) atau ulasan multi-line (//) bergantung kepada keperluan dan keperluan projek komen: 1. Gunakan komen satu baris untuk tafsiran cepat dan sebaris; 2. Gunakan komen berbilang baris untuk dokumentasi terperinci; 3. Mengekalkan konsistensi gaya komen; 4. Elakkan daripada annotasi; 5. Pastikan komen dikemas kini secara serentak dengan kod. Memilih gaya anotasi yang betul dapat membantu meningkatkan kebolehbacaan dan pemeliharaan kod anda.

Ya, JavaScriptcommentsareneraryAnderyShouldbeusedefectively.1) theguedevelopersthroughcodelogicandIntent, 2) arevitalincomplexprojects, and3) couldenhanceclaritywithoutclutterthecode.

JavaScriptcommentsareessentialformaintaining,reading,andguidingcodeexecution.1)Single-linecommentsareusedforquickexplanations.2)Multi-linecommentsexplaincomplexlogicorprovidedetaileddocumentation.3)Inlinecommentsclarifyspecificpartsofcode.Bestpractic

Java dan JavaScript adalah bahasa pengaturcaraan yang berbeza, masing -masing sesuai untuk senario aplikasi yang berbeza. Java digunakan untuk pembangunan aplikasi perusahaan dan mudah alih yang besar, sementara JavaScript digunakan terutamanya untuk pembangunan laman web.

Commentsarecrucialinjavascriptformaintainingclarityandfosteringcollaboration.1) theyhelpindebugging, onboarding, andunderstandingcodeevolution.2) menggunakan-linecommentsforquickexplanationsandmulti-linecommentsfordetaileddescriptions.3)

Javascripthasseveralprimitivedatatypes: nombor, rentetan, boolean, undefined, null, simbol, andbigint, dan non-primitivetypesliikeobjectandarray.UnderstheseiscialfritingFritingefisien, bug-freecode: 1) numberusesa64-fitformat, pemimpin-fitformat, pemimpin-fitformat

JavaScriptispreferredforwebdevelopment, whersjavaisbetterforlarge-scalebackendsystemsandandroidapps.1) javascriptexcelsinceleatinginteractiveWebexperienceswithitsdynamicnatureanddommanipulation.2) javaoffersstrongyblectionandobjection
