注:我主要参考网上一篇文章名为:《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关系表映射关系到正确对象等问题了!