关于前后台DOM树应用
Dom对象是在程序开发中很实用而且经常会应用到的技术,通过Dom对象可以传递具有树结构的对象,有利用前台页面的诸如树的显示和相应值的处理,本文从两个方面全面解析Dom对象的应用,一是从后台得到完整的Dom形式的字符串后到前台页面组装成Dom对象,二是直接在前台页面上直接组装成一个Dom对象。
(1)后台可以得到的数据一般也分为两种类型,一是直接读取硬盘上的.xml文件生成的,这种形式可以这样调用:
DocumentBuilder builder=DocumentBuilderFactory
.newInstance().newDocumentBuilder();
Document
doc=null; //这两个类最好用org.w3c.dom.Document
String
rootPath=ZhcxtjCtrlHelp.class.getResource("").toString();
doc=builder.parse(rootPath+"ybcxtj.xml");
在后台得到Doc后如果想取值可以这么调用:
NodeList
convertList=doc.getElementsByTagName(elementName);
Element
thisNode=(Element)convertList.item(0);
String
nodeContent=thisNode.getAttribute("nodeValue");
当然方法还有很多,不再赘述。
后台得到Dom对象的另一种方式或者说情况是有时候只是一串字符串,为了前台页面的显示效果,要将其转成
Dom 对象,这个时候可以这样调用:
try {
builder=DocumentBuilderFactory
.newInstance().newDocumentBuilder();
}
catch (ParserConfigurationException e)
{
e.printStackTrace();
}
Document
doc=builder.newDocument();
Element root= doc.createElement("root");
root.setAttribute("state",state);
root.setAttribute("message",message); //state 和message 是你传递过来的参数
doc.appendChild(root);
当然,第二种方式可以自己随心所欲的控制生成的Doc的节点,只要自己控制好他们的appendChild关系即可。
如果要将这个Doc对象传到前台页面,除了ajax可以直接传递Dom对象,类似这样:
response.setContentType("text/xml;charset=UTF-8");
PrintWriter
out = response.getWriter();
out.println(dataXml);
out.flush();
out.close();
return null;
绝大多数情况下,我们还是需要先将Doc对象转换成String,然后传到前台页面的,这个从Dom对象转换成String
的方法是这样的:
OutputFormat format;
try {
format = new OutputFormat(SrcDoc);
format.setEncoding("UTF-8");
StringWriter stringOut = new
StringWriter();
XMLSerializer serial = new
XMLSerializer(stringOut, format);
// org.apache.xml.serialize.OutputFormat;
// org.apache.xml.serialize.XMLSerializer;
serial.asDOMSerializer();
serial.serialize(SrcDoc.getDocumentElement());
return stringOut.toString();
}catch
(Exception e) {
return
"<ERR/>";
}
这样,就完成了后台组装Dom对象,并以String的形式传到了前台页面。
通过后台传值的方式如何在前台如何得到后台的Dom对象?除了ajax方式的
var doc = partxmlhttp.responseXML;//得到dialogmessage Dom对象
绝大多数情况,我们需要在页面上根据后台传来的String字符串,拼装成一个Dom。这里,我们只讲基于 Windows的Explorer浏览器的Dom生成,因为就Mozilla而言,确实是与Explorer有很大差异的。
其代码是这样的:
var thisDom;
var domxml=document.getElementById("xmlstring").value; //得到从后台传过来的配置树字符串
var oDom = new ActiveXObject("MSXML2.DOMDocument.5.0"); //利用内置的ActiveX得到Dom控件
//MSXML2.DOMDocument.5.0是可选的,根据版本的不同,一般这是最新的
//因为IE从5.0版本就内嵌了这个Dom的ActiveX控件。
oDom.async = false; //默认是是异步加载,这里控制是同步加载的方式
if (strPath != null){
thisDom = oDom.load(strPath) ? oDom
: null;
//strPath是路径,可以按指定路径来加载
}else{
thisDom = oDom.loadXML(domxml) ?
oDom : null;
}
通过上面的代码,我们就在页面上得到了thisDom这个对象。
(2)第二种方式就是在前台页面直接new一个Dom对象出来,这种方式是很简单,代码如下:
var dom= new
ActiveXObject("MSXML2.DOMDocument.5.0");
dom.loadXML("<?xml version='1.0' encoding='utf-8'
?><navi></navi>");
var
root1=dom.createElement("navi");
root1.setAttribute("prikey","SQ");
var
node11=dom.createElement("name");
node11.setAttribute("text","A级");
node11.setAttribute("value","yhl_aj");
node11.text="Dimmacro";
var
node12=dom.createElement("name");
node12.setAttribute("text","B级");
node12.setAttribute("value","yhl_bj");
root1.appendChild(node11);root1.appendChild(node12);
var
root2=dom.createElement("navi");
root2.setAttribute("prikey","SB");
var
node21=dom.createElement("name");
node21.setAttribute("text","B级");
node21.setAttribute("value","bzl_bj");
root2.appendChild(node21);
dom.documentElement.appendChild(root1);
dom.documentElement.appendChild(root2);
通过这种手动设置的方式,我们就可以创建一个Dom对象了。
关于前后台DOM树应用的更多相关文章
- DOM树操作
DOM 操作 访问与树关系(节点) 绘制 DOM 树: childNodes, attributes 从一个中心元素访问其所有的直系亲属元素 访问父节点: parentNode 访问上一个兄弟节点: ...
- 通过Ztree生成页面html元素Dom树,以及拖拽改变元素的位置
zTree 是一款依靠 jQuery 实现的多功能 "树插件",http://www.treejs.cn/v3/main.php#_zTreeInfo,功能强大,不多赘述. 下面我 ...
- 【VB6】使用VB6创建和访问Dom树【爬虫基础知识 】
使用VB6创建和访问Dom树 关键字:VB,DOM,HTML,爬虫,IHTMLDocument 我们知道,在VB中一般大家会用WebBrowser来获取和操作dom对象. 但是,有这样一种情形,却让我 ...
- jquery: json树组数据输出到表格Dom树的处理方法
项目背景 项目中需要把表格重排显示 处理方法 思路主要是用历遍Json数组把json数据一个个append到5个表格里,还要给每个单元格绑定个单击弹出自定义对话框,表格分了单双行,第一行最后还要改ro ...
- jQuery操作列表数据转成Json再输出为html dom树
jQuery 把列表数据转成Json再输出为如下 dom树 <div id="menu" class="lv1"> <ul class=&qu ...
- 【浏览器渲染原理】渲染树构建之渲染树和DOM树的关系(转载 学习中。。。)
在DOM树构建的同时,浏览器会构建渲染树(render tree).渲染树的节点(渲染器),在Gecko中称为frame,而在webkit中称为renderer.渲染器是在文档解析和创建DOM节点后创 ...
- dom树的介绍,及原理分析
三.解析和DOM树的构建 1.解析: 由于解析渲染引擎是一个非常重要的过程,我们将会一步步的深入,现在让我们来介绍解析. 解析一个文档,意味着把它转换为一个有意义的结构——代码可以了解和使用的东西,解 ...
- 页面全部加载完毕和页面dom树加载完毕
dom树加载完毕 $(document).ready()//原生写法document.ready = function (callback) { ///兼容FF,Google ...
- 从Chrome源码看浏览器如何构建DOM树
.aligncenter { clear: both; display: block; margin-left: auto; margin-right: auto } p { font-size: 1 ...
随机推荐
- 【祥哥带你玩HoloLens开发】了解如何实现远程主机为HoloLens实时渲染
今天有一个兄弟在群里讲到他们的项目模型比较大,单用HoloLens运行设备的性能无法满足需要,问道如何将渲染工作交给服务器来做,讲渲染结果传给HoloLens.正好刚刚看官方github的时候发现一个 ...
- ios crash log
1.IOS策略 1.1 低内存闪退 前面提到大多数crash日志都包含着执行线程的栈调用信息,但是低内存闪退日志除外,这里就先看看低内存闪退日志是什么样的.我们使用Xcode 5和iOS 7的设备模拟 ...
- 为什么要用Android Studio?
为什么要用Android Studio 本书节选自<Android Studio实用指南> 作者: 毕小朋 目前本书已上传到百度阅读,在百度中搜索[Anroid Studio实用指南]便可 ...
- jquery下的提交,点击按钮没反应,post方法不执行 JSON方式在FORM表单下不起作用
jquery下的提交,点击按钮没反应,post方法不执行 JSON方式在FORM表单下不起作用
- OpenNebula 4.0 Beta 新特性介绍
http://blog.chinaunix.net/uid-20940095-id-3561376.html 2013年3月26号,OpenNebula社区发布了OpenNebula 4.0 Beta ...
- Cisco VPP启动流程
Cisco VPP启动流程,有需要的朋友可以参考一下. VPP初始化 VLIB_INIT_FUNCTION用来定义构造函数,注册函数到vlib_main_t->init_function_reg ...
- Zookeeper使用--开源客户端
一.ZkClient ZkClient是在Zookeeper原生API接口之上进行了包装,是一个更易用的Zookeeper客户端,其内部还实现了诸如Session超时重连.Watcher反复注册等功能 ...
- ant+proguard签名打包 .jar
ant+proguard签名打包 .jar 摘自: https://blog.csdn.net/a_ycmbc/article/details/53432812 2016年12月02日 14:52:3 ...
- 爬虫框架scrapy的基本内容
Scrapy介绍 Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 可以帮助用户简单快速的部署一个专业的网络爬虫.如果说前面我们写的定制bs4爬虫是”手动挡“,那Scrapy就相当 ...
- 编写高质量代码改善C#程序的157个建议——建议82:Parallel简化但不等同于Task默认行为
建议82:Parallel简化但不等同于Task默认行为 建议81说到了Parallel的使用方法,不知道大家是否注意到文中使用的字眼:在同步状态下简化了Task的使用.也就是说,在运行Paralle ...