แผนที่แหล่งที่มาคืออะไร

การแมปแหล่งที่มาเป็นเครื่องมือที่สำคัญในการพัฒนาเว็บสมัยใหม่ ซึ่งจะทำให้การแก้ไขข้อบกพร่องง่ายขึ้นอย่างมาก หน้านี้จะอธิบายข้อมูลเบื้องต้นเกี่ยวกับซอร์สแมป วิธีสร้าง และวิธีปรับปรุงประสบการณ์การแก้ไขข้อบกพร่อง

ความจำเป็นในการแมปแหล่งที่มา

เว็บแอปยุคแรกๆ สร้างขึ้นด้วยความซับซ้อนต่ำ นักพัฒนาซอฟต์แวร์จะติดตั้งใช้งานไฟล์ HTML, CSS และ JavaScript ลงในเว็บโดยตรง

เว็บแอปที่ทันสมัยและซับซ้อนมากขึ้นอาจต้องใช้เครื่องมือที่หลากหลายในเวิร์กโฟลว์การพัฒนา เช่น

  • ภาษาเทมเพลตและโปรแกรมประมวลผล HTML ก่อนการคอมไพล์: Pug, Nunjucks, Markdown
  • โปรแกรมประมวลผล CSS: SCSS, LESS, PostCSS
  • เฟรมเวิร์ก JavaScript: Angular, React, Vue, Svelte
  • เฟรมเวิร์กเมตา JavaScript: Next.js, Nuxt, Astro
  • ภาษาโปรแกรมระดับสูง ได้แก่ TypeScript, Dart และ CoffeeScript
ภาพรวมคร่าวๆ ของเครื่องมือต่างๆ
เครื่องมือพัฒนาเว็บแอปที่พบบ่อย

เครื่องมือเหล่านี้ต้องใช้กระบวนการสร้างเพื่อแปลงโค้ดเป็น HTML, JavaScript และ CSS มาตรฐานที่เบราว์เซอร์เข้าใจ นอกจากนี้ แนวทางปฏิบัติทั่วไปอีกอย่างหนึ่งคือการเพิ่มประสิทธิภาพโดยการย่อขนาดและรวมไฟล์เหล่านี้โดยใช้เครื่องมืออย่าง Terser

เช่น เมื่อใช้เครื่องมือสร้าง เราสามารถแปลงและบีบอัดไฟล์ TypeScript ต่อไปนี้ลงใน JavaScript บรรทัดเดียว คุณสามารถลองใช้ด้วยตัวคุณเองในเดโมบน GitHub นี้

/* A TypeScript demo: example.ts */

document.querySelector('button')?.addEventListener('click', () => {
  const num: number = Math.floor(Math.random() * 101);
  const greet: string = 'Hello';
  (document.querySelector('p') as HTMLParagraphElement).innerText = `${greet}, you are no. ${num}!`;
  console.log(num);
});

เวอร์ชันที่บีบอัดจะมีลักษณะดังนี้

/* A compressed JavaScript version of the TypeScript demo: example.min.js  */

document.querySelector("button")?.addEventListener("click",(()=>{const e=Math.floor(101*Math.random());document.querySelector("p").innerText=`Hello, you are no. ${e}!`,console.log(e)}));

อย่างไรก็ตาม การบีบอัดโค้ดอาจทําให้การแก้ไขข้อบกพร่องยากขึ้น แผนที่แหล่งที่มาจะช่วยแก้ปัญหานี้ได้ โดยจับคู่โค้ดที่คอมไพล์แล้วกลับไปกับโค้ดต้นฉบับ ซึ่งจะช่วยให้คุณค้นหาแหล่งที่มาของข้อผิดพลาดได้อย่างรวดเร็ว

สร้างแผนที่ซอร์สโค้ด

แผนที่ซอร์สโค้ดคือไฟล์ที่มีชื่อลงท้ายด้วย .map (เช่น example.min.js.map และ styles.css.map) ซึ่งเครื่องมือสร้างส่วนใหญ่จะสร้างได้ ซึ่งรวมถึง Vite, webpack, Rollup, Parcel และ esbuild

เครื่องมือบางรายการจะมีสําเนาที่มาโดยค่าเริ่มต้น ส่วนรายการอื่นๆ อาจต้องมีการกําหนดค่าเพิ่มเติมจึงจะสร้างได้

/* Example configuration: vite.config.js */
/* https://vitejs.dev/config/ */

export default defineConfig({
  build: {
    sourcemap: true, // enable production source maps
  },
  css: {
    devSourcemap: true // enable CSS source maps during development
  }
})

ทําความเข้าใจแผนที่แหล่งที่มา

ไฟล์แผนที่แหล่งที่มาเหล่านี้มีข้อมูลสําคัญเกี่ยวกับวิธีที่โค้ดที่คอมไพล์แล้วแมปกับโค้ดต้นฉบับเพื่อช่วยในการแก้ไขข้อบกพร่อง ตัวอย่างไฟล์ Map แหล่งที่มา

{
  "mappings": "AAAAA,SAASC,cAAc,WAAWC, ...",
  "sources": ["src/script.ts"],
  "sourcesContent": ["document.querySelector('button')..."],
  "names": ["document","querySelector", ...],
  "version": 3,
  "file": "example.min.js.map"
}

คุณอ่านข้อกำหนดของการแมปแหล่งที่มาหรือโครงสร้างของการแมปแหล่งที่มาเพื่อทำความเข้าใจแต่ละช่องเหล่านี้ได้

ส่วนสําคัญที่สุดของแผนที่แหล่งที่มาคือช่อง mappings โดยจะใช้สตริงที่เข้ารหัส VLQ Base64 เพื่อแมปบรรทัดและตําแหน่งในไฟล์ที่คอมไพล์กับไฟล์ต้นฉบับที่เกี่ยวข้อง คุณสามารถดูการแมปนี้ได้โดยใช้เครื่องมือแสดงภาพซอร์สแมป เช่น source-map-visualization หรือ Source Map Visualization

การแสดงภาพการแมปแหล่งที่มา
การแสดงภาพตัวอย่างโค้ดก่อนหน้าซึ่งสร้างโดยเครื่องมือแสดงภาพ

คอลัมน์ที่สร้างขึ้นทางด้านซ้ายจะแสดงเนื้อหาที่บีบอัด และคอลัมน์ต้นฉบับจะแสดงแหล่งที่มาเดิม

วิดีโอ Visualizer จะใส่โค้ดสีแต่ละบรรทัดในคอลัมน์ต้นฉบับด้วยโค้ดที่เกี่ยวข้องในคอลัมน์สร้างขึ้น

ส่วนการแมปจะแสดงการแมปที่ถอดรหัสแล้วของโค้ด ตัวอย่างเช่น รายการ 65 -> 2:2 หมายถึง

  • โค้ดที่สร้างขึ้น: คํา const เริ่มต้นที่ตําแหน่ง 65 ในเนื้อหาที่บีบอัด
  • รหัสต้นฉบับ: คํา const เริ่มต้นที่บรรทัด 2 และคอลัมน์ 2 ในเนื้อหาต้นฉบับ
รายการการแมป
การแสดงภาพการแมปโดยเน้นที่รายการ 65 -> 2:2

ซึ่งช่วยให้นักพัฒนาแอประบุความสัมพันธ์ระหว่างโค้ดที่ผ่านการย่อขนาดกับโค้ดต้นฉบับได้อย่างรวดเร็ว จึงทำให้การแก้ไขข้อบกพร่องเป็นไปอย่างราบรื่น

เครื่องมือสำหรับนักพัฒนาซอฟต์แวร์เบราว์เซอร์จะใช้ซอร์สแมปเหล่านี้เพื่อช่วยคุณระบุปัญหาการแก้ไขข้อบกพร่องได้อย่างรวดเร็วในเบราว์เซอร์

เครื่องมือสําหรับนักพัฒนาซอฟต์แวร์ที่ใช้แผนที่แหล่งที่มา
ตัวอย่างวิธีที่เครื่องมือสําหรับนักพัฒนาซอฟต์แวร์เบราว์เซอร์ใช้แผนภาพซอร์สโค้ดและแสดงการแมประหว่างไฟล์

ส่วนขยายการแมปแหล่งที่มา

แผนที่แหล่งที่มารองรับฟิลด์ส่วนขยายที่กำหนดเองที่ขึ้นต้นด้วยคำนำหน้า x_ ตัวอย่างหนึ่งคือช่องส่วนขยาย x_google_ignoreList ที่ Chrome DevTools เสนอ ดูข้อมูลเพิ่มเติมเกี่ยวกับวิธีที่ส่วนขยายเหล่านี้ช่วยให้คุณมุ่งเน้นที่โค้ดได้ที่ x_google_ignoreList

ข้อเสียของการแมปแหล่งที่มา

อย่างไรก็ตาม การแมปแหล่งที่มาอาจไม่สมบูรณ์อย่างที่คุณต้องการ ในตัวอย่างแรกของเรา ตัวแปร greet ได้รับการเพิ่มประสิทธิภาพระหว่างขั้นตอนการสร้าง แม้ว่าค่าจะถูกฝังลงในเอาต์พุตสตริงสุดท้ายโดยตรงก็ตาม

ไม่ได้แมปคําทักทายของตัวแปร
ไม่มีตัวแปร greet ในโค้ดต้นฉบับในการแมป

ในกรณีนี้ เมื่อแก้ไขข้อบกพร่องโค้ด เครื่องมือสําหรับนักพัฒนาซอฟต์แวร์อาจไม่สามารถอนุมานและแสดงค่าจริง ข้อผิดพลาดประเภทนี้อาจทําให้การตรวจสอบและการวิเคราะห์โค้ดยากขึ้น

ยังไม่ได้กำหนดคำทักทายที่เป็นตัวแปร
เครื่องมือสําหรับนักพัฒนาแอปไม่พบค่าสําหรับ greet

นี่เป็นปัญหาที่จำเป็นต้องแก้ไขในการออกแบบการแมปแหล่งที่มา วิธีแก้ปัญหาที่เป็นไปได้อย่างหนึ่งคือการใส่ข้อมูลขอบเขตในซอร์สแมปในลักษณะเดียวกับที่ภาษาโปรแกรมอื่นๆ ใช้กับข้อมูลการแก้ไขข้อบกพร่อง

อย่างไรก็ตาม วิธีนี้ต้องใช้ระบบนิเวศทั้งระบบทำงานร่วมกันเพื่อปรับปรุงข้อกำหนดและการใช้งานการแมปแหล่งที่มา หากต้องการติดตามการพัฒนาอย่างต่อเนื่องเพื่อปรับปรุงความสามารถในการแก้ไขข้อบกพร่องด้วยซอร์สแมป โปรดดูข้อเสนอสำหรับ Source Maps v4 ใน GitHub