วิธีสร้างไฟล์ xml delphi คู่มือการเดินทางทางอินเทอร์เน็ต - ความสนุกทั้งหมดบนเว็บ คำสองสามคำเกี่ยวกับการจัดโฟลว์เอกสาร
ยินดีต้อนรับ! บล็อกนี้เกี่ยวกับอินเทอร์เน็ตและคอมพิวเตอร์ หรือค่อนข้างจะอุทิศให้กับพวกเขา
อาจเป็นที่ชัดเจนว่าไม่มีบทความใหม่ปรากฏบนเว็บไซต์เป็นเวลาหลายปี ใช่ นั่นคือชะตากรรมของบล็อกส่วนใหญ่ โครงการนี้ครั้งหนึ่งเคยเป็นงานที่มีความทะเยอทะยาน และผู้เขียนก็เหมือนกับคนอื่นๆ อีกหลายคนที่เขียนในขณะนั้น มีแผนทะเยอทะยานที่จะกลายเป็นหนึ่งในบล็อกเกอร์ชาวรัสเซียที่ดีที่สุด ถ้าคุณดูตอนนี้ บล็อกเหล่านั้นที่สร้างขึ้นพร้อมกับฉัน ส่วนใหญ่หายไปตลอดกาล และฉันก็ไม่มีเวลาพอที่จะเขียนบล็อก ใช่แล้ว มันไม่อัปเดตอีกต่อไป แม้ว่าเมื่อเรากับไซต์นี้ชนะการแข่งขัน "Blog of Runet 2011"
ฉันมีความคิดที่จะลบสิ่งเหล่านี้ทั้งหมด แต่แล้วฉันก็แก้ไขเนื้อหาเก่าและตระหนักว่ายังคงมีประโยชน์ต่อผู้อ่าน ใช่ บทความบางบทความล้าสมัย (หากฉันมีความแข็งแกร่งเพียงพอ พวกเขาจะได้รับบันทึกย่อที่เหมาะสม) แต่เว็บไซต์ ตัวอย่างเช่น อาจมีประโยชน์สำหรับผู้เริ่มต้น - คุณสามารถอ่านได้ที่นี่ แนวคิดพื้นฐานอินเทอร์เน็ต เรียนรู้วิธีกำหนดค่าอินเทอร์เน็ต Windows หรือแม้แต่ตัดสินใจเปลี่ยนไปใช้ Linux ให้ดูเกณฑ์การให้คะแนนและเลือกเกณฑ์ที่เหมาะสมกับคุณ
และถึงกระนั้น ฉันหวังว่านี่จะไม่ใช่แค่บล็อก แต่เป็นแนวทางที่แท้จริงสำหรับอินเทอร์เน็ต ไซต์สามารถดูได้ในโหมดไดเร็กทอรี ซึ่งบทความที่มีอยู่ทั้งหมดมีโครงสร้างตามหมวดหมู่ และใครจะไปรู้ บางทีวันหนึ่งบทความคุณภาพสูงใหม่ๆ ก็เริ่มปรากฏขึ้นที่นี่
แซนเดอร์
Picodi.ru เป็นพอร์ทัลส่วนลดจาก International Coupons ผู้เชี่ยวชาญด้านการออมและการช้อปปิ้งราคาถูกของโปแลนด์ ชาวโปแลนด์ถือเป็นหนึ่งในประเทศที่ประหยัดที่สุดในโลก จึงไม่น่าแปลกใจที่โครงการประเภทนี้จะเติบโตจากการเริ่มต้นของโปแลนด์ kodyrabatowe.pl พอร์ทัลนี้จะมีประโยชน์ต่อผู้ใช้อินเทอร์เน็ตทั่วไปในรัสเซียได้อย่างไร
โทรศัพท์ Android สมัยใหม่เป็นมากกว่าโทรศัพท์ คุณคุ้นเคยกับการพิมพ์ โปรแกรมที่ติดตั้ง, ไปยังประวัติการโทรของคุณและ ข้อความ, คอลเลกชั่นรูปภาพ และอื่นๆ แต่เวลาผ่านไป และอุปกรณ์ที่เหมาะสมกับคุณจะเริ่มทำงานช้าลง ผิดพลาด หรือสูญเสียรูปลักษณ์ที่เรียบร้อยไปเนื่องจากชิปบนเคสหรือรอยขีดข่วนบนหน้าจอ คำถามเกิดขึ้นกับการเลือกโทรศัพท์ใหม่และการเปลี่ยนแปลง โทรศัพท์ Android... และถ้าตอนนี้เราข้ามคำถามที่เลือกแล้ว "ย้าย" ไปที่ โทรศัพท์ใหม่ยังคงเป็นปัญหาร้ายแรง - คุณไม่ต้องการเริ่มข้อมูลทั้งหมดตั้งแต่เริ่มต้น นี่คือสิ่งที่เราจะพูดถึงในวันนี้
ผู้อ่านบล็อกนี้ส่วนใหญ่มักไม่เคยพบกับระบบควบคุมเวอร์ชันและจะไม่พบระบบใด ๆ ในอนาคตอันใกล้นี้ มันน่าเสียดาย สิ่งประดิษฐ์ที่สะดวกสบายอย่างยิ่งนี้ถูกใช้กันอย่างแพร่หลายโดยโปรแกรมเมอร์ แต่ในความคิดของฉัน มันอาจจะมีประโยชน์มากสำหรับผู้ที่ทำงานกับข้อความอย่างแข็งขัน แต่น่าจะตอนนี้ไม่มีระบบควบคุมเวอร์ชันเดียวที่จะเริ่มต้นใช้งานสำหรับ "สำนักงาน" ได้ง่าย ( Microsoft Office) งาน. อย่างไรก็ตาม ฉันคิดว่าเนื้อหาที่นำเสนอในบทความอาจน่าสนใจสำหรับผู้อ่านทุกคน
หากคุณเคยคิดว่าจะดูภาพยนตร์บนเครือข่ายจากทีวีและออนไลน์ได้อย่างไร บทความนี้เหมาะสำหรับคุณ ไม่ ฉันรู้ว่าทีวีบางรุ่นมีฟังก์ชัน Smart TV อยู่แล้ว แต่ฉันไม่เคยเห็นว่ามันทำงานอย่างถูกต้องมาก่อน เห็นได้ชัดว่าเมื่อเร็ว ๆ นี้ บริษัท Google ได้สาธิตอุปกรณ์ที่น่าทึ่งอย่างยิ่งซึ่งกลายเป็นความรู้สึกทันที เรากำลังพูดถึง Chromecast media streamer (Chromecast) ซึ่งเป็น Nexus Q รุ่นหายนะที่ล้ำหน้ากว่าและราคาไม่แพงในปีที่แล้ว
Dongle Chromecast ซึ่งมีขนาดไม่เกิน 2 นิ้ว เสียบเข้ากับพอร์ต ทีวี HDMIและให้คุณเพลิดเพลินกับการรับชมเนื้อหาเว็บสตรีมมิ่ง ในการควบคุมสตรีมเมอร์ คุณสามารถใช้อุปกรณ์ใดก็ได้ (แท็บเล็ต พีซี สมาร์ทโฟน) ที่ใช้ระบบปฏิบัติการ iOS, Windows, Android หรือ Mac OS
บทความนี้มีไว้สำหรับอุปกรณ์ของหน่วยความจำระบบ Android ปัญหาที่อาจเกิดขึ้นเนื่องจากการขาดแคลนและวิธีแก้ปัญหา เมื่อไม่นานมานี้ ตัวฉันเองต้องเผชิญกับความจริงที่ว่าโทรศัพท์ Android ของฉันเริ่มส่งข้อความเกี่ยวกับหน่วยความจำไม่เพียงพอเป็นประจำเมื่อพยายามติดตั้งแอปพลิเคชัน ซึ่งแปลกมากสำหรับฉัน เนื่องจากตามคำอธิบายในตลาดควรมีขนาดประมาณ 16GB และฉันก็เพิ่มปริมาณนี้ด้วยการ์ดหน่วยความจำเพิ่มเติม อย่างไรก็ตาม มันมีปัญหาและฉันต้องคิดมากก่อนจะเจอ การตัดสินใจที่ถูกต้องที่ไม่ต้องการการเข้าถึงรูทหรือคืนค่าโทรศัพท์จากโรงงานทั้งหมด
มีการใช้ XML มากขึ้นในการจัดเก็บข้อมูลและแลกเปลี่ยนข้อมูลระหว่างแอปพลิเคชันและเว็บไซต์ แอปพลิเคชั่นจำนวนมากใช้ภาษานี้เป็นภาษาพื้นฐานสำหรับการจัดเก็บข้อมูล ในขณะที่แอปพลิเคชั่นอื่นๆ ใช้สำหรับการส่งออกและนำเข้าข้อมูล XML ดังนั้นจึงถึงเวลาแล้วที่นักพัฒนาจะต้องเริ่มคิดว่าจะใช้ข้อมูล XML ในแอปพลิเคชันของตนเองได้อย่างไร
ในบทความนี้ เราจะดู XML Document Object Model (DOM) และการนำ XML DOM ไปใช้งานของ Microsoft
XML DOM เป็นอ็อบเจ็กต์โมเดลที่ให้นักพัฒนามีอ็อบเจ็กต์สำหรับการโหลดและประมวลผลไฟล์ XML โมเดลอ็อบเจ็กต์ประกอบด้วยอ็อบเจ็กต์หลักต่อไปนี้: XMLDOMDocument, XMLDOMNodeList, XMLDOMNode, XMLDOMNamedNodeMap และ XMLDOMparseError แต่ละอ็อบเจ็กต์เหล่านี้ (ยกเว้น XMLDOMparseError) มีคุณสมบัติและวิธีการที่ช่วยให้คุณรับข้อมูลเกี่ยวกับออบเจ็กต์ จัดการค่าและโครงสร้างของอ็อบเจ็กต์ และนำทางโครงสร้างของเอกสาร XML
มาดูออบเจ็กต์ XML DOM หลักและแสดงตัวอย่างการใช้งานใน Borland Delphi
การใช้ XML DOM ใน Borland Delphi
ในการใช้ Microsoft XML DOM ในแอปพลิเคชัน Delphi คุณต้องเชื่อมต่อไลบรารีประเภทที่เหมาะสมกับโครงการ ในการดำเนินการนี้ เรารันคำสั่ง Project | Import Type Library และในกล่องโต้ตอบ Import Type Library ให้เลือกไลบรารี Microsoft XML เวอร์ชัน 2.0 (เวอร์ชัน 2.0) ซึ่งมักจะอยู่ในไฟล์ Windows \ System \ MSXML.DLL
หลังจากคลิกปุ่มสร้างหน่วย โมดูลอินเทอร์เฟซ MSXML_TLB จะถูกสร้างขึ้น ซึ่งจะช่วยให้เราใช้วัตถุ XML DOM: DOMDocument, XMLDocument, XMLHTTPRequest และอื่นๆ อีกจำนวนหนึ่ง นำไปใช้ในไลบรารี MSXML.DLL การอ้างอิงถึงโมดูล MSXML_TLB ต้องอยู่ในรายการ Uses
อุปกรณ์ XML DOM
Document Object Model แสดงถึงเอกสาร XML ในโครงสร้างแบบต้นไม้ของกิ่ง XML DOM API อนุญาตให้แอปพลิเคชันนำทางโครงสร้างเอกสารและจัดการสาขา แต่ละสาขาสามารถมีประเภทเฉพาะได้ (DOMNodeType) ตามที่กำหนดสาขาหลักและสาขาย่อย เอกสาร XML ส่วนใหญ่มีสาขาขององค์ประกอบประเภท แอตทริบิวต์ และข้อความ คุณลักษณะเป็นสาขาพิเศษและไม่ใช่สาขาย่อย วิธีการพิเศษที่จัดเตรียมโดยวัตถุ XML DOM ใช้เพื่อจัดการแอตทริบิวต์
นอกเหนือจากการใช้อินเทอร์เฟซที่แนะนำของ World Wide Web Consortium (W3C) แล้ว Microsoft XML DOM ยังมีเมธอดที่สนับสนุน XSL, XSL Patterns, Namespaces และประเภทข้อมูล ตัวอย่างเช่น เมธอด SelectNodes ให้คุณใช้ไวยากรณ์รูปแบบ XSL เพื่อค้นหาสาขาในบริบทเฉพาะ และวิธีการ TransformNode รองรับการใช้ XSL เพื่อทำการแปลง
เอกสาร XML ทดสอบ
เป็นตัวอย่างเอกสาร XML ลองใช้ไดเร็กทอรีซีดีรอมเพลงซึ่งมีโครงสร้างดังต่อไปนี้:
ตอนนี้เราพร้อมที่จะเริ่มดูโมเดลวัตถุ XML DOM โดยเริ่มจากวัตถุ XMLDOMDocument
เอกสาร XML - XMLDOMDocument Object
การทำงานกับเอกสาร XML เริ่มต้นด้วยการโหลดเอกสาร ในการดำเนินการนี้ เราใช้วิธี Load ซึ่งมีพารามิเตอร์เพียงตัวเดียวที่ระบุ URL ของเอกสารที่โหลด เมื่อโหลดไฟล์จากโลคัลดิสก์ จะระบุเฉพาะชื่อไฟล์แบบเต็มเท่านั้น (ไฟล์: /// สามารถละเว้นโปรโตคอลได้ในกรณีนี้) ถ้าเอกสาร XML ถูกจัดเก็บเป็นสตริง ให้ใช้วิธี LoadXML เพื่อโหลดเอกสาร
คุณสมบัติ Async ใช้เพื่อควบคุมวิธีการโหลดเอกสาร (ซิงโครนัสหรืออะซิงโครนัส) ตามค่าเริ่มต้น คุณสมบัตินี้ถูกตั้งค่าเป็น True ซึ่งบ่งชี้ว่าเอกสารถูกโหลดแบบอะซิงโครนัสและการควบคุมจะถูกส่งกลับไปยังแอปพลิเคชันก่อนที่เอกสารจะโหลดจนเต็ม มิฉะนั้น เอกสารจะโหลดแบบซิงโครนัส จากนั้นคุณต้องตรวจสอบค่าของคุณสมบัติ ReadyState เพื่อดูว่ามีการโหลดเอกสารหรือไม่ คุณยังสามารถสร้างตัวจัดการสำหรับเหตุการณ์ OnReadyStateChange ที่จะควบคุมเมื่อค่าของคุณสมบัติ ReadyState เปลี่ยนแปลง
ข้อมูลต่อไปนี้แสดงวิธีการโหลดเอกสาร XML โดยใช้วิธี Load:
ใช้ ... MSXML_TLB ... ขั้นตอน TForm1.Button1Click (ผู้ส่ง: TObject); var XMLDoc: IXMLDOMDocument; เริ่ม XMLDoc: = CoDOMDocument.Create; XMLDoc.Async: = เท็จ; XMLDoc.Load ('C: \ DATA \ DATA.xml'); // // นี่คือตำแหน่งที่โค้ดที่จัดการ // เอกสาร XML และสาขา // XMLDoc: = ไม่มี; จบ;
หลังจากโหลดเอกสารแล้ว เราสามารถเข้าถึงคุณสมบัติของเอกสารได้ ดังนั้น คุณสมบัติ NodeName จะมีค่า #document คุณสมบัติ NodeTypeString จะมีค่าเอกสาร และคุณสมบัติ URL จะมีไฟล์: /// C: /DATA/DATA.xml ค่า
การจัดการข้อผิดพลาด
สิ่งที่น่าสนใจเป็นพิเศษคือคุณสมบัติที่เกี่ยวข้องกับการประมวลผลเอกสารเมื่อโหลด ตัวอย่างเช่น คุณสมบัติ ParseError ส่งคืนอ็อบเจ็กต์ XMLDOMParseError ที่มีข้อมูลเกี่ยวกับข้อผิดพลาดที่เกิดขึ้นขณะประมวลผลเอกสาร
ในการเขียนตัวจัดการข้อผิดพลาด คุณสามารถเพิ่มรหัสต่อไปนี้:
Var XMLError: IXMLDOMparseError; ... XMLDoc.Load ('C: \ DATA \ DATA.xml'); XMLError: = XMLDoc.ParseError; ถ้า XMLError.ErrorCode<>0 จากนั้น // // ที่นี่เราจัดการกับข้อผิดพลาด // Else Memo1.Lines.Add (XMLDoc.XML); ... XMLDoc: = ไม่มี;
หากต้องการทราบข้อมูลที่ส่งคืนในกรณีที่เกิดข้อผิดพลาด ให้เปลี่ยนรายการไดเรกทอรีต่อไปนี้:
ถอดองค์ประกอบปิด
ตอนนี้เรามาเขียนโค้ดที่คืนค่าคุณสมบัติของอ็อบเจกต์ XMLDOMparseError:
XMLError: = XMLDoc.ParseError; ถ้า XMLError.ErrorCode<>0 จากนั้นด้วย XMLError Memo1.Lines จะเริ่มเพิ่ม ('ไฟล์:' + URL); เพิ่ม ('รหัส:' + IntToStr (รหัสข้อผิดพลาด)); เพิ่ม ('ข้อผิดพลาด:' + เหตุผล); เพิ่ม ('ข้อความ:' + SrcText); เพิ่ม ('บรรทัด:' + IntToStr (บรรทัด)); เพิ่ม ('ตำแหน่ง:' + IntToStr (LinePos)); สิ้นสุด Memo1.Lines.Add อื่น (XMLDoc.XML); จบ;
และดำเนินการสมัครของเรา ด้วยเหตุนี้ เราจึงได้รับข้อมูลต่อไปนี้เกี่ยวกับข้อผิดพลาด
ดังที่คุณเห็นจากตัวอย่างข้างต้น ข้อมูลที่ส่งคืนโดยอ็อบเจ็กต์ XMLDOMParseError นั้นเพียงพอที่จะแปลข้อผิดพลาดและเข้าใจสาเหตุของการเกิดขึ้น
ตอนนี้เราจะคืนค่าองค์ประกอบปิด
การเข้าถึงแผนผังเอกสาร
ในการเข้าถึงแผนผังเอกสาร คุณสามารถรับองค์ประกอบรูทแล้ววนซ้ำบนสาขาย่อยหรือค้นหาสาขาที่ต้องการ ในกรณีแรก เราได้รับองค์ประกอบรูทผ่านคุณสมบัติ DocumentElement ซึ่งส่งคืนอ็อบเจ็กต์ประเภท XMLDOMNode ต่อไปนี้คือวิธีใช้คุณสมบัติ DocumentElement เพื่อรับเนื้อหาของแต่ละองค์ประกอบย่อย:
โหนด Var: IXMLDOMNode; ราก: IXMLDOMEองค์ประกอบ; ฉัน: จำนวนเต็ม; ... รูท: = XMLDoc.DocumentElement; สำหรับฉัน: = 0 ถึง Root.ChildNodes.Length-1 ทำ Begin Node: = Root.ChildNodes.Item [I]; Memo1.Lines.Add (โหนด.ข้อความ); จบ;
สำหรับเอกสาร XML ของเรา เราได้รับข้อความต่อไปนี้
หากเราสนใจสาขาใดสาขาหนึ่งหรือสาขาใดสาขาหนึ่งที่อยู่ต่ำกว่าสาขาย่อยสาขาแรก เราสามารถใช้เมธอด NodeFromID หรือเมธอด GetElementByTagName ของอ็อบเจ็กต์ XMLDOMDocument
วิธีการ NodeFromID ต้องการตัวระบุเฉพาะตามที่กำหนดไว้ใน XML Schema หรือ Document Type Definition (DTD) และส่งคืนสาขาที่มีตัวระบุนั้น
เมธอด GetElementByTagName ต้องใช้สตริงที่มีองค์ประกอบเฉพาะ (แท็ก) และส่งคืนสาขาทั้งหมดที่มีองค์ประกอบนี้ ต่อไปนี้คือวิธีใช้วิธีนี้เพื่อค้นหาศิลปินทั้งหมดในไดเร็กทอรี CD-ROM ของเรา:
โหนด: IXMLDOMNodeList; โหนด: IXMLDOMNode; ... โหนด: = XMLDoc.GetElementsByTagName ('ARTIST'); สำหรับ I: = 0 ถึง Nodes.Length-1 ทำ Begin Node: = Nodes.Item [I]; Memo1.Lines.Add (โหนด.ข้อความ); จบ;
สำหรับเอกสาร XML ของเรา เราจะได้ข้อความต่อไปนี้
โปรดทราบว่าเมธอด SelectNodes ของอ็อบเจ็กต์ XMLDOMNode เป็นวิธีที่ยืดหยุ่นกว่าในการเข้าถึงสาขาของเอกสาร แต่เพิ่มเติมเกี่ยวกับที่ด้านล่าง
สาขาเอกสาร - XMLDOMNode Object
วัตถุ XMLDOMNode แสดงถึงสาขาเอกสาร เราพบวัตถุนี้แล้วเมื่อเราได้รับองค์ประกอบรูทของเอกสาร:
ราก: = XMLDoc.DocumentElement;
เมื่อต้องการรับข้อมูลเกี่ยวกับสาขาของเอกสาร XML คุณสามารถใช้คุณสมบัติของอ็อบเจ็กต์ XMLDOMNode (ตารางที่ 1)
ในการเข้าถึงข้อมูลที่จัดเก็บไว้ในสาขา เป็นเรื่องปกติที่จะใช้คุณสมบัติ NodeValue (มีให้สำหรับแอตทริบิวต์ สาขาข้อความ ความคิดเห็น คำแนะนำในการประมวลผล และส่วน CDATA) หรือคุณสมบัติ Text ซึ่งส่งคืนเนื้อหาที่เป็นข้อความของสาขา หรือคุณสมบัติ NodeTypedValue อย่างไรก็ตาม สิ่งหลังสามารถใช้ได้เฉพาะสำหรับสาขาที่มีรายการพิมพ์เท่านั้น
การนำทางโครงสร้างเอกสาร
ออบเจ็กต์ XMLDOMNode มีหลายวิธีในการนำทางแผนผังเอกสาร ตัวอย่างเช่น ในการเข้าถึงสาขาพาเรนต์ ให้ใช้คุณสมบัติ ParentNode (ประเภท XMLDOMNode) เข้าถึงสาขาย่อยผ่านคุณสมบัติ ChildNodes (ประเภท XMLDOMNodeList), FirstChild และ LastChild (ประเภท XMLDOMNode) เป็นต้น คุณสมบัติ OwnerDocument ส่งกลับวัตถุ XMLDOMDocument ที่ระบุเอกสาร XML เอง คุณสมบัติที่แสดงด้านบนทำให้ง่ายต่อการสำรวจโครงสร้างเอกสาร
ตอนนี้ เรามาวนซ้ำทุกสาขาของเอกสาร XML:
ราก: = XMLDoc.DocumentElement; สำหรับฉัน: = 0 ถึง Root.ChildNodes.Length-1 ทำ Begin Node: = Root.ChildNodes.Item [I]; ถ้า Node.HasChildNodes แล้ว GetChilds (โหนด, 0); จบ;
ดังที่กล่าวไว้ข้างต้น SelectNodes ของอ็อบเจ็กต์ XMLDOMNode ให้วิธีที่ยืดหยุ่นมากขึ้นในการเข้าถึงสาขาของเอกสาร นอกจากนี้ยังมีเมธอด SelectSingleNode ที่ส่งคืนเฉพาะสาขาแรกของเอกสาร ทั้งสองวิธีนี้อนุญาตให้คุณกำหนดเทมเพลต XSL สำหรับการค้นหาสาขา
มาดูขั้นตอนการใช้วิธี SelectNodes เพื่อดึงสาขาทั้งหมดที่มีสาขาซีดีและสาขาย่อย PRICE:
ราก: = XMLDoc.DocumentElement; โหนด: = Root.SelectNodes ('CD / PRICE');
สาขาย่อย PRICE ทั้งหมดของสาขาซีดีจะอยู่ในคอลเล็กชันโหนด เราจะกลับมาพูดถึงเทมเพลต XSL อีกครั้งในภายหลัง
การจัดการสาขาย่อย
ในการจัดการสาขาย่อย เราสามารถใช้เมธอดของอ็อบเจกต์ XMLDOMNode (ตารางที่ 2)
เพื่อลบบันทึกเกี่ยวกับดิสก์แรกอย่างสมบูรณ์ คุณต้องเรียกใช้รหัสต่อไปนี้:
Var XMLDoc: IXMLDOMDocument; ราก: IXMLDOMNode; โหนด: IXMLDOMNode; XMLDoc: = CoDOMDocument.Create; XMLDoc.Async: = เท็จ; XMLDoc.Load ('C: \ DATA \ DATA.xml'); // รับองค์ประกอบราก ราก: = XMLDoc.DocumentElement; โหนด: = รูท; // ลบโหนดย่อยสาขาแรก Node.RemoveChild (Node.FirstChild);
โปรดทราบว่าในตัวอย่างนี้ เรากำลังลบสาขาย่อยแรก วิธีลบองค์ประกอบแรกของสาขาย่อยแรกแสดงด้านล่าง:
Var XMLDoc: IXMLDOMDocument; ราก: IXMLDOMNode; โหนด: IXMLDOMNode; XMLDoc: = CoDOMDocument.Create; XMLDoc.Async: = เท็จ; XMLDoc.Load ('C: \ DATA \ DATA.xml'); // รับองค์ประกอบราก ราก: = XMLDoc.DocumentElement; // และโหนดย่อยของโหนดย่อย: = Root.FirstChild; // ลบโหนดย่อยสาขาแรก Node.RemoveChild (Node.FirstChild);
ในตัวอย่างข้างต้น เราไม่ได้ลบสาขาแรกออก
ตอนนี้ขอเพิ่มสาขาใหม่ ด้านล่างนี้คือรหัสที่แสดงวิธีการเพิ่มรายการซีดีรอมเพลงใหม่:
Var NewNode: IXMLDOMNode; ลูก: IXMLDOMNode; ... // สร้างสาขาใหม่ -
รหัสด้านบนแสดงลำดับขั้นตอนต่อไปนี้เพื่อเพิ่มสาขาใหม่:
- การสร้างสาขาใหม่โดยใช้วิธี CreateNode:
- การสร้างองค์ประกอบโดยใช้เมธอด CreateNode
- การเพิ่มองค์ประกอบไปยังสาขาโดยใช้วิธี AppendChild
- การตั้งค่าองค์ประกอบผ่านคุณสมบัติข้อความ;
- … ทำซ้ำสำหรับองค์ประกอบทั้งหมด
- การเพิ่มสาขาใหม่ให้กับเอกสารโดยใช้วิธี AppendChild
จำได้ว่าเมธอด AppendChild เพิ่มสาขาที่ส่วนท้ายของทรี ในการเพิ่มสาขาไปยังตำแหน่งเฉพาะในแผนผัง คุณต้องใช้เมธอด InsertBefore
ชุดสาขา - วัตถุ XMLDOMNodeList
ออบเจ็กต์ XMLNodeList ประกอบด้วยรายการของสาขา ซึ่งสามารถสร้างได้โดยใช้เมธอด SelectNodes หรือ GetElementsByTagName และยังได้มาจากคุณสมบัติ ChildNodes
เราได้กล่าวถึงการใช้วัตถุนี้ในตัวอย่างที่ให้ไว้ในส่วน "การนำทางแผนผังเอกสาร" ที่นี่เราจะให้ข้อคิดเห็นเชิงทฤษฎี
จำนวนสาขาในรายการสามารถรับได้เป็นค่าของคุณสมบัติ Length แบรนช์ถูกสร้างดัชนีจาก 0 ถึง Length-1 และแต่ละแบรนช์สามารถเข้าถึงได้ผ่านไอเท็มที่จัดทำดัชนีที่สอดคล้องกันในอาร์เรย์ไอเท็ม
การนำทางผ่านรายการสาขาสามารถทำได้โดยใช้วิธี NextNode ซึ่งจะส่งคืนสาขาถัดไปในรายการ หรือไม่มีเลยหากสาขาปัจจุบันเป็นสาขาสุดท้าย หากต้องการกลับไปที่ด้านบนสุดของรายการ ให้เรียกวิธีการรีเซ็ต
สร้างและบันทึกเอกสาร
ดังนั้นเราจึงได้กล่าวถึงวิธีการเพิ่มสาขาและองค์ประกอบในเอกสาร XML ที่มีอยู่ ตอนนี้ มาสร้างเอกสาร XML กันเถอะ ก่อนอื่น โปรดจำไว้ว่า เอกสารสามารถโหลดได้ไม่เพียงแค่จาก URL แต่ยังมาจากสตริงปกติด้วย ต่อไปนี้เป็นวิธีสร้างองค์ประกอบรูท ซึ่งสามารถใช้เพื่อสร้างองค์ประกอบที่เหลือแบบไดนามิก (ซึ่งเราได้กล่าวถึงในส่วนการจัดการสาขาย่อยแล้ว):
Var XMLDoc: IXMLDOMDocument; ราก: IXMLDOMNode; โหนด: IXMLDOMNode; S: WideString; ... ส: = ‘
หลังจากสร้างเอกสาร XML แล้ว ให้บันทึกลงในไฟล์โดยใช้วิธีการบันทึก ตัวอย่างเช่น:
XMLDoc.Save ('C: \ DATA \ NEWCD.XML');
นอกจากการบันทึกลงในไฟล์แล้ว วิธีบันทึกยังช่วยให้คุณบันทึกเอกสาร XML ในอ็อบเจ็กต์ XMLDOMDocument ใหม่ได้อีกด้วย ในกรณีนี้ เอกสารจะได้รับการประมวลผลอย่างสมบูรณ์ และด้วยเหตุนี้จึงมีการตรวจสอบโครงสร้างและไวยากรณ์ของเอกสาร วิธีบันทึกเอกสารไปยังวัตถุอื่นมีดังนี้
ขั้นตอน TForm1.Button2Click (ผู้ส่ง: TObject); var XMLDoc2: IXMLDOMDocument; เริ่ม XMLDoc2: = CoDOMDocument.Create; XMLDoc.Save (XMLDoc2); Memo2.Lines.Add (XMLDoc2.XML); ... XMLDoc2: = ไม่มี; จบ;
โดยสรุป วิธีการบันทึกยังช่วยให้คุณสามารถบันทึกเอกสาร XML ไปยังวัตถุ COM อื่น ๆ ที่สนับสนุนอินเทอร์เฟซ IStream, IPersistStream หรือ IPersistStreamInit
การใช้เทมเพลต XSL
เมื่อพูดถึงเมธอด SelectNodes ของอ็อบเจ็กต์ XMLDOMNode เรากล่าวว่าวิธีนี้ให้วิธีที่ยืดหยุ่นกว่าในการเข้าถึงสาขาของเอกสาร ความยืดหยุ่นคือคุณสามารถระบุเทมเพลต XSL เป็นเกณฑ์ในการเลือกสาขาได้ เทมเพลตดังกล่าวมีกลไกที่มีประสิทธิภาพในการค้นหาข้อมูลในเอกสาร XML ตัวอย่างเช่น หากต้องการรับรายชื่อชื่อซีดีรอมเพลงทั้งหมดในไดเรกทอรีของเรา คุณสามารถเรียกใช้แบบสอบถามต่อไปนี้:
หากต้องการทราบว่าแผ่นดิสก์ของศิลปินรายใดบ้างที่ออกจำหน่ายในสหรัฐอเมริกา คำขอมีดังต่อไปนี้:
โหนด: = Root.SelectNodes ('ซีดี / ศิลปิน');
วิธีค้นหาไดรฟ์แรกในไดเรกทอรีมีดังนี้
โหนด: = Root.SelectNodes ('CD / TITLE');
และสุดท้าย:
โหนด: = Root.SelectNodes ('CD / TITLE');
ในการค้นหาดิสก์ของ Bob Dylan คุณสามารถเรียกใช้แบบสอบถามต่อไปนี้:
โหนด: = Root.SelectNodes ('CD [$ ใด ๆ $ ARTIST =” Bob Dylan ”] / TITLE');
และเพื่อให้ได้รายการดิสก์ที่สร้างขึ้นหลังปี 1985 เราเรียกใช้แบบสอบถามต่อไปนี้:
โหนด: = Root.SelectNodes ('CD / TITLE');
การอภิปรายโดยละเอียดเกี่ยวกับไวยากรณ์ XSL ต้องมีการเผยแพร่แยกต่างหาก เพื่อให้ผู้อ่านสนใจและสนับสนุนให้มีการวิจัยเพิ่มเติม ฉันจะยกตัวอย่างเพียงตัวอย่างเล็กๆ น้อยๆ ของการใช้ XSL ที่เป็นไปได้ สมมติว่าเราจำเป็นต้องแปลงแคตตาล็อกของเราเป็นตาราง HTML ปกติ โดยใช้วิธีการดั้งเดิม เราต้องวนซ้ำทุกกิ่งก้านของต้นไม้และสำหรับองค์ประกอบที่ได้รับแต่ละรายการจะสร้างแท็กที่สอดคล้องกัน
เมื่อใช้ XSL เราเพียงแค่สร้างเทมเพลต (หรือสไตล์ชีต) ที่ระบุสิ่งที่จะแปลงและวิธี จากนั้นเราก็วางเทมเพลตนี้ลงในแค็ตตาล็อกของเรา - เท่านี้ก็เรียบร้อย เรามีข้อความของเทมเพลต XSL ที่เปลี่ยนแค็ตตาล็อกให้เป็นตาราง (รายการที่ 2)
โค้ดสำหรับวางทับเทมเพลต XSL ในไดเร็กทอรีของเรามีลักษณะดังนี้:
ขั้นตอน TForm1.Button2Click (ผู้ส่ง: TObject); var XSLDoc: IXMLDOMDocument; เริ่ม XSLDoc: = CoDOMDocument.Create; XSLDoc.Load ('C: \ DATA \ DATA.xsl'); Memo2.Text: = XMLDoc.TransformNode (XSLDoc); XSLDoc: = ไม่มี; จบ;
ในการสรุปการสนทนาของเราเกี่ยวกับ XSL ควรจะกล่าวว่าในปัจจุบันภาษานี้ถูกใช้อย่างแข็งขันสำหรับการแปลงระหว่างเอกสาร XML ต่างๆ เช่นเดียวกับการจัดรูปแบบเอกสาร
บทสรุป
ด้วยเหตุผลที่ชัดเจน จึงเป็นไปไม่ได้ที่จะครอบคลุมออบเจ็กต์ Microsoft XML DOM ทั้งหมดและให้ตัวอย่างการใช้งานในบทความเดียว เราเพิ่งพูดถึงประเด็นพื้นฐานของการใช้ XML DOM ในแอปพลิเคชัน ตาราง 3 แสดงวัตถุทั้งหมดที่นำมาใช้ใน Microsoft XML DOM
คอมพิวเตอร์กด 12 "2000
สำหรับโปรแกรมเมอร์ Delphi หลายๆ คน การตั้งค่าการบันทึกเกี่ยวข้องกับการใช้ INIไฟล์ในโปรแกรมของพวกเขา ควรหลีกเลี่ยงการใช้วิธีนี้ในโปรเจ็กต์ที่จริงจังไม่มากก็น้อย เนื่องจากวิธีนี้จะจำกัดความยืดหยุ่น ซึ่งจะป้องกันไม่ให้มีการขยายโปรแกรมออกไปอีก ควรกล่าวว่าวิธีการนี้ค่อนข้างเป็นที่นิยมเนื่องจากใช้งานง่ายและมีเครื่องมือในตัวในสภาพแวดล้อมการพัฒนา
อย่างไรก็ตาม โครงสร้าง XMLไฟล์. ข้อได้เปรียบของพวกเขาคือไม่สามารถกำหนดจำนวนพารามิเตอร์ได้ เพื่อให้เข้าใจสิ่งนี้ดีขึ้น ให้พิจารณาตัวอย่างเฉพาะ
ในโปรแกรม USearch เมื่อคุณคลิกที่รายการ เมนูบริบทจะปรากฏขึ้น ซึ่งจะแสดงรายการ รายการเหล่านี้เป็นคำสั่ง ซึ่งจะถูกโหลดจากไฟล์การตั้งค่า ในกรณีที่การตั้งค่าถูกเก็บไว้ใน INIจากนั้นโปรแกรมสามารถบันทึกและโหลดคำสั่งจำนวนหนึ่งได้ เช่น 10 หรือ 50 คำสั่ง ทันทีที่ต้องการค่าที่มากขึ้น คุณจะต้องเขียนโค้ดใหม่และคอมไพล์ใหม่ตามนั้น
การใช้แนวทางโดยใช้ XMLไฟล์ เราจะสามารถโหลดพารามิเตอร์ของส่วนทั้งหมดไดนามิก นอกจากนี้ ไฟล์คอนฟิกูเรชันจะดูสวยงามยิ่งขึ้น โดยไม่มีการกำหนดหมายเลขพารามิเตอร์ซ้ำซ้อน อย่างไรก็ตาม เครื่องมือมาตรฐานในการทำงานกับ XML Delphi มีข้อเสียมากมาย ฉันจึงแนะนำให้ใช้ไลบรารี่มาตรฐาน MSXML... โดยปกติแล้วจะรวมอยู่ในระบบปฏิบัติการของตระกูล Windows ตามค่าเริ่มต้น
หากต้องการเชื่อมต่อกับ MSXMLเราจำเป็นต้องสร้างไฟล์อินเทอร์เฟซพร้อมรายการฟังก์ชันทั้งหมดโดยนำเข้าจากเซิร์ฟเวอร์ COM มีการเขียนบทความที่มีรายละเอียดมากมายเกี่ยวกับวิธีการนำเข้าอินเทอร์เฟซ แต่ฉันแนะนำให้คุณดาวน์โหลดไฟล์ MSXML2_TLB.PASพร้อมใช้. หลังจากที่ดาวน์โหลดไฟล์แล้ว ให้วางไว้ข้างโปรเจ็กต์ของคุณ หรือวางลงในโฟลเดอร์ lib ของสภาพแวดล้อม Delphi ดังนั้นโปรแกรมที่สร้างขึ้นทั้งหมดจะสามารถใช้โมดูลได้ MSXMLคุณเพียงแค่ต้องเพิ่มบรรทัด MSXML2_TLB เพื่อใช้งาน
เพื่อความชัดเจน ให้พิจารณาตัวอย่างต่อไปนี้ของการใช้ไลบรารีนี้:
ขั้นตอน LoadData; var XMLDoc: DOMDocument; ราก: IXMLDOMEองค์ประกอบ; เริ่ม XMLDoc: = CoDOMDocument.Create; XMLDoc.Load ("settins.xml"); ราก: = XMLDoc.DocumentElement; ShowMessage (Root.SelectSingleNode ("ขนาด / ความกว้าง") ข้อความ); ราก: = ไม่มี; XMLDoc: = ไม่มี; จบ;
ขั้นแรก อินสแตนซ์ของคลาส DOMDocument จะถูกสร้างขึ้น จากนั้นเนื้อหาของไฟล์ settings.xml จะถูกโหลดลงในหน่วยความจำ เนื่องจากตามมาตรฐานใด ๆ XMLไฟล์จะต้องมีแท็กรูท (ในกรณีนี้ config) จากนั้นเราต้องรับมันโดยใช้ฟังก์ชั่น เอกสารองค์ประกอบ... จากนั้นเนื้อหาจะแสดงระหว่างแท็ก
ที่นี่ใช้เมธอด SelectSingleNode ซึ่งรับสตริงเป็นพารามิเตอร์
สั่งซื้อวิธีแก้ปัญหาบน DELPHI
Delphi เป็นภาษาการเขียนโปรแกรมที่สำคัญที่สุดอันดับสองที่นักเรียนมักได้รับการแนะนำให้รู้จักในกระบวนการเรียนรู้ นี่คือจุดเริ่มต้นของการเรียนรู้เกี่ยวกับการเขียนโปรแกรมเชิงวัตถุ ในฐานะนักเรียน ฉันได้ข้อสรุปว่าไม่มีวิธีใดในการเรียนรู้ภาษาใดง่ายไปกว่าการเขียนเครื่องคิดเลข แม้ว่าคุณจะใช้ฟังก์ชันพื้นฐานสำหรับการบวกตัวเลขสองตัว มันก็จะให้ความกระจ่างขึ้นอย่างมาก
CodeGaear, Delphi 7, Lazarus เป็นคอมไพเลอร์ที่แตกต่างกัน โปรแกรมที่จะถ่ายโอนรหัสที่คุณเขียนไปยังเครื่อง แปลงเป็นอันหนึ่งอันเดียวกัน ทั้งหมดนี้คือโปรแกรมสำหรับสร้างโปรแกรม ไม่ใช่ภาษาโปรแกรมแยกต่างหาก คอมไพเลอร์เหล่านี้ใช้ภาษาการเขียนโปรแกรม Object Pascal ซึ่งเป็นพื้นฐานของภาษา Delphi ซึ่งคล้ายกับไวยากรณ์ของ Pascal ปกติ แต่การใช้งานแตกต่างกันอย่างมาก
ไวยากรณ์ของภาษาโปรแกรมคืออะไร?
นี่คือรูปแบบการเขียนโอเปอเรเตอร์ต่างๆ ตัวอย่างเช่น ลูป Pascal "for" มีรูปแบบดังนี้: "for n: = 1 to k do" เป็นต้น
ในภาษาการเขียนโปรแกรม C ++ ลูปเดียวกันเขียนต่างกันเล็กน้อย: for (n = 1; n เราเขียนเครื่องคิดเลข
สิ่งนี้จะช่วยให้คุณเข้าใจว่าอ็อบเจกต์โต้ตอบกับโค้ดโปรแกรมอย่างไร "ตัวแปร" คืออะไร และฟังก์ชันทางคณิตศาสตร์ทำงานอย่างไร การเขียนโปรแกรมใด ๆ จะเป็นการคำนวณอยู่ดี เกมยังเป็นโปรแกรมที่คำนวณบางสิ่งอย่างต่อเนื่อง ทำงานกับตัวเลขและฟังก์ชันตัวเลข การเขียนโปรแกรมแยกออกจากคณิตศาสตร์ไม่ได้
ลองใช้สภาพแวดล้อมการพัฒนาลาซารัสในการเขียน ฟังก์ชันการทำงานไม่ได้สมบูรณ์เท่ากับ CodeGear แต่ใช้งานได้ฟรีและมีไว้สำหรับการฝึกอบรม
เมื่อเปิดสภาพแวดล้อมการพัฒนา เราจะเห็นแบบฟอร์มและกล่องเครื่องมือ นี่คือแบบฟอร์ม
นี่คือกล่องเครื่องมือ
สิ่งแรกที่เราจะทำคือเพิ่มองค์ประกอบสามอย่างที่เราจำเป็นต้องใช้ฟังก์ชันเพื่อเพิ่มตัวเลขสองตัว เราต้องการ: "Tedit" จำนวนสามชิ้นและ "TButton" ในภาพด้านล่างจะแสดงบนแผงที่มีลูกศร เราคลิกที่พวกเขาหนึ่งครั้งแล้วคลิกอีกครั้งบนแบบฟอร์มและปรากฏบนนั้น
เหล่านี้เป็นฟิลด์ข้อความสำหรับป้อนข้อมูลและปุ่มปกติ คุณพบองค์ประกอบเหล่านี้โดยใช้โปรแกรม Windows เกือบทุกโปรแกรม ลองดูสิ.
มาทำความสะอาดป้ายกำกับเหล่านี้กัน คลิกแท็บ "ดู" และคลิกที่รายการ "ตัวตรวจสอบวัตถุ หน้าต่างแบบนี้จะปรากฏขึ้น
เราคลิกหนึ่งครั้งที่องค์ประกอบ "ปุ่ม" บนแบบฟอร์ม และเปลี่ยนค่า "คำอธิบายภาพ" ในหน้าต่างตัวตรวจสอบเป็นค่าอื่น ตัวอย่างเช่น คำว่า "ตกลง" เรากด Enter เราเห็นในแบบฟอร์มว่าองค์ประกอบเปลี่ยนชื่ออย่างไร
เราจะทำเช่นเดียวกันกับ Edit's เพียงแต่เราจะไม่เปลี่ยนชื่อ แต่เราจะทำให้ไม่มีเนื้อหาใด ๆ เลือกและล้างค่าข้อความในตัวตรวจสอบ อย่าลืมกด Enter
ส่งผลให้รูปร่างของเราเป็นแบบนี้
ตอนนี้ เพื่อให้เครื่องคิดเลขของเราทำงานได้ คุณต้องเขียนรหัสโปรแกรมที่จำเป็นสำหรับขั้นตอนการทำงานของปุ่มของเรา คลิกที่องค์ประกอบปุ่มสองครั้งและเปิดตัวแก้ไขแหล่งที่มา
ดู? ขั้นตอน Button1Click นี่เป็นขั้นตอนที่รับผิดชอบต่อสิ่งที่เกิดขึ้นเมื่อเราคลิกที่ปุ่มหนึ่งครั้ง และสิ่งต่อไปนี้ควรเกิดขึ้น: โปรแกรมต้องแสดงผลรวมของตัวเลขที่ป้อนในสองฟิลด์แรกในการแก้ไขครั้งที่สาม เราเขียนรหัส
เราต้องเขียนโค้ดง่ายๆ 5 บรรทัด ความคิดเห็นและคำอธิบายสามารถเห็นได้ในภาพด้านบน หลังจากนั้นเรากดปุ่มนี้
โครงการของเราจะรวบรวม จะถูกรวบรวมเป็นโปรแกรม เราป้อนตัวเลขในสองฟิลด์แรกคลิกที่ปุ่มและรับค่าของผลรวม
บทสรุป
คุณสามารถคลิกปุ่ม "ไฟล์" จากนั้น "บันทึกทั้งหมด" เลือกโฟลเดอร์ที่จะบันทึก และคุณจะมีโปรแกรมเต็มรูปแบบที่สามารถเปิดใช้งานได้จากเดสก์ท็อป ตอนนี้พยายามหาคำตอบด้วยตัวเองว่าคุณต้องเขียนโค้ดนี้อย่างไรเพื่อที่โปรแกรมจะหารตัวเลขสองตัวและไม่บวกกัน คำแนะนำ: คุณต้องเปลี่ยนประเภทข้อมูล วิดีโอด้านล่างแสดงตัวอย่างที่คล้ายกัน แต่ในสภาพแวดล้อม Delphi 7 ไม่ใช่ Lazarus
เมื่อเร็ว ๆ นี้ได้รับความสนใจอย่างมากในการสร้างระบบ e-business หรือที่เรียกว่า B2B (ธุรกิจต่อธุรกิจ) พิจารณาข้อเสนอแนะเกี่ยวกับการสร้างระบบสตรีมมิ่งแลกเปลี่ยนของหน่วยงานประสานงานของเทคโนโลยีอินเทอร์เน็ต - WWW Consortium: เน้นที่เทคโนโลยี XML และการสร้างระบบสำหรับการแลกเปลี่ยนเอกสาร XML
ข้อดีของการใช้ XML ใน e-business คือระบบ B2B ที่มีประสิทธิภาพสูงในต้นทุนต่ำสำหรับการสร้าง เนื่องจากการนำเสนอข้อมูลที่มีโครงสร้างที่ชัดเจนและเห็นภาพ ความสามารถในการใช้โปรโตคอลเครือข่ายที่ทันสมัย และสร้างระบบธุรกิจแบบเรียลไทม์
ความเป็นอิสระของการนำเสนอข้อมูลในรูปแบบของเอกสาร XML ช่วยให้บริษัทต่างๆ ที่เกี่ยวข้องกับ e-business สามารถผลิตซอฟต์แวร์ได้อย่างอิสระ
ในทุกระบบ การแลกเปลี่ยนตามกฎจะถูกสร้างขึ้นตามรูปแบบเดียวกัน โดยใช้คำขอ HTTP SSL ถูกใช้เป็นโปรโตคอลการรักษาความปลอดภัยของข้อมูล (แต่นี่เป็นหัวข้อแยกต่างหาก)
หนึ่งในตัวเลือกที่เป็นไปได้สำหรับการประมวลผลข้อความ XML คือการสร้างแอปพลิเคชัน BIN / CGI (ISAPI) หรือส่วนประกอบ COM (เซิร์ฟเวอร์) ที่สร้างหรือประมวลผลเอกสาร XML
ในอีกด้านหนึ่ง แอปพลิเคชันทำหน้าที่เป็นไคลเอนต์ ซึ่งออกคำขอ HTTP ในโหมด POST ในทางกลับกัน มีเว็บเซิร์ฟเวอร์ที่ด้านที่มีการประมวลผลคำขอและมีการตอบกลับ การแลกเปลี่ยนข้อมูลใช้เอกสาร XML
หนึ่งในตัวเลือกการใช้งานที่มีประสิทธิภาพมากที่สุดคือการใช้ตัวแยกวิเคราะห์ XML ที่มีอยู่ซึ่งสนับสนุนโมเดล DOM parser ดังกล่าวเป็นแพ็คเกจการแจกจ่ายของ Win'98 หรือเป็นส่วนสำคัญของ IE 4.7 และสูงกว่า (สำหรับ Win'95) และแสดงถึงเซิร์ฟเวอร์ COM ที่อยู่ในไลบรารี msxml.dll
Component Object Model (COM) - แสดงถึงข้อมูลและเมธอดที่ห่อหุ้มไว้ในเอนทิตีเดียว และวิธีการเข้าถึงผ่านระบบอินเทอร์เฟซ การใช้เครื่องมือ Delphi ทำให้ง่ายต่อการเข้าถึงคลาสของวัตถุ COM (สามารถรวมหลายคลาสในเซิร์ฟเวอร์ COM เดียว) อ็อบเจ็กต์เข้าถึงได้โดยการเริ่มต้นอินสแตนซ์ของคลาสผ่านระบบอินเทอร์เฟซ คำอธิบายของอินเทอร์เฟซดำเนินการโดยภาษาข้อกำหนดอินเทอร์เฟซ (IDL) ซึ่งสามารถดำเนินการโดยใช้สภาพแวดล้อมโดยอัตโนมัติ
เครื่องมือ Delphi ใช้เพื่อนำเข้าจากเซิร์ฟเวอร์ COM msxml.dllไฟล์สำหรับคำอธิบายของอินเทอร์เฟซ IDL และไฟล์สำหรับคำอธิบายไบนารีของประเภทไลบรารี - TLB ถูกสร้างขึ้น การดำเนินการนี้ดำเนินการผ่านเมนูระบบ: โครงการ | ประเภทไลบรารีนำเข้า:(ภาพที่ 1). ถัดไป กล่องโต้ตอบจะปรากฏขึ้น (รูปที่ 2) ซึ่งคุณต้องเลือกวัตถุ COM (ในกรณีของเรา วัตถุนั้นลงทะเบียนภายใต้ชื่อ "Microsoft.XMLDom (เวอร์ชัน 2.0)") และสร้างไฟล์ TLB (ปุ่ม สร้างหน่วย). เมื่อใช้ไฟล์ TLB กรอบงานจะสร้างไฟล์คำอธิบายเซิร์ฟเวอร์ "Pascal" COM - MSXML_TLB.pas
ไฟล์ MSXML_TLB.pas อธิบายอินเทอร์เฟซ ค่าคงที่ และ coclasses ทั้งหมดของเซิร์ฟเวอร์ COM
ในการเข้าถึงวัตถุขององค์ประกอบ COM คุณต้องมีคำสั่ง ใช้เพิ่มชื่อไฟล์คำอธิบายไลบรารี (MSXML_TLB.pas) ด้านล่างนี้เป็นโปรแกรมอย่างง่ายที่ใช้ DOM parser msxml.dll มาตรฐาน ซึ่งโหลดเอกสาร XML และแสดงในองค์ประกอบฟิลด์ข้อความ Memo1
ใช้ Windows, ข้อความ, SysUtils, คลาส, กราฟิก, การควบคุม, ฟอร์ม, ไดอะล็อก, OleServer, MSXML_TLB, StdCtrls; พิมพ์ TForm1 = ระดับ(TForm) Button1: TButton; บันทึกที่ 1: TMemo; ขั้นตอน Button1Click (ผู้ส่ง: TObject); จบ; varแบบฟอร์ม 1: TForm1; การนำไปใช้($ R * .DFM) ขั้นตอน TForm1.Button1Click (ผู้ส่ง: Tobject); // ประกาศของ soclass ของวัตถุ DOMDocument; var coDoc: CoDOMDocument; // คลาสที่สอดคล้องกับอินเทอร์เฟซ IDOMDocument; varเอกสาร: IXMLDOMDocument; เริ่ม // สร้างอินสแตนซ์ของวัตถุ DOMDocumentเอกสาร: = coDoc.Create; // เรียกวิธีการโหลดของอินสแตนซ์ของวัตถุ DOMDocument Doc.load ("data.xml"); // เข้าถึงคุณสมบัติ xml ของอินสแตนซ์ DOMDocument Memo1.Text: = Doc.xml; จบ; จบ.DOM Concept - Document Object Model
เอกสาร XML แต่ละรายการจะแสดงเป็นชุดของวัตถุหลายรายการ (คลาส) ด้วยความช่วยเหลือซึ่งคุณสามารถเข้าถึงองค์ประกอบแต่ละรายการ (ฟิลด์อ็อบเจ็กต์) DOM - อินเทอร์เฟซอธิบายการเข้าถึงทั้งวัตถุอย่างง่ายของประเภท DOMString หรือ CharacterData และส่วนหรือองค์ประกอบแต่ละรายการของเอกสาร XML: DOMFragmentElement, DOMNode, DOMElement
ต่อไปนี้เป็นคุณสมบัติและวิธีการที่สำคัญที่สุดของวัตถุ XMLDOMDocument, XMLDOMNode, XMLDOMNodeList ควรสังเกตว่าวิธีการและหน้าที่ของอ็อบเจ็กต์ Document Object Model (DOM) ที่แสดงด้านล่างนี้ถูกใช้โดย Microsoft XML parser msxml.dll และค่อนข้างกว้างกว่าโมเดล DOM ที่อนุมัติโดย W3C Consortium
สามารถอ่านคำอธิบายที่สมบูรณ์ยิ่งขึ้นของอินเทอร์เฟซวัตถุ DOM ได้ที่
XMLDOMวัตถุเอกสาร | |
แสดงถึงระดับบนสุดของลำดับชั้นของออบเจ็กต์และประกอบด้วยวิธีการทำงานกับเอกสาร: การโหลด การวิเคราะห์ การสร้างองค์ประกอบ คุณลักษณะ ข้อคิดเห็น ฯลฯ ... | |
คุณสมบัติ | |
อะซิงโครนัส | คุณสมบัติระบุโหมดการประมวลผลปัจจุบัน |
ParseError | ส่งกลับการอ้างอิงไปยังข้อผิดพลาดการจัดการ XMLDOMparseError การจัดการวัตถุ |
เปิดใช้งาน - ปิดใช้งานการตรวจสอบเอกสาร | |
url | ส่งกลับ URL ของเอกสาร |
เอกสารองค์ประกอบ | มีการอ้างอิงถึงองค์ประกอบรูทของเอกสารเป็นอ็อบเจ็กต์ XMLDOMElement |
วิธีการ | |
โหลด (url) loadXML (xmlString) |
โหลดเอกสาร XML |
บันทึก (objTarget) | บันทึกเอกสาร XML ลงในไฟล์ |
ยกเลิก | การหยุดชะงักของกระบวนการโหลดและประมวลผลเอกสาร |
createAttribute (ชื่อ) | สร้างแอตทริบิวต์ใหม่ด้วยชื่อที่ระบุสำหรับองค์ประกอบปัจจุบัน |
createNode (ชนิด, ชื่อ, nameSpaceURI) | สร้างโหนดของประเภทและชื่อที่ระบุ |
createElement (ชื่อแท็ก) | สร้างองค์ประกอบเอกสารที่มีชื่อที่ระบุ |
createTextNode (ข้อมูล) | สร้างข้อความภายในเอกสาร |
getElementsByTagName (ชื่อแท็ก) | ส่งกลับการอ้างอิงไปยังคอลเลกชันขององค์ประกอบเอกสารที่มีชื่อที่กำหนด |
nodeFromID (idString) | ค้นหาองค์ประกอบตาม ID |
XMLDOMNode วัตถุ | |
ออบเจ็กต์ XMLDOMNode ที่ใช้อินเทอร์เฟซ DOM พื้นฐาน โหนดมีไว้สำหรับจัดการกับโหนดที่แยกจากกันของแผนผังเอกสาร คุณสมบัติและวิธีการช่วยให้คุณได้รับและเปลี่ยนแปลงข้อมูลทั้งหมดเกี่ยวกับโหนดปัจจุบัน - ประเภท, ชื่อ, ชื่อเต็ม, เนื้อหา, รายการองค์ประกอบย่อย ฯลฯ | |
คุณสมบัติ | |
nodeName, ชื่อฐาน | ส่งกลับชื่อของโหนดปัจจุบัน |
คำนำหน้า | ส่งกลับคำนำหน้าเนมสเปซ |
ประเภทข้อมูล | ระบุประเภทเนื้อหาของโหนดปัจจุบัน |
nodeType, nodeTypeString | ส่งกลับประเภทของโหนดปัจจุบัน: |
คุณลักษณะ | รับรายการแอ็ตทริบิวต์ของโหนดปัจจุบันเป็นคอลเล็กชัน XMLDOMNamedNodeMap |
ข้อความ | ส่งกลับเนื้อหาของทรีย่อยปัจจุบันเป็นข้อความ |
xml | ส่งกลับการแสดง XML ของทรีย่อยปัจจุบัน |
nodeValue | ส่งกลับเนื้อหาของโหนดปัจจุบัน |
ลูกโหนด | ส่งคืนรายการองค์ประกอบย่อยเป็น XMLDOMNodeList |
ลูกคนแรก ลูกคนสุดท้าย | ส่งกลับลูกคนแรก / คนสุดท้าย |
ก่อนหน้าพี่น้อง ต่อไปพี่น้อง | คืนค่าพี่น้องก่อนหน้า / ถัดไป |
parentNode | มีลิงก์ไปยังองค์ประกอบหลัก |
เจ้าของเอกสาร | ส่งกลับตัวชี้ไปยังเอกสารที่มีโหนดปัจจุบัน |
วิธีการ | |
appendChild (เด็กใหม่) | เพิ่มชายน์ใหม่ในโหนดปัจจุบัน |
แทรกก่อน (newChild, refChild) | แทรกโหนดย่อยโดยจัดตำแหน่งในทรีย่อยปัจจุบันทางด้านซ้ายของโหนดที่ระบุโดย refChild |
cloneNode (ลึก) | สร้างสำเนาของรายการปัจจุบัน |
getAttribute(ชื่อ) getAttributeNode(ชื่อ) setAttribute (ชื่อ ค่า) setAttributeNode (XMLDOMattribute) |
เข้าถึงแอตทริบิวต์ (สร้าง อ่าน เขียน) ของวัตถุ ชื่อคือชื่อของแอตทริบิวต์ ค่าคือค่าของมัน ส่งกลับค่าของวัตถุ XMLDOMattribute |
replaceChild (newChild, oldChild) removeChild (ลูกเก่า) | การแทนที่วัตถุ oldChild ของรายการปัจจุบันของวัตถุลูกด้วย newChild กำลังลบวัตถุ oldChild |
selectNodes (patternString) เลือก SingleNode (patternString) | ส่งกลับวัตถุ XMLDOMNodeList ที่เลือกโดยรูปแบบการค้นหาหรือโหนดแรก |
TransformerNode (สไตล์ชีต) transformNodeToObject (สไตล์ชีต, outputObject) |
กำหนดสไตล์ชีตให้กับทรีย่อยของโหนดปัจจุบันและส่งคืนสตริงที่เป็นผลจากการประมวลผล พารามิเตอร์คือการอ้างอิงไปยังอ็อบเจ็กต์ DOMDocument ที่มีคำสั่ง XSL |
การใช้ XML ในธุรกิจ
เพื่อให้เห็นภาพชัดเจนขึ้น จำเป็นต้องมีคำอธิบาย และเหตุใดจึงต้องมีทั้งหมดนี้เพื่อให้เข้าใจถึงวิธีการทำงาน:
เมื่อสร้าง B2B หรือระบบ ERP ขององค์กร เมื่อจัดการการแลกเปลี่ยนข้อมูลของเอกสาร XML ระหว่างองค์กรหรือสาขาของ pr-I จะใช้ระบบที่ได้รับการพิสูจน์แล้วว่ามีประสิทธิภาพในการถ่ายโอนข้อมูลตามเว็บเซิร์ฟเวอร์ที่มีอยู่ผ่านโปรโตคอล HTTP
ในอีกด้านหนึ่ง แอปพลิเคชันทำหน้าที่เป็นไคลเอนต์ซึ่งออกคำขอ HTTP ในโหมด POST ในอีกทางหนึ่ง มีเว็บเซิร์ฟเวอร์ซึ่งด้านของการประมวลผลคำขอและมีการตอบกลับ เอกสาร XML ใช้เป็นการแลกเปลี่ยน
ตัวอย่างเช่น ในระบบ ERP ขององค์กรอย่างง่าย โปรแกรมบัญชี (ACS Accounting) จำเป็นต้องสร้างคำขอใบแจ้งหนี้และส่งไปยังสาขาที่มีคลังสินค้า (ACS Warehouse) AWP A คำชี้แจงปัญหาที่คล้ายกันเมื่อสร้างระบบ B2B เมื่อ Enterprise A ขอความพร้อมของผลิตภัณฑ์ (ทำการสั่งซื้อ) จากซัพพลายเออร์ B.
Enterprise A และโปรแกรมของบริษัททำหน้าที่เป็นลูกค้า คลังสินค้าให้บริการโดยซัพพลายเออร์ B ซึ่งมีคลังสินค้าพร้อมฐานข้อมูลบนเซิร์ฟเวอร์ SQL การแลกเปลี่ยนจะดำเนินการผ่านเว็บเซิร์ฟเวอร์ขององค์กรของผู้จัดหา V
ด้านล่างนี้คืออัลกอริธึมการแลกเปลี่ยนทั่วไปดังต่อไปนี้:
รูปที่ 3
- องค์กร Aผู้ริเริ่ม กระบวนการ A(การสั่งผลิต) ซึ่งทำหน้าที่เป็น Web Client
- กระบวนการ Aสร้างเอกสาร XML (เช่น คำขอใบแจ้งหนี้) และส่งเป็นคำขอ POST http ไปยังเว็บเซิร์ฟเวอร์ของผู้ให้บริการ B ตัวระบุทรัพยากรของแอปพลิเคชันการประมวลผลจะถูกใช้เป็น URI URI สามารถเหมือนกันได้สำหรับเอกสารทุกประเภท หรือเป็นรายบุคคลสำหรับแต่ละประเภท ทุกอย่างขึ้นอยู่กับโครงสร้างของเซิร์ฟเวอร์ B2B (WEB)
- เว็บเซิร์ฟเวอร์วิเคราะห์คำขอและสร้างเซิร์ฟเวอร์ กระบวนการ Bโดยส่งเนื้อความของเอกสาร XML เป็นพารามิเตอร์
เว็บเซิร์ฟเวอร์เปิดตัวกระบวนการ B และประมวลผลเป็นเพจ ASP, CGI (ISAPI) - แอปพลิเคชันหรือเซิร์ฟเวอร์ JAVA (แอปพลิเคชันเซิร์ฟเวอร์) - กระบวนการ B- สร้างคำขอไปยังเซิร์ฟเวอร์ฐานข้อมูล SQL
- เซิร์ฟเวอร์ SQL ดำเนินการที่จำเป็นในฐานข้อมูล สร้างการตอบสนองและส่งกลับ กระบวนการ B.
- ตามการตอบสนองจากเซิร์ฟเวอร์ SQL กระบวนการ Bสร้างเอกสาร XML (ตอบกลับ) และส่งคืนเป็นการตอบสนองต่อการร้องขอ http ไปยังแอปพลิเคชันไคลเอนต์
- นอกจากนี้ ขึ้นอยู่กับสถานการณ์ในฝั่งไคลเอ็นต์ อาจมีการสร้างคำขอ http ใหม่ หรือสิ้นสุดเซสชัน
คำสองสามคำเกี่ยวกับการจัดโฟลว์เอกสาร
กฎทั่วไปในการพัฒนาระบบสำหรับการแลกเปลี่ยนเอกสาร XML คือ:
- ประการแรก- การพัฒนาผังงานเอกสารอิเล็กทรอนิกส์และโครงสร้าง
- ประการที่สอง- การพัฒนาตารางฟังก์ชันของกระบวนการ (กระบวนการย่อย) เช่น ฟังก์ชันใดเกี่ยวกับเอกสาร XML ที่แต่ละกระบวนการจะนำไปใช้
เอกสาร XML แต่ละรายการ เช่นเดียวกับเอกสาร HTML จะต้องประกอบด้วยส่วนหัวของข้อความ (ข้อมูลที่ปิดด้วยแท็ก) และเนื้อหาข้อความ (สำหรับคำขอ ข้อมูลนี้จะถูกใส่กรอบด้วยแท็กเพื่อตอบสนองต่อคำขอ) เพื่อให้เอกสาร XML มีรูปแบบที่ดี จำเป็นต้องจัดเฟรมสองส่วน "ชื่อ" และ "คำขอ" ด้วยแท็ก เป็นต้น ประเภทของเอกสารทั่วไปแสดงไว้ด้านล่าง:
ส่วนหัว (รูปที่ 4) ตรงกันข้ามกับเอกสาร HTML จะต้องมีข้อมูลการบริการหลายประเภท รวมถึงข้อมูลเกี่ยวกับประเภทของเอกสารที่ส่งและขั้นตอนการประมวลผล เนื้อหาของเอกสารเข้าสู่การประมวลผลข้อมูลเช่น เนื้อหากรอบโดยแท็ก ควรสังเกตว่าโครงสร้างของหัวเรื่องควรเหมือนกันสำหรับเอกสารทุกประเภท
สำหรับกระบวนการที่เปิดใช้งานโดยเซิร์ฟเวอร์ ดีกว่า (แต่ไม่จำเป็น) เพื่อสร้างอัลกอริธึมการประมวลผลดังต่อไปนี้:
รูปที่ 6
ประเด็นพื้นฐานบางประการในการสร้างฝั่งไคลเอ็นต์
ตามที่อธิบายไว้แล้ว เมื่อสร้างเอกสาร XML จะใช้การแสดงในรูปแบบ DOM ด้านล่างนี้เป็นตัวอย่างของส่วนข้อความ Delphi ของโปรแกรมสร้างส่วนหัวของข้อความ xml
ขั้นตอน TThread1.HeaderCreate (ผู้ส่ง: Tobject); var // ประกาศคลาส จำเป็นต้องสร้าง coDoc: CoDomDocument; // XMLDomDocument วัตถุเอกสาร: DomDocument; r: IXMLDOMEองค์ประกอบ; โหนด: IXMLDOMEองค์ประกอบ; // DOMText txt: IXMLDOMTข้อความ; // DOMAttribute แอตทริบิวต์: IXMLDOMattribute; เริ่ม // สร้างเอกสาร DOMเอกสาร: = coDoc.Create; Doc.Set_async (เท็จ); // การเริ่มต้นเริ่มต้นของเอกสาร DOM Doc.LoadXML ("ควรสังเกตว่าการประกาศตัวแปร coDoc: CoDomDocument และ Doc: DomDocument ตลอดจนการสร้างโดยเมธอด Create (Doc: = coDoc.Create;) ทำได้เพียงครั้งเดียว การประกาศตัวแปรอยู่ในส่วนที่อธิบายตัวแปรโกลบอล และไม่ใช่ในโพรซีเดอร์โลคัล ตามที่ได้แสดงให้เห็นเพื่อความชัดเจนในตัวอย่างนี้ (นั่นคือ ตัวแปรโกลบอลของประเภท DomDocument หนึ่งตัวต่อหนึ่งโมดูลโปรแกรม)
ผลลัพธ์ของการทำงานของโปรแกรมข้างต้นจะเป็นส่วนหัวที่สร้างขึ้นซึ่งนำไปใช้กับเอกสาร xml ตัวอย่างของเรา: แสดงในรูปที่ 5
รูปที่ 5
รูปที่ 6
ข้อได้เปรียบหลักของการถ่ายโอนข้อมูลในรูปแบบของเอกสาร XML คือสามารถสร้างข้อความโดยใช้โครงสร้างตารางอิสระใน DBMS ทั้งในด้านการรับและการส่ง จากตัวอย่างของเรา สมมติว่าจำเป็นต้องโอนข้อมูลเกี่ยวกับใบแจ้งหนี้ของ Enterprise A จาก DBMS ที่มีโครงสร้างดังแสดงในรูปที่ 6
ในการสร้างเอกสาร xml ที่มีใบแจ้งหนี้ การสืบค้น SQL (query A) จะถูกสร้างขึ้นด้วยข้อมูลเกี่ยวกับตัวใบแจ้งหนี้เอง:
เลือก* จาก Invoice_General ที่ไหนหมายเลขใบแจ้งหนี้ =: num เลือกสินค้า คุณภาพ ราคา HZ_cod จากสินค้า ที่ไหนหมายเลขใบแจ้งหนี้ =: num //: num เป็นพารามิเตอร์ที่ระบุหมายเลขใบแจ้งหนี้ด้านล่างนี้เป็นส่วนหนึ่งของโปรแกรมที่สร้างเนื้อหาของเอกสาร xml:
ขั้นตอน TThread1.DataBodyCreate (ผู้ส่ง: Tobject); var // ประกาศคลาสและอ็อบเจ็กต์ XMLDomDocument// coDoc: CoDomDocument; // ต้องเป็นโกลบอลสำหรับทั้งโมดูล// เอกสาร: DomDocument; // ประกาศ DOMElement วัตถุ r: IXMLDOMEองค์ประกอบ; // โดมองค์ประกอบ; โหนด Node2: IXMLDOMEองค์ประกอบ; Node3, Node4: IXMLDOMEองค์ประกอบ; // DOMText txt: IXMLDOMTข้อความ; str: สตริง; // เลขใบสั่งของ: จำนวนเต็ม;- ตัวแปรโกลบอล - // มีค่า 987654 // queryA, queryB: สตริง;- ตัวแปรส่วนกลาง // มีค่าที่สอดคล้องกับคำขอ // queryA - คำขอ A พร้อมข้อมูลทั่วไปเกี่ยวกับใบแจ้งหนี้ // queryB - ขอข้อมูล B เกี่ยวกับสินค้าที่อธิบายไว้ใน // ใบแจ้งหนี้ (ดูข้อความ) เริ่มแบบสอบถาม ปิด; // ดูข้อความ "ขอ A" Query.Text: = แบบสอบถามA; // ดำเนินการตามคำขอแบบสอบถาม ExecSQL; แบบสอบถามเปิด; // รับที่อยู่ขององค์ประกอบรูท r: = Doc.Get_documentElement; Node2: = Doc.createElement ("คำขอ"); // สร้าง DOMElement (แท็ก)โหนด: = Doc.createElement ("ใบแจ้งหนี้"); // เพิ่มองค์ประกอบให้กับรูท r.appendChild (โหนด2); // เพิ่มรายการไปที่โหนด2 appendChild (โหนด); // สร้าง DOMElement (แท็ก) Node3: = Doc.createElement ("การปลดปล่อย"); // เพิ่มรายการไปที่โหนด appendChild (โหนด3); // เรียกไปที่ช่อง "Depurture" ของคำขอ str: = Query.FieldByName ("Depurture") AsString; // สร้างโหนดข้อความ = ค่าฟิลด์// กำหนดค่าให้กับโหนด // โหนดข้อความ ตัวแปร str Node.appendChild (txt); // การดำเนินการที่คล้ายกันสำหรับ tagจากขั้นตอนนี้ ข้อความต่อไปนี้ของเอกสาร XML จะถูกสร้างขึ้น:
ในการสร้างคำขอจะใช้วิธีการเปิดของวัตถุ IXMLHttpRequest:
ขั้นตอนเปิด (const bstrMethod, - method type = "POST" bstrUrl, - Server url varAsync, - Communication mode asynchronous / synchronous = true bstrUser, - username for authentication bstrPassword) - รหัสผ่านการสร้างฝั่งเซิร์ฟเวอร์ของการประมวลผลเอกสาร
ตามที่ระบุไว้ก่อนหน้านี้ การประมวลผลคำขอ HTTP สามารถจัดการได้โดยแอปพลิเคชัน CGI หรือเซิร์ฟเล็ต Java ตัวแปรของการเขียน ASP-pages ก็เป็นไปได้เช่นกัน แต่ในกรณีนี้ การถ่ายโอนข้อมูลทำได้โดยวิธี "GET" ผ่านสตริงการสืบค้นเท่านั้น อย่างไรก็ตาม การจัดการคำขอ HTTP สำหรับหน้า ASP นั้นมีประสิทธิภาพมากกว่าแอปพลิเคชัน CGI อย่างไรก็ตาม ในความคิดของฉัน ไม่สำคัญว่าจะประมวลผลอย่างไร แต่การแก้ปัญหานั้นสำคัญกว่า - วิธีสร้างโปรแกรมประมวลผล ไม่ใช่ด้วยวิธีการใด
หากจากบทที่แล้วเราตรวจสอบตัวเลือกสำหรับการสร้างเอกสาร XML แสดงว่างานของแอปพลิเคชันเซิร์ฟเวอร์นั้นตรงกันข้าม - การแยกวิเคราะห์เอกสาร XML ด้านล่างนี้เป็นส่วนหนึ่งของโปรแกรมที่แยกวิเคราะห์เอกสาร xml:
ขั้นตอน Tthread1.DataParser (ผู้ส่ง: Tobject); var // ประกาศ DOMElement วัตถุ r, FNode: IXMLDOMEองค์ประกอบ; Str ชื่อไฟล์: สตริง; พาร์: สตริง; // ประกาศ soclass และ CoDocXML, CoDocXSL, CoDocResult: CoDomDocument; // XMLDomDocument วัตถุ XMLDoc, XSLDoc, ResultDoc: DomDocument; // HttpStr: สตริง; - ตัวแปรส่วนกลางที่มีสตริงคำขอ HTTP เริ่ม XMLDoc: = coDocXML.Create; XMLDoc.LoadXML (HttpStr); // รับที่อยู่ขององค์ประกอบรูท r: = Doc.Get_documentElement; // รับค่าขององค์ประกอบ FNode: = r.SelectSingleNode ("// TypeDocument"); // รับค่าของแอตทริบิวต์ id = "Order"ชื่อไฟล์: = FNode.GetAttibute ("id"); // และการสร้างชื่อไฟล์ Order.xslชื่อไฟล์: = ชื่อไฟล์ + ". Xsl"; // สร้างเอกสาร XSLDoc XSLDoc: = coDocXSL.สร้าง; XSLDoc.LoadXML (ชื่อไฟล์); // สร้างเอกสาร XMLDoc ResultDoc: = coDocResult.Create; // ตั้งค่าโหมดการประมวลผลแบบซิงโครนัส ResultDoc.Set_async (เท็จ); // ตั้งค่าการตรวจสอบการแยกวิเคราะห์ ResultDoc.validateOnParse: = จริง; // แยกวิเคราะห์ XMLDoc โดยใช้เทมเพลต XSL XMLDoc.transformNodeToObject (XSLDoc, ResultDoc); // ตัวแปร Str ถูกกำหนดเป็นค่าข้อความ // ของเอกสารผลลัพธ์ Str: = ResultDoc.text; // ค้นหาองค์ประกอบ FNode: = r.SelectSingleNode ("// หมายเลขใบแจ้งหนี้"); // และรับค่าขององค์ประกอบ parm: = FNode.text; // ปิดคำขอเข้าถึงแบบสอบถาม ปิด; ข้อความค้นหา: = Str; // การกำหนดค่าพารามิเตอร์ Query.Params.AsString: = parm; // ดำเนินการตามคำขอแบบสอบถาม ExecSQL; จบ;จุดเด่นทั้งหมดของการแยกวิเคราะห์อยู่ที่การใช้เทมเพลต XSL ซึ่งสร้างขึ้นแยกกันสำหรับเอกสารแต่ละประเภท ผลลัพธ์ของการแยกวิเคราะห์คือสตริงการสืบค้น SQL ต่อจากนั้น การดำเนินการของสตริงการสืบค้น SQL ที่สร้างขึ้นจะทำการเปลี่ยนแปลงที่จำเป็นกับข้อมูลใน DBMS
ข้อดีของการใช้การแยกวิเคราะห์ผ่านเทมเพลตก็คือคุณจะได้รับความยืดหยุ่นของข้อมูล และคุณจะได้รับความเป็นอิสระของอัลกอริทึมอย่างสมบูรณ์จากโค้ดโปรแกรม ด้านล่างนี้คือข้อความของเทมเพลต XSL ที่ใช้ในการประมวลผลเอกสารประเภท ORDER:
จากการอธิบายตัวอย่างข้างต้น ควรสังเกตว่าการใช้คู่แท็กนั้นเป็นทางการเนื่องจาก หลังจากแยกวิเคราะห์ เอกสาร XML ที่เป็นผลลัพธ์ต้องมีอย่างน้อยหนึ่งโหนดอย่างเป็นทางการ เมธอด ResultDoc.text กำหนดค่าข้อความของ ResultDoc ที่ได้รับระหว่างการแยกวิเคราะห์เอกสาร XML ในกรณีนี้ ค่าคือทุกอย่างที่อยู่ในกรอบของแท็กคู่หนึ่ง และนั่นคือ แบบสอบถาม SQL ที่เราสร้างขึ้น
คุณสมบัติอื่นของการเขียนโปรแกรมควรสังเกตความเป็นไปได้ของการใช้พารามิเตอร์ SQL : เลขที่การใช้พารามิเตอร์ทำให้ข้อความของเทมเพลต xsl ง่ายขึ้น คำจำกัดความของค่าขององค์ประกอบที่สอดคล้องกันของโหนดของเอกสาร XML ถูกกำหนดในขั้นต้นโดยการเลือกโดยใช้ชื่อของโหนดที่เกี่ยวข้อง ตัวอย่างเช่น
XSL ได้อย่างรวดเร็ว
XSL เป็นตัวย่อที่ได้มาจากภาษาของสไตล์ชีต eXtensible ซึ่งเป็นภาษาการจัดรูปแบบสไตล์ชีต (ข้อมูล XML) ดังที่คุณเห็นจากส่วนหัว eXtensible Stylesheet Language (XSL) ใช้เพื่อจัดรูปแบบข้อมูล XML ตามคำจำกัดความ W3C XSL ประกอบด้วยสองส่วน:
- XSLT - การแปลง XSL ภาษาที่ใช้ในการแปลงหรือจัดรูปแบบ (แปลง) เอกสาร XML ดังนั้น ด้วยความช่วยเหลือของ XSLT เราจึงสามารถตัดชุดข้อมูลและรูปแบบการนำเสนอข้อมูลที่แตกต่างกันได้
- การจัดรูปแบบองค์ประกอบ องค์ประกอบเหล่านี้รวมถึงองค์ประกอบการพิมพ์ทั้งหมดของข้อมูลหลังจากประมวลผลด้วย XSL แล้ว ใช้สำหรับสร้างหน้า HTML เท่านั้น
ด้วยความช่วยเหลือของ XSLT เราสามารถเลือกข้อมูลที่เราต้องการจากไฟล์ XML และจัดเรียงในรูปแบบเพื่อนำเสนอต่อผู้ใช้ ตัวอย่างเช่น ในกรณีของเรา เราได้แปลงข้อมูล XML ในรูปแบบของแบบสอบถาม SQL การใช้ XSL แบบคลาสสิกมักจะจัดรูปแบบข้อมูลในรูปแบบของหน้า HTML หรือในรูปแบบไฟล์ RTF ที่แทบจะไม่เกิดขึ้นเลย
ไฟล์ XSL อธิบายเทมเพลต ซึ่งจะทำการแปลงข้อมูล XML กลับไปที่เทมเพลต xsl องค์ประกอบ (คำสั่ง) ต่อไปนี้สามารถแยกแยะได้ใน XSLT:
คำสั่ง XSL | คำอธิบาย |
---|---|
xsl: สมัครเทมเพลต | คำสั่งที่ระบุการใช้เทมเพลตที่ตรงกันสำหรับแอตทริบิวต์ select = "ชื่อเทมเพลต" |
xsl: คุณลักษณะ | สร้างแผนผังแอตทริบิวต์และเพิ่มลงในองค์ประกอบเอาต์พุต ชื่อพารามิเตอร์ = "ชื่อแอตทริบิวต์" เนมสเปซคือ URI เนมสเปซ (คำนำหน้าเนมสเปซ) |
xsl: เทมเพลตการโทร | เรียกเทมเพลต ชื่อแอตทริบิวต์ = "URI ไปยังเทมเพลต" |
xsl: เลือก xsl: เมื่อไร xsl: มิฉะนั้น |
การเลือกตามเงื่อนไข xsl: เมื่อ expr = "การประเมินนิพจน์ในสคริปต์", ภาษา = "ชื่อภาษา" ทดสอบ = "นิพจน์ที่ประเมิน" |
xsl: ความคิดเห็น | สร้างความคิดเห็นในเอกสารส่งออก |
xsl: สำเนา xsl: สำเนาของ |
คัดลอกโหนดปัจจุบันไปยังแหล่งเอาต์พุตหรือแทรกส่วนย่อยของเอกสารลงในโหนดโดยที่แอตทริบิวต์ select = "ชื่อโหนดต้นทาง" |
xsl: องค์ประกอบ | สร้างองค์ประกอบเอาต์พุตตามชื่อ ชื่อแอตทริบิวต์ = "ชื่อองค์ประกอบ" เนมสเปซ = "การอ้างอิงเนมสเปซ uri" |
xsl: for-each | ใช้เทมเพลตอีกครั้งกับโหนดทั้งหมดของรายการโหนด โดยแอตทริบิวต์ select จะระบุรายการของโหนด |
xsl: ถ้า | การตรวจสอบเงื่อนไข กำหนดโดยแอตทริบิวต์การทดสอบเป็นนิพจน์ |
xsl: รวม | รวมเทมเพลตภายนอกแอตทริบิวต์ href = "การอ้างอิง URI" |
xsl: เอาต์พุต | ระบุเอาต์พุตแอตทริบิวต์ method สามารถเป็น "xml", "html" หรือ "text" |
xsl: พารามิเตอร์ | ระบุค่าของพารามิเตอร์ ชื่อแอตทริบิวต์ = "ชื่อพารามิเตอร์" เลือก = "ค่า" |
xsl: การประมวลผลคำสั่ง | สร้างคำสั่งการประมวลผล ชื่อแอตทริบิวต์ = "ชื่อของกระบวนการคำสั่ง" |
xsl: sort | sorts set of nodes, คุณสมบัติ select = "node name", data-type = data type ("text" | "number" | Qname), order = sort direction ("ascending" | "descending") |
xsl: สไตล์ชีต | กำหนดเอกสารเทมเพลต xsl เป็นองค์ประกอบรูทสำหรับ XSLT |
xsl: template | กำหนดเทมเพลต xsl ชื่อแอตทริบิวต์ = "URI นำหน้าชื่อเทมเพลต" จับคู่ = "ตัวบ่งชี้ของโหนดที่ใช้เทมเพลต" |
xsl: ข้อความ | สร้างข้อความไปยังเอาต์พุตสตรีม คุณลักษณะ disable-output-escaping = "yes" หรือ "no" หมายถึงความสามารถในการสร้างอักขระ ESC |
xsl: ค่าของ | แทรกค่าของโหนดที่เลือกเป็นข้อความ, แอตทริบิวต์ select = "pointer to node" จากตำแหน่งที่รับค่า |
xsl: ตัวแปร | ระบุค่าขอบเขตตัวแปร ชื่อแอตทริบิวต์ = "ชื่อตัวแปร" เลือก = "การคำนวณค่าตัวแปร" |
xsl: พร้อมพารามิเตอร์ | ใช้พารามิเตอร์กับแม่แบบ ชื่อแอตทริบิวต์ = "ชื่อพารามิเตอร์" เลือก = นิพจน์เพื่อประเมินบริบทปัจจุบัน ค่าเริ่มต้น "" |
บทสรุป
สุดท้าย ควรสังเกตว่าการใช้ตัวแยกวิเคราะห์ XML มาตรฐาน msxml.dllไม่ใช่เครื่องมือเดียวสำหรับการแยกวิเคราะห์และสร้างเอกสาร XML ตัวอย่างเช่น ในการสร้างเอกสาร XML อย่างมีประสิทธิภาพ ให้ใช้ส่วนประกอบ TPageProduserและ ผู้ผลิตตาราง... แต่บทความนี้เน้นเฉพาะความกว้างและการบังคับใช้ของโมเดล DOM ในทางปฏิบัติเท่านั้น
ผู้เขียนจะขอบคุณมากสำหรับคำติชมเกี่ยวกับความเกี่ยวข้องของหัวข้อ เนื้อหาทั่วไป รูปแบบการนำเสนอ ตลอดจนความคิดเห็นอื่น ๆ ทั้งหมดที่จะช่วยปรับปรุงคุณภาพของการเขียนบทความและการเปิดตัวหนังสือที่ครอบคลุมหัวข้อต่อไป ด้านการปฏิบัติของการใช้เอกสาร XML ในอีคอมเมิร์ซ ข้อมูลรายละเอียดเพิ่มเติมเกี่ยวกับการใช้งานจริงของเอกสารอิเล็กทรอนิกส์สามารถดูได้จากเว็บไซต์ของผู้เขียน www.eDocs.al.ru นอกจากนี้ยังมีการวางแผนที่จะวางข้อความต้นฉบับและตัวอย่างบนไซต์ของผู้เขียน