Rumah > hujung hadapan web > tutorial css > Bagaimanakah Saya Boleh Mengesan dan Mengendalikan Peristiwa Tamat Peralihan CSS3 Merentasi Pelayar Berbeza?

Bagaimanakah Saya Boleh Mengesan dan Mengendalikan Peristiwa Tamat Peralihan CSS3 Merentasi Pelayar Berbeza?

Linda Hamilton
Lepaskan: 2024-12-04 21:41:13
asal
574 orang telah melayarinya

How Can I Reliably Detect and Handle CSS3 Transition End Events Across Different Browsers?

Penormalan Merentas Penyemak Imbas Peristiwa Tamat Peralihan CSS3

Berurusan dengan nama acara penamat peralihan CSS3 yang berbeza merentas penyemak imbas boleh menjadi satu cabaran. Berikut ialah beberapa pendekatan untuk menangani isu ini:

Penghidu Penyemak Imbas

Satu pendekatan ialah menghidu penyemak imbas, seperti yang ditunjukkan di bawah:

var transitionend = (isSafari) ? "webkitTransitionEnd" : (isFirefox) ? "transitionEnd" : (isOpera) ? "oTransitionEnd" : "transitionend";

element.addEventListener(transitionend, function() {
  // Do something
}, false);
Salin selepas log masuk

Kaedah ini menyemak ejen pengguna penyemak imbas tertentu dan memberikan nama acara yang sesuai. Walau bagaimanapun, ia bergantung pada peraturan yang dipratentukan khusus dan mungkin tidak mengambil kira semua versi penyemak imbas atau kemungkinan variasi.

Berbilang Pendengar Acara

Sebagai alternatif, anda boleh melampirkan berbilang pendengar acara untuk setiap nama acara penyemak imbas yang disokong:

element.addEventListener("webkitTransitionEnd", fn);
element.addEventListener("oTransitionEnd", fn);
element.addEventListener("transitionEnd", fn);

function fn() {
  // Do something
}
Salin selepas log masuk

Pendekatan ini mengendalikan semua acara yang disokong tetapi mungkin membawa kepada yang tidak perlu overhed pengendalian acara.

Teknik Modernizr yang Diperbaiki

Pendekatan yang lebih mantap dan mesra penyemak imbas adalah untuk menentukan secara dinamik nama acara akhir peralihan menggunakan perpustakaan Modernizr:

function transitionEndEventName() {
  var el = document.createElement('div'),
      transitions = {
        'transition':'transitionend',
        'OTransition':'otransitionend',
        'MozTransition':'transitionend',
        'WebkitTransition':'webkitTransitionEnd'
      };

  for (var i in transitions) {
    if (transitions.hasOwnProperty(i) && el.style[i] !== undefined) {
      return transitions[i];
    }
  }

  throw 'TransitionEnd event is not supported in this browser'; 
}

var transitionEnd = transitionEndEventName();
element.addEventListener(transitionEnd, theFunctionToInvoke, false);
Salin selepas log masuk

Teknik ini mengelakkan daripada menghidu penyemak imbas dan mengesan acara yang disokong secara dinamik nama berdasarkan sifat CSS yang disokong elemen.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengesan dan Mengendalikan Peristiwa Tamat Peralihan CSS3 Merentasi Pelayar Berbeza?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan