XML Data Binding
This 60 second overview shows you the basic concept of generating source code from an XML Schema using Liquid XML Data Binder.
What is XML Data Binding?
XML Data Binding enables you to load XML Documents into a strongly typed object model within your source code.
Meaning fewer coding errors, reduced development and testing time, increased conformance and coding reliability.
Liquid XML Data Binder Features
- Generates an easy to use class library for Visual Basic 6.
- Generated HTML documentation for your class library API.
- Supports Smart Device platforms Android and iOS.
- Supports W3C XML Schema XSD, XDR and DTD standards.
- Support for the most complex XML standards.
- Royalty free distribution of compiled code and runtime.
XML Code Generator for Visual Basic
Platform Support - No other product supports Visual Basic 6
Legacy VB6 COM component which can be used from any COM compliant environment such as Delphi, Business Objects, and ASP.
Liquid XML is the only XML Data Binding solution for Visual Basic 6.
Easy migration path to VB.Net
We provide a simple migration path to VB.Net and C#. Any code you write for VB6 is easily ported to .Net as the library interfaces are very similar.
Ease of Use
Strongly Typed Code
Liquid XML Data Binder creates simple intuitive code from your XML Schema. The generated code library contains strongly typed classes, collections, and enumerations to create an intuitive custom API to code against. Allowing you to concentrate on writing your Business logic code.
Properties
The generated classes expose the values in the XML as simple properties (getters and setters) allowing values to be easily manipulated.
Customisable Code
The generated output may also be modified within special 'Hand Coded Blocks', changes inside these blocks are persisted when the library is re-generated, allowing the library to be customised to fit the projects needs.
A Simple XML Data Binding Example for VB
The following VB example we will use the Person.xsd, shown below to demonstrate how to read and write an XML document based on this schema.
<?xml version="1.0" encoding="utf-8" ?> <!--Created with Liquid Studio --> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema"> <xs:element name="Person"> <xs:complexType> <xs:sequence> <xs:element name="Name" type="xs:string" /> <xs:element name="DateOfBirth" type="xs:date" /> <xs:element minOccurs="0" name="Address"> <xs:complexType> <xs:sequence> <xs:element name="HouseNo" type="xs:int" /> <xs:element name="PostCode" type="xs:string" /> </xs:sequence> </xs:complexType> </xs:element> <xs:element minOccurs="0" maxOccurs="unbounded" name="Car"> <xs:complexType> <xs:sequence> <xs:element name="Make" type="xs:string" /> <xs:element name="Model" type="xs:string" /> </xs:sequence> </xs:complexType> </xs:element> </xs:sequence> </xs:complexType> </xs:element> </xs:schema>
<?xml version="1.0" encoding="utf-8" ?> <!--Created with Liquid Studio --> <Person> <Name>Fred</Name> <DateOfBirth>1978-06-26</DateOfBirth> <Address> <HouseNo>7</HouseNo> <PostCode>WV6 6JY</PostCode> </Address> <Car> <Make>Escort</Make> <Model>Ford</Model> </Car> <Car> <Make>Elise</Make> <Model>Lotus</Model> </Car> </Person>
Example VB code to create the PersonSample.xml document using the strongly typed XML Data Binding generated code:
' create the root item person Dim person As New Person person.Name_ = "Fred" person.DateOfBirth.SetDate 1978, 6, 26 ' add address Dim address As New Address Set person.Address = address person.Address.HouseNo = 7 person.Address.PostCode = "WV6 6JY" ' add car1 cars to collection Dim car1 As New Car person.Cars.Add car1 car1.Make = "Ford" car1.Model = "Escort" ' add car2 cars to collection Dim car2 As New Car person.Cars.Add car2 car2.Make = "Lotus" car2.Model = "Elise" ' write xml document to string Debug.Print person.ToXml ' write xml document to file person.ToXmlFile "SampleFile.xml"
The XML Data Binding code is much easier to read and more concise than equivalent code written using generic DOM technology.
The strongly typed API allows errors to be detected at compile time should the data model change as opposed to DOM code where any errors will only be picked up in testing.
Example VB code to read the PersonSample.xml document using XML Data Binding:
' create the root item person Dim person As New Person Dim car As Car ' load the items into the model person.FromXmlFile "SampleFile.xml" ' read items from the model Debug.Print person.Name_ & " was born " & _ person.DateOfBirth.ToString & ", and lives at " & _ person.Address.HouseNo & ", " & _ person.Address.PostCode Debug.Print "Cars Owned (" & person.Cars.Count & ")" For Each car In person.Cars Debug.Print " " & car.Make & ", " & car.Model Next
The XML Data Binding code provides the majority of the parsing for you, so manipulating the XML objects is a simple task of dealing with collections of strongly typed objects.
This is much easier than using generic DOM code, where you need to continually check the data type of an item.
In Summary
Easier to Code
XML Data Binding makes it significantly easier to deal with XML documents from within your VB code, resulting in less code, which is simpler to read and maintain.
Easier to Test
As the generated class library is strongly typed, it forms a template for the developer, ensuring that the data created is valid and conforms to the underlying XML Schema.
Easier to Maintain
The maintenance phase of a project also befits as XML Data Binding allows any errors introduced because of changes in the data model to be caught early at compile time, unlike weakly typed DOM trees, which will give no indication of a problem until runtime. These kinds of changes can be a major cause of bugs which can only be caught in testing. Being able to identify these at compile time can save a significant amount of time and effort.