注:我主要参考网上一篇文章名为:《VB和VB.NET中的XML操作》文章url:http://www.wrclub.net/study/listarticle.aspx?id=1459
在里面里介绍了大体过程,但是,在我的实际应用过程中
Dim mySDD As System.Xml.XmlDataDocument
myXDD = New System.Xml.XmlDataDocument(Me.dsMaster1)
myXDD.Load ("dataOnly.xml")
SetBindings(Me.dsMaster1)
SetBindings这一方法始终不知道是什么东西,在msdn里也找不到,所以最后还是没有按照他的文章方法实现。参照了一下msdn,不过此文章对我的帮助还是比较大,虽然也导致我走了一些弯路。
在这里主要帖出两个事件,即将xml载入到datagrid中的办法:
'如果直接使用ds做datasource则不会展开datagrid,用dv则可以直接显示正确。
Dim ds As DataSet = New DataSet
ds.ReadXml(xmlFile)
Dim tb As DataTable
Dim dv As DataView
tb = ds.Tables(0)
dv = New DataView(tb)
'DataGrid1.DataSource = dv
'DataGrid1.DataMember = "testXmlMember"
'DataGrid1.DataMember = "employeefname"
'Dim dxd As New XmlDataDocument
DataGrid1.SetDataBinding(dv,"")
xmlDD = New XmlDataDocument(ds)
注意ds和xmlDD这两个引用变量的位置。查找msdn可以找到对应的帮助。具体就是避免重复绑定的错误。
另外一个事件在保存事件中,只要直接调用:
xmlDD.Save(xmlFile)
即可
这样就可以实现xml显示在grid中,然后通过保存,把grid中的内容保存到xml文件中。
万事开头难,开个头,接下来的就不那么难了!
如果用.net来操作xml,我想主要用到的类也就是XMLDocument、XMLReader、XMLWriter.以及他们的衍生类,在MSDN里可以找到!
接下来的任务就是:获取某一节点,然后只需要更新某一节点,以及通过xml关系表映射关系到正确对象等问题了!