Foundation - Utilitas JavaScript
Foundation mencakup utilitas JavaScript yang digunakan untuk menambahkan fungsionalitas umum. Ini sangat membantu dan mudah digunakan. Pustaka utilitas JavaScript ini dapat ditemukan di folder Your_folder_name / node_modules / foundation-sites / js
Kotak
Perpustakaan Foundation.Box terdiri dari beberapa metode.
Itu js/foundation.util.box.js adalah nama file skrip, yang dapat disertakan saat menulis kode.
Objek jQuery atau elemen JavaScript biasa dapat diteruskan ke kedua metode.
var dims = Foundation.Box.GetDimensions(element);
Objek yang dikembalikan menentukan dimensi elemen sebagai -
{
height: 54,
width: 521,
offset: {
left: 198,
top: 1047
},
parentDims: {
height: ... //The same format is share for parentDims and windowDims as the element dimensions.
},
windowDims: {
height: ...
}
}
Fungsi ImNotTouchingYou disertakan.
Berdasarkan elemen yang diteruskan, nilai Boolean dikembalikan, yang merupakan konflik dengan edge jendela atau opsional atau elemen induk.
Dua opsi yang ditentukan dalam baris yang diberikan di bawah ini yaitu leftAndRightOnly, topAndBottomOnly digunakan untuk mengidentifikasi tabrakan hanya pada satu sumbu.
var clear = Foundation.Box.ImNotTouchingYou (
element [, parent, leftAndRightOnly, topAndBottomOnly]);
Papan ketik
Ada banyak metode dalam Foundation.Keyboard , yang membantu mempermudah interaksi acara keyboard.
Itu js/foundation.util.keyboard.js adalah nama file skrip, yang dapat disertakan saat menulis kode.
Objek Foundation.Keyboard.keys terdiri dari pasangan kunci / nilai, kunci mana yang lebih sering digunakan dalam kerangka kerja.
Setiap kali tombol ditekan maka Foundation.Keyboard.parseKey dipanggil untuk mendapatkan string. Ini membantu mengelola input keyboard Anda sendiri.
Kode berikut digunakan untuk menemukan semua elemen yang dapat difokuskan dalam elemen $ yang diberikan . Oleh karena itu, Anda tidak perlu menulis fungsi dan pemilih apa pun.
var focusable = Foundation.Keyboard.findFocusable($('#content'));
Fungsi handleKey adalah fungsi utama dari perpustakaan ini.
Metode ini digunakan untuk menangani acara keyboard; itu dapat dipanggil setiap kali ada plugin yang terdaftar dengan utilitas.
Foundation.Keyboard.register('pluginName', {
'TAB': 'next'
});
...//in event callback
Foundation.Keyboard.handleKey(event, 'pluginName', {
next: function(){
//do stuff
}
});
Fungsi Foundation.Keyboard.register dapat dipanggil saat Anda ingin menggunakan key binding Anda sendiri.
MediaQuery
Pustaka MediaQuery adalah tulang punggung dari semua teknik CSS responsif.
Itu js/foundation.util.mediaQuery.js adalah nama file skrip, yang dapat disertakan saat menulis kode.
The Foundation.MediaQuery.atLeast ( 'besar') digunakan untuk memeriksa apakah layar setidaknya selebar breakpoint.
The Foundation.MediaQuery.get ( 'menengah') mendapat permintaan media breakpoint.
The Foundation.MediaQuery.queries adalah sebuah array dari pertanyaan media, Yayasan menggunakan untuk breakpoints.
The Foundation.MediaQuery.current adalah string ukuran breakpoint saat ini.
Foundation.MediaQuery.get('medium');
Foundation.MediaQuery.atLeast('large');
Foundation.MediaQuery.queries;
Foundation.MediaQuery.current;
Kode berikut menyiarkan perubahan kueri media di jendela.
$(window).on('changed.zf.mediaquery', function(event, newSize, oldSize){});
Gerak & Pindah
JavaScript Foundation.Motion mirip dengan library Motion UI, yang disertakan dalam Foundation 6. Ini digunakan untuk membuat transisi dan animasi CSS kustom.
Itu js/foundation.util.motion.js adalah nama file skrip, yang dapat disertakan saat menulis kode.
Foundation.Move digunakan untuk membuat animasi yang didukung CSS3 menjadi sederhana dan elegan.
requestAnimationFrame();metode memberitahu browser untuk melakukan animasi; itu meminta agar fungsi animasi Anda dipanggil sebelum browser melakukan pengecatan ulang berikutnya.
Foundation.Move(durationInMS, $element, function() {
//animation logic
});
Saat animasi selesai, finish.zf.animate diaktifkan.
Timer & Gambar Dimuat
Orbit menggunakan keduanya, fungsi pengatur waktu dan gambar yang dimuat. Itujs/foundation.util.timerAndImageLoader.js adalah nama file skrip, yang dapat disertakan saat menulis kode.
var timer = new Foundation.Timer($element, {duration: ms, infinite: bool}, callback);
Metode pemuatan gambar menjalankan fungsi panggilan balik dalam koleksi jQuery Anda saat gambar dimuat sepenuhnya.
Foundation.onImagesLoaded($images, callback);
Menyentuh
Metode ini digunakan untuk menambahkan acara seret semu dan menggesek ke elemen.
Itu js/foundation.util.touch.js adalah nama file skrip, yang dapat disertakan saat menulis kode.
The addTouch metode yang digunakan untuk elemen mengikat menyentuh peristiwa di plugin Slider untuk perangkat mobile.
The spotSwipe metode mengikat unsur-unsur peristiwa menggesek di plugin Orbit untuk perangkat mobile.
$('selector').addTouch().on('mousemove', handleDrag);
$('selector').spotSwipe().on('swipeleft', handleLeftSwipe);
Pemicu
Ini memicu acara tertentu untuk elemen yang dipilih.
Itu js/foundation.util.triggers.js adalah nama file skrip, yang dapat disertakan saat menulis kode.
Pemicu digunakan di banyak plugin Foundation.
$('selector').on('open.zf.trigger', handleOpen);
$('selector').on('close.zf.trigger', handleClose);
$('selector').on('toggle.zf.trigger', handleToggle);
Dua metode berikut digunakan dalam pustaka ini yaitu mengubah ukuran dan menggulir.
Metode resize () memicu peristiwa pengubahan ukuran ketika peristiwa pengubahan ukuran terjadi.
Metode scroll () memicu peristiwa scroll saat peristiwa scroll terjadi.
$('#someId').on('scrollme.zf.trigger', handleScroll);
$('#someId').on('resizeme.zf.trigger', handleResize);
Miscellaneous
Foundation berisi beberapa fitur di pustaka inti, yang digunakan di banyak tempat.
Itu js/foundation.core.js adalah nama file skrip, yang dapat disertakan saat menulis kode.
Foundation.GetYoDigits ([number, namespace]) mengembalikan uid base-36 acak dengan namespacing. Ini mengembalikan panjang string 6 karakter secara default.
Foundation.getFnName (fn) mengembalikan nama fungsi JavaScript.
Foundation.transitionend terjadi ketika transisi CSS selesai.