Foundation - ยูทิลิตี้ JavaScript
Foundation ประกอบด้วยยูทิลิตี้ JavaScript ที่ใช้เพื่อเพิ่มฟังก์ชันทั่วไป มีประโยชน์มากและใช้งานง่าย ไลบรารียูทิลิตี้ JavaScript นี้สามารถพบได้ในโฟลเดอร์Your_folder_name / node_modules / foundation-sites / js
กล่อง
ห้องสมุดFoundation.Boxประกอบด้วยสองวิธี
js/foundation.util.box.js คือชื่อไฟล์สคริปต์ซึ่งสามารถรวมได้ขณะเขียนโค้ด
วัตถุ jQuery หรือองค์ประกอบ JavaScript ธรรมดาสามารถส่งผ่านไปยังทั้งสองวิธีได้
var dims = Foundation.Box.GetDimensions(element);
อ็อบเจ็กต์ที่ส่งคืนระบุขนาดขององค์ประกอบเป็น -
{
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: ...
}
}
ฟังก์ชันImNotTouchingYouรวมอยู่ด้วย
ขึ้นอยู่กับองค์ประกอบที่ส่งผ่านค่าบูลีนจะถูกส่งกลับซึ่งอาจขัดแย้งกับขอบของหน้าต่างหรือทางเลือกหรือองค์ประกอบหลัก
สองตัวเลือกที่ระบุในบรรทัดด้านล่างคือ leftAndRightOnly, topAndBottomOnly ถูกใช้เพื่อระบุการชนกันบนแกนเดียวเท่านั้น
var clear = Foundation.Box.ImNotTouchingYou (
element [, parent, leftAndRightOnly, topAndBottomOnly]);
คีย์บอร์ด
มีหลายวิธีในFoundation.Keyboardซึ่งช่วยให้การโต้ตอบกับเหตุการณ์ของแป้นพิมพ์เป็นเรื่องง่าย
js/foundation.util.keyboard.js คือชื่อไฟล์สคริปต์ซึ่งสามารถรวมได้ขณะเขียนโค้ด
วัตถุFoundation.Keyboard.keysประกอบด้วยคู่คีย์ / ค่าซึ่งคีย์จะถูกใช้ในกรอบงานบ่อยกว่า
เมื่อใดก็ตามที่กดปุ่มFoundation.Keyboard.parseKeyจะถูกเรียกเพื่อรับสตริง สิ่งนี้ช่วยในการจัดการอินพุตคีย์บอร์ดของคุณเอง
รหัสต่อไปนี้จะใช้ในการหาองค์ประกอบที่สามารถโฟกัสทั้งหมดภายในกำหนดองค์ประกอบ $ ดังนั้นคุณจึงไม่จำเป็นต้องเขียนฟังก์ชันและตัวเลือกใด ๆ
var focusable = Foundation.Keyboard.findFocusable($('#content'));
handleKeyฟังก์ชั่นเป็นหน้าที่หลักของห้องสมุดนี้
วิธีนี้ใช้เพื่อจัดการกับเหตุการณ์แป้นพิมพ์ สามารถเรียกใช้ได้ทุกครั้งที่ลงทะเบียนปลั๊กอินกับยูทิลิตี้
Foundation.Keyboard.register('pluginName', {
'TAB': 'next'
});
...//in event callback
Foundation.Keyboard.handleKey(event, 'pluginName', {
next: function(){
//do stuff
}
});
Foundation.Keyboard.registerฟังก์ชั่นสามารถเรียกได้ว่าเมื่อคุณต้องการที่จะใช้ผูกที่สำคัญของคุณเอง
MediaQuery
ไลบรารีMediaQueryเป็นหัวใจสำคัญของเทคนิค CSS ที่ตอบสนองทั้งหมด
js/foundation.util.mediaQuery.js คือชื่อไฟล์สคริปต์ซึ่งสามารถรวมได้ขณะเขียนโค้ด
Foundation.MediaQuery.atLeast (ขนาดใหญ่)จะใช้ในการตรวจสอบว่าหน้าจอเป็นอย่างน้อยที่กว้างเป็นเบรกพอยต์
Foundation.MediaQuery.get (กลาง)ได้รับการสอบถามสื่อของเบรกพอยต์
Foundation.MediaQuery.queriesมีอาร์เรย์ของคำสั่งสื่อมูลนิธิใช้สำหรับจุดพัก
Foundation.MediaQuery.currentคือสตริงขนาดเบรกพอยต์ในปัจจุบัน
Foundation.MediaQuery.get('medium');
Foundation.MediaQuery.atLeast('large');
Foundation.MediaQuery.queries;
Foundation.MediaQuery.current;
รหัสต่อไปนี้เผยแพร่การเปลี่ยนแปลงคิวรีสื่อบนหน้าต่าง
$(window).on('changed.zf.mediaquery', function(event, newSize, oldSize){});
การเคลื่อนไหวและการเคลื่อนไหว
Foundation.Motion javascript คล้ายกับไลบรารี Motion UI ซึ่งรวมอยู่ใน Foundation 6 ใช้เพื่อสร้างการเปลี่ยน CSS และภาพเคลื่อนไหวที่กำหนดเอง
js/foundation.util.motion.js คือชื่อไฟล์สคริปต์ซึ่งสามารถรวมได้ขณะเขียนโค้ด
Foundation.Moveใช้เพื่อทำให้แอนิเมชั่นที่สนับสนุน CSS3 เรียบง่ายและสง่างาม
requestAnimationFrame();วิธีการบอกให้เบราว์เซอร์แสดงภาพเคลื่อนไหว จะร้องขอให้เรียกใช้ฟังก์ชันภาพเคลื่อนไหวของคุณก่อนที่เบราว์เซอร์จะทำการทาสีใหม่ครั้งต่อไป
Foundation.Move(durationInMS, $element, function() {
//animation logic
});
เมื่อแอนิเมชั่นเสร็จสมบูรณ์finished.zf.animateจะเริ่มทำงาน
โหลดตัวจับเวลาและรูปภาพแล้ว
Orbit ใช้ทั้งตัวจับเวลาฟังก์ชันและรูปภาพที่โหลด js/foundation.util.timerAndImageLoader.js คือชื่อไฟล์สคริปต์ซึ่งสามารถรวมได้ขณะเขียนโค้ด
var timer = new Foundation.Timer($element, {duration: ms, infinite: bool}, callback);
วิธีการโหลดรูปภาพจะเรียกใช้ฟังก์ชันการเรียกกลับในคอลเลกชัน jQuery ของคุณเมื่อโหลดรูปภาพเสร็จสมบูรณ์
Foundation.onImagesLoaded($images, callback);
สัมผัส
วิธีการนี้ใช้สำหรับการเพิ่มเหตุการณ์การลากหลอกและปัดไปที่องค์ประกอบ
js/foundation.util.touch.js คือชื่อไฟล์สคริปต์ซึ่งสามารถรวมได้ขณะเขียนโค้ด
addTouchวิธีการที่ใช้ในการผูกองค์ประกอบที่จะสัมผัสเหตุการณ์ในปลั๊กอิน Slider สำหรับอุปกรณ์มือถือ
spotSwipeวิธีการผูกองค์ประกอบที่จะรูดเหตุการณ์ในวงโคจรปลั๊กอินสำหรับอุปกรณ์มือถือ
$('selector').addTouch().on('mousemove', handleDrag);
$('selector').spotSwipe().on('swipeleft', handleLeftSwipe);
ทริกเกอร์
ทริกเกอร์เหตุการณ์ที่ระบุสำหรับองค์ประกอบที่เลือก
js/foundation.util.triggers.js คือชื่อไฟล์สคริปต์ซึ่งสามารถรวมได้ขณะเขียนโค้ด
ทริกเกอร์ถูกใช้ในปลั๊กอิน Foundation จำนวนมาก
$('selector').on('open.zf.trigger', handleOpen);
$('selector').on('close.zf.trigger', handleClose);
$('selector').on('toggle.zf.trigger', handleToggle);
สองวิธีต่อไปนี้ใช้ในไลบรารีนี้คือปรับขนาดและเลื่อน
วิธีresize ()ทริกเกอร์เหตุการณ์การปรับขนาดเมื่อเกิดเหตุการณ์การปรับขนาด
วิธีการเลื่อน ()เรียกเหตุการณ์การเลื่อนเมื่อเหตุการณ์เลื่อนเกิดขึ้น
$('#someId').on('scrollme.zf.trigger', handleScroll);
$('#someId').on('resizeme.zf.trigger', handleResize);
เบ็ดเตล็ด
Foundation มีคุณสมบัติบางอย่างในไลบรารีหลักซึ่งใช้ในหลาย ๆ ที่
js/foundation.core.js คือชื่อไฟล์สคริปต์ซึ่งสามารถรวมได้ขณะเขียนโค้ด
Foundation.GetYoDigits ([number, namespace])ส่งคืน uid ฐาน -36 แบบสุ่มพร้อมเนมสเปซ จะคืนค่าความยาวสตริง 6 อักขระตามค่าเริ่มต้น
Foundation.getFnName (fn)ส่งคืนชื่อฟังก์ชัน JavaScript
Foundation.transitionendเกิดขึ้นเมื่อการเปลี่ยน CSS เสร็จสิ้น