网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

什么是XML-创新互联

这期内容当中小编将会给大家带来有关什么是XML,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

创新互联公司是专业的娄烦网站建设公司,娄烦接单;提供网站建设、成都网站建设,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行娄烦网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!

  1、XML : extensible markup language 可扩展标记语言 version="1.0"

  • 可扩展:所有的标签都是自定义的

  • 功能:数据存储

    • 配置文件

    • 数据传输

  • html 与 xml 区别

    • HTML语法松散,xml语法严格

    • html做页面展示,xml做数据存储

    • Html所有标签都是预定义的,xml所有标签都是自定义的

2、xml语法:

  • 文档声明

    • version 版本号 固定值1.0

    • encoding 指定文档的码表 默认值为iso-8859-1

    • standalone 指定文档是否独立 yes 或 no

    • 必须写在xml文档的第一行

    • 写法:

    • 属性

  • 元素 xml文档中的标签

    • 元素名称区分大小写

    • 数字不能开头

    • 文档中必须有且只能有一个根元素

    • 元素需要正确闭合

    • 元素需要正确嵌套

    • 元素名称要遵守

  • 文本

    • 转义字符 >;

    • CDATA 里边的数据会原样显示

  • 属性

    • 属性值必须用引号引起来,单双引号都行

  • 注释

  • 处理指令:现在基本不用

3、XML约束

  • 约束就是xml的书写规则

  • 约束的分类:

    • 导入xsd约束文档

    • 编写根标签

    • 引入实例名称空间 xmlns:xsi="www.w3.org/2001/XMLSchema-instance"

    • 引入名称空间 xsi:schemaLocation="www.itcast.cn/xml student.xsd"

    • 引入默认的名称空间

    • student.xsd

    • student.xml

    • 
      
          
          
              
                  
              
          
          
              
                  
                  
                  
              
              
          
          
              
                  
                  
              
          
          
              
                  
                  
              
          
          
              
                  
              
          
      
      
    • 
          
              asfd
              12
              male
          
      
      
          
              asfd
              12
              male
          
      
    • 内部dtd 在xml内部定义dtd

    • 外部dtd 在外部文件中定义dtd

    • Student.dtd

    • student.xml

    • 本地dtd文件

    • 网络dtd文件

    • 
      
      
      
      
       唯一的,必须的
      
      
      
          
              zs
              abc
              yao
          
      
    • dtd  约束不严谨

    • schema

4、XML解析

  • 解析XML可以做:

    • 如果xml作为配置文件:读取

    • 如果xml作为传输文件:写、读

  • XML解析思想:

    • 优点:不占内存,速度快

    • 缺点:只能读取,不能回写

    • 优点:因为在内存中会形成dom树,可以对dom树进行增删改查

    • 缺点:dom树非常占内存,解析速度慢

    • Document Element Text Attribute Comment

    • DOM:将文档加载到内存,形成一棵dom树(document对象),将文档的各个组成部分封装为一些对象

    • SAX:逐行读取,基于事件驱动

  • xml常用的解析器

    • 定义了一种规则

    • 使用方法

    • 使用步骤

    • XPath:

    • public classTestXPath3 {
            @Test
            publicvoidtest()throwsException{
                  SAXReaderread= new SAXReader();
                  Documentdocument= read.read("src/Dom4jTest.xml");
                  Listnodes= document.selectNodes("/bookstore//book/title");
                  for(inti= 0;i< nodes.size();i++) {
                        Nodenode= (Node)nodes.get(i);
                        System.out.println(node.getText());
                  }
            }
      }
    • selectSingleNode()

    • selectNodes()

    • 注意:要导包 jaxen...jar

    • 创建解析器 SAXReader reader = new SAXReader()

    • 解析xml 获得document对象 Document document = reader.read(url)

    • //    nodename 选取此节点。

    • //    /     从根节点选取。

    • //    //     从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置。

    • //    ..     选取当前节点的父节点。

    • //    @     选取属性。

    • //      [@属性名]    属性过滤

    • //      [标签名]     子元素过滤

    •      @Test

           //遍历所有元素节点

    •  publicvoidtest2()throwsException{
                  //创建一个xml解析对象
                  SAXReaderreader= new SAXReader();
                  //把xml文档加载到document对象中
                  Documentdocument= reader.read("src/Book.xml");
                  Elementroot= document.getRootElement();
                  treeWalk(root);
            }
            
            privatevoidtreeWalk(Elementele){
                  //输出当前节点的名字
                  System.out.println(ele.getName());
                  //ele.nodeCount()得到当前节点的所有子节点的数量
                  for(inti= 0;i
    • public classTestDom4j {
            @Test
            publicvoidtest1()throwsException{
                  //创建一个xml解析对象
                  SAXReaderreader= new SAXReader();
                  //把xml文档加载到document对象中
                  Documentdocument= reader.read("src/Book.xml");
                  Elementroot= document.getRootElement();
      //          Element bookNode = root.element("书");
      //          System.out.println(bookNode.getName());
                  //得到当前节点所有的子节点
                  Listlist= root.elements();
                  //得到第二本书对象
                  ElementsecondBook= (Element)list.get(1);
                  //得到当前节点的文本内容
                  Stringname= secondBook.element("书名").getText();
                  System.out.println(name);
            }
    • 导入jar包 dom4j.jar

    • 创建解析器

    • 解析xml 获得document对象

    • SAXReader reader = new SAXReader()

    • Document document = reader.read(url)

    • JAXP sun公司提供的解析 支持dom和sax

    • JDOM

    • DOM4J dom for java民间方式,但是是事实方式,非常好,支持dom

    • 解析xml

    • XPATH 专门用于查询

上述就是小编为大家分享的什么是XML了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注创新互联行业资讯频道。


分享标题:什么是XML-创新互联
当前网址:http://bjjierui.cn/article/dooegc.html

其他资讯