XML:可扩展标记语言!

  01.很像HTML

  02.着重点是数据的保存

  03.无需预编译

  04.符合W3C标准

可扩展:我们可以自定义,完全按照自己的规划来!

标记:计算机所能认识的信息符号!

   比如: int num = 5;    教材编号

XML的组成部分:
  01.文档声明  <?xml version="1.0" encoding="UTF-8">

  02.元素  <p></p>

  03.属性  <p id="haha"></p>

  04.注释  <!-- -->

  05.特殊字符

  06.CDATA区域  Character data  字符数据

  07.处理指令  引入css样式

<school>
<grade name="一班">
<student name="A"></student>
</grade>
</school>

注意点:

  01.xml文件中只能有一个根节点

  02.节点要成对出现  有开发和闭合

  03.节点必须正确的嵌套!!!

    比如不能出现以下格式代码:(嵌套格式不对!!!)

<学校>
<班级 名称="一班">
<学生 姓名="A">
</班级>
</学生>
</学校>

  04.严格区分大小写

  05.空格和换行都是特殊字符  会被解析器解析

XML,HTML都是一个类似于倒挂的树!

只有一个根节点,枝叶茂盛!

我们把这个倒挂的数称之为===》dom数!

DOM:(Doucument  Object  Model)文档对象模型

特殊字符:

>      &gt;

<      &lt;

&      &amp;

'       &apos;

"       &quot;

CDAT区域:XML解析器不会处理,而是当成字符串原样输出!

<![CDATA[xml内容]]>

解析xml文件的方式:

  01.DOM:基于xml文档树结构的解析,把xml文件中的内容读取到内存中,比较占内存,消耗资源多!

  02.SAX:基于事件的解析。消耗资源小!

  03.JDOM:针对于Java的特定模型!满足2  8原则!自身没有解析器,依赖于SAX2!

  04.DOM4J:for(4)JDOM的一个分支!源码开放,性能优异,功能强大!

创建第一个maven项目:
  1.new  project===>maven==>quick==>archetypeCatalog=internal
  2.引入需要的pom节点
  3.自定义一个xml文件  (学校  年级  班级)
  4.需求通过dom4j实现查询学校下面的年级以及班级信息
  5.创建一个测试类 书写代码

DTD:Document Type Definition(文檔類型定義)
  01.规范我们的编码
  02.在浏览器中正常的显示

<!ELEMENT school (grade+),(class|student)>
ELEMENT :元素,关键字
school:元素名称
grade:子元素或者元素类型  CDATA  PCDATA (Parse)解析数据,不能包含子元素

  ():用来给元素分组
  | :两者必须选择一个
  + : 1-N,至少出现一次
  * : 0-N,可有可无,并且可以多次
  ?: 0|1,最多一次
  ,:元素出现的顺序

DTD文档使用方式:
  01.内部DTD
    <!DOCTYPE 根元素[定义的内容]>

  02.外部DTD
    <!DOCTYPE 根元素 SYSTEM "dtd文件位置">

  03.内外部DTD
    <!DOCTYPE 根元素 SYSTEM "dtd文件位置"[定义的内容]>

关于XML的一些事的更多相关文章

  1. XLT格式化XML那点事(C#代码中的问题解决)(二)

    接上篇<XML通过XSL格式化的那点事(XML到自定义节点折叠显示)>,本文就如何将大的XLST分割成小文件和如何用C#将XML通过XSL生成HTML文件中的问题做下分析,避免有同样需求的 ...

  2. XML的一些事

    XML文件的优缺点: 使用XML作为传输格式的优势: 1. 格式统一, 符合标准 2. 容易与其他系统进行远程交互, 数据共享比较方便 3.调用将 XML 用作传输的现有服务. 4.使用 XSLT 可 ...

  3. XML通过XSL格式化的那点事(XML到自定义节点折叠显示)

    引言 有时我们想看下系统生成的XML文件(如XML格式的Project文件),如果文件结构简单,我们浏览器看起来还比较方便,但是随着XML schema复杂后就变得让人头疼啦,单独写一个程序去做展现又 ...

  4. 两年来的core折腾之路几点总结,附上nginx启用http2拿来即用的配置

    序:一年多没更新博客园的内容了,core已经发生了翻天覆地的变化,想起2014年这时候,我就开始了从当时还叫k的那套preview都不如的vnext搭建这套系统,陆陆续续它每一次升级,我也相应地折腾, ...

  5. SSM-MyBatis-04:Mybatis中使用properties整合jdbc.properties

    ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------properties整合jdbc.properties首先准备好jdbc.properties,里面的key值写 ...

  6. redis数据结构和常用命令

    redis常用数据结构 String 最简单的K_V,value可以是数字或者字符串,使用场景:微博数.普通计数,命令:get set incr(加1) decr(减1) mget(获取多个值),se ...

  7. SpringMVC静态资源拦截的问题

    通常在web.xml中的核心控制器的DispatcherServlet中的url-pattern属性配置成类似“/”的拦截路径,但是会出现静态资源找不到的问题,比如js脚本.图片.css等无法加载,那 ...

  8. 不可不知的 Android strings.xml 那些事

    相信 strings.xml 已经是大家在 Android 开发中最熟悉的文件之一了,但其实它也有很多需要注意的地方和一些小技巧,知道了这些可以让你的 Android 应用更加规范易用,大家来看看吧. ...

  9. java web开发中的奇葩事web.xml中context-param中的注释

    同事提交了代码.结果除同事之外,其他人全部编译报错.报错说web.xml中配置的一个bean 没有定义.按照报错提示,各种找,无果. 由于代码全部都是提交到svn主干,之前也没有做过备份,只能一步一步 ...

随机推荐

  1. ESP8266-Station模式--我想连上谁

    Station模式又叫做站点工作模式,类似于无线终端 处于Station模式下的ESP8266,可以连接到AP.通过Station(简称为“STA”)模式,ESP8266作为客户端连接到路由的wifi ...

  2. Python---webserver

    一. # HTTP项目实战 - 深入理解HTTP协议 - 模拟后台服务程序基本流程和大致框架 - 每一个步骤一个文件夹 - 图解http协议,图解tcp/ip协议 # v01-验证技术 - 验证soc ...

  3. javascript(腾讯)

    var a={key:"1",value:2}; war b=a; b.value+=a.key, 打印b.value是多少,a.value呢? 答案:都是21.因为javascr ...

  4. 获取树莓派ip地址的方法

    1.有显示器​ (1)鼠标停留在屏幕右上角网络图标上,2-3秒会显示网络连接信息​(2) 图形界面下打开终端运行ifconfig命令 2.登录路由器​查看名叫raspberry的设备 3.电脑上运行命 ...

  5. vertical-greenplum

    https://github.com/sumitchawla/docker-vertica You can either pull the image from Docker Registry usi ...

  6. Django 的 CBV&FBV

    Django FBV, function base view  视图里使用函数处理请求 url 1 url(r‘^users/‘, views.users), views 1 2 3 4 5 from ...

  7. webUploader---实现大文件断点续传

    核心原理: 该项目核心就是文件分块上传.前后端要高度配合,需要双方约定好一些数据,才能完成大文件分块,我们在项目中要重点解决的以下问题. * 如何分片: * 如何合成一个文件: * 中断了从哪个分片开 ...

  8. php大文件上传支持断点上传

    文件夹数据库处理逻辑 publicclass DbFolder { JSONObject root; public DbFolder() { this.root = new JSONObject(); ...

  9. 线程工具类ThreadUtils

    package yqw.java.util; public class ThreadUtils { /**     * showThreadInfo     *      * @return     ...

  10. 命令行创建 vue 项目(仅用于 Vue 2.x 版本)

    1 .安装 Node.js 和 npm ( 验证安装成功输入下图 1 命令行可得 2:输入命令行 3 可得 4 即安装成功) 2.安装全局 webpack (安装依照下图输入命令行 1 耐心等待至到出 ...