Jadual Kandungan
Tetapan lalai
init () kaedah
start () kaedah
stop () kaedah
isrunning () kaedah
Rumah hujung hadapan web tutorial js Membuat kesan teks berkedip dengan jQuery

Membuat kesan teks berkedip dengan jQuery

Feb 24, 2025 am 10:19 AM

Creating a Flashing Text Effect with jQuery

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.
Kadang -kadang, anda memerlukan beberapa kesan sejuk untuk meningkatkan rupa dan rasa laman web anda dan menarik perhatian pelawat anda. Terdapat banyak plugin percuma dan segera yang terdapat di pasaran untuk meningkatkan gaya laman web anda. Tutorial ini akan membimbing anda untuk membangunkan plugin jQuery penyemak imbas yang mencipta teks yang diletakkan secara rawak, berukuran secara rawak di dalam kawasan tertentu. Ia juga akan mempertimbangkan isu -isu kebolehaksesan (selepas semua, kita bercakap tentang teks berkelip), menyediakan kaedah

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: [], // 要显示的字符串数组
  fadeIn: 300, // 以毫秒为单位的时间
  duration: 500, // 以毫秒为单位的时间
  fadeOut: 300, // 以毫秒为单位的时间
  selection: "random" // 文本选择的顺序。可能的值:“random”、“ascending”、“descending”
};
Salin selepas log masuk
Salin selepas log masuk

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"));
}
Salin selepas log masuk
Salin selepas log masuk

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: [], // 要显示的字符串数组
  fadeIn: 300, // 以毫秒为单位的时间
  duration: 500, // 以毫秒为单位的时间
  fadeOut: 300, // 以毫秒为单位的时间
  selection: "random" // 文本选择的顺序。可能的值:“random”、“ascending”、“descending”
};
Salin selepas log masuk
Salin selepas log masuk

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"));
}
Salin selepas log masuk
Salin selepas log masuk

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("无效的方法调用:未指定设置");
    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() {
      // 删除当前元素
      $(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);
    });
  // 设置位置,以便元素适合区域的大小
  var posX = Math.floor(Math.random() * ($("#" + idElem).width() - $text.outerWidth()));
  var posY = Math.floor(Math.random() * ($("#" + idElem).height() - $text.outerHeight()));
  // 设置文本的位置
  $text.css({
    left: posX + "px",
    top: posY + "px"
  });
}
Salin selepas log masuk

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();
  // 恢复默认可见性
  this.children().css("visibility", "visible");
}
Salin selepas log masuk

Untuk menggunakan teks yang menjalankan kesan perenggan, anda hanya perlu melakukan perkara berikut:

isRunning: function() {
  return (this.children("span.audero-flashing-text").size() > 0);
}
Salin selepas log masuk

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>
Salin selepas log masuk

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!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apa yang perlu saya lakukan jika saya menghadapi percetakan kod yang dihiasi untuk resit kertas terma depan? Apa yang perlu saya lakukan jika saya menghadapi percetakan kod yang dihiasi untuk resit kertas terma depan? Apr 04, 2025 pm 02:42 PM

Soalan dan penyelesaian yang sering ditanya untuk percetakan tiket kertas terma depan dalam pembangunan front-end, percetakan tiket adalah keperluan umum. Walau bagaimanapun, banyak pemaju sedang melaksanakan ...

Demystifying JavaScript: Apa yang berlaku dan mengapa penting Demystifying JavaScript: Apa yang berlaku dan mengapa penting Apr 09, 2025 am 12:07 AM

JavaScript adalah asas kepada pembangunan web moden, dan fungsi utamanya termasuk pengaturcaraan yang didorong oleh peristiwa, penjanaan kandungan dinamik dan pengaturcaraan tak segerak. 1) Pengaturcaraan yang didorong oleh peristiwa membolehkan laman web berubah secara dinamik mengikut operasi pengguna. 2) Penjanaan kandungan dinamik membolehkan kandungan halaman diselaraskan mengikut syarat. 3) Pengaturcaraan Asynchronous memastikan bahawa antara muka pengguna tidak disekat. JavaScript digunakan secara meluas dalam interaksi web, aplikasi satu halaman dan pembangunan sisi pelayan, sangat meningkatkan fleksibiliti pengalaman pengguna dan pembangunan silang platform.

Siapa yang dibayar lebih banyak Python atau JavaScript? Siapa yang dibayar lebih banyak Python atau JavaScript? Apr 04, 2025 am 12:09 AM

Tidak ada gaji mutlak untuk pemaju Python dan JavaScript, bergantung kepada kemahiran dan keperluan industri. 1. Python boleh dibayar lebih banyak dalam sains data dan pembelajaran mesin. 2. JavaScript mempunyai permintaan yang besar dalam perkembangan depan dan stack penuh, dan gajinya juga cukup besar. 3. Faktor mempengaruhi termasuk pengalaman, lokasi geografi, saiz syarikat dan kemahiran khusus.

Bagaimana untuk mencapai kesan menatal paralaks dan kesan animasi elemen, seperti laman web rasmi Shiseido?
atau:
Bagaimanakah kita dapat mencapai kesan animasi yang disertai dengan menatal halaman seperti laman web rasmi Shiseido? Bagaimana untuk mencapai kesan menatal paralaks dan kesan animasi elemen, seperti laman web rasmi Shiseido? atau: Bagaimanakah kita dapat mencapai kesan animasi yang disertai dengan menatal halaman seperti laman web rasmi Shiseido? Apr 04, 2025 pm 05:36 PM

Perbincangan mengenai realisasi kesan animasi tatal dan elemen Parallax dalam artikel ini akan meneroka bagaimana untuk mencapai yang serupa dengan laman web rasmi Shiseido (https://www.shiseido.co.jp/sb/wonderland/) ... ...

Evolusi JavaScript: Trend Semasa dan Prospek Masa Depan Evolusi JavaScript: Trend Semasa dan Prospek Masa Depan Apr 10, 2025 am 09:33 AM

Trend terkini dalam JavaScript termasuk kebangkitan TypeScript, populariti kerangka dan perpustakaan moden, dan penerapan webassembly. Prospek masa depan meliputi sistem jenis yang lebih berkuasa, pembangunan JavaScript, pengembangan kecerdasan buatan dan pembelajaran mesin, dan potensi pengkomputeran IoT dan kelebihan.

Adakah JavaScript sukar belajar? Adakah JavaScript sukar belajar? Apr 03, 2025 am 12:20 AM

Pembelajaran JavaScript tidak sukar, tetapi ia mencabar. 1) Memahami konsep asas seperti pembolehubah, jenis data, fungsi, dan sebagainya. 2) Pengaturcaraan asynchronous tuan dan melaksanakannya melalui gelung acara. 3) Gunakan operasi DOM dan berjanji untuk mengendalikan permintaan tak segerak. 4) Elakkan kesilapan biasa dan gunakan teknik debugging. 5) Mengoptimumkan prestasi dan mengikuti amalan terbaik.

Bagaimana untuk menggabungkan elemen array dengan ID yang sama ke dalam satu objek menggunakan JavaScript? Bagaimana untuk menggabungkan elemen array dengan ID yang sama ke dalam satu objek menggunakan JavaScript? Apr 04, 2025 pm 05:09 PM

Bagaimana cara menggabungkan elemen array dengan ID yang sama ke dalam satu objek dalam JavaScript? Semasa memproses data, kita sering menghadapi keperluan untuk mempunyai id yang sama ...

Bagaimana untuk melaksanakan fungsi seretan panel dan drop pelarasan yang serupa dengan vscode dalam pembangunan front-end? Bagaimana untuk melaksanakan fungsi seretan panel dan drop pelarasan yang serupa dengan vscode dalam pembangunan front-end? Apr 04, 2025 pm 02:06 PM

Terokai pelaksanaan fungsi seretan panel dan drop panel seperti VSCode di bahagian depan. Dalam pembangunan front-end, bagaimana untuk melaksanakan vscode seperti ...

See all articles