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 เสร็จสิ้น