XML 第一趴

1.表单提交方式(******)
    * 使用submit提交
        <form>
            ......
            <input type="submit">
        </form>

    * 使用button提交表单
       
        //实现提交方法
        function form1(){
            //获取form
            var form1 = document.getElementById("formid");
            //设置action
            form1.action = "Hello.html";
            //提交form表单
            form1.submit();
        }
    * 使用超链接提交
        - 代码
        <a href="Hello.html?username=123456">使用超链接提交</a>
    * onclick:鼠标点击事件
      onchange:改变内容(一半和select一起使用)
      onfocus:得到焦点
      onblur:失去焦点

2.xml的简介(了解)
    * eXtensible Markup Language:可扩展标记型语言
        ** 标记型语言:html是标记型语言
            - 也是使用标签来操作
        ** 可扩展:
            - html里面的标签是固定的,每个标签有特定的含义
            - 标签可以自己定义,可以写中文的标签 <person></person><猫></猫>

    * xml用途:
        ** html适用于显示数据,xml也可以显示数据(不是主要功能)
        ** xml主要功能:为了存储数据

    * xml是w3c组织发布的技术
    * xml有两个版本 1.0 1.1
        - 使用都是1.0版本 (1.1版本不能向下兼容)

3.xml的应用
    * 不同的系统之间传输数据
        ** QQ之间数据传输
        ** 画图说明
    * 用来表示生活中有关系的数据

    * 经常用在配置文件
        * 比如连接数据库,肯定知道数据库的用户名和密码,数据名称
        * 如果修改数据库的信息,不需要修改原代码,只要修改配置文件就可以了

4.xml的语法
    (1)xml的文档声明(***)
    * 创建一个文件 后缀名是 .xml
    * 如果写xml,第一步 必须要有 文档声明(写了文档声明之后,表示写的是xml文件的内容)
    ** <?xml version="1.0" encoding="gbk"?>
    *** 文档声明必须写在 第一行第一列

    * 属性
        - version:xml的版本 1.0(使用) 1.1
        - encoding:xml编码 gbk utf-8 iso8859-1(不包括中文)
        - standalone:是否需要依赖其他文件 yes/no

    * xml中文乱码的解决(******)
        - 原因:文件编码utf-8,保存到本地硬盘gbk(张三转到gbk码表,对应99 98),打开xml文件设置编码utf-8(到utf-8码表里面找张三对应值,不是99 98)---出现乱码

        - 解决办法:设置保存时候的编码和打开时候的编码一致

    (2)定义元素(标签)(***)
    (3)定义属性(***)
    (4)注释(***)
    (5)特殊字符(***)
    (6)CDATA区
    (7)PI指令

5.xml元素(标签)的定义
    ** 标签定义

    ** 标签定义又开始必须有结束:<person></person>
    ** 标签没有内容,可以标签内结束:<aa/>
    ** 标签可以嵌套,必须合理嵌套
        不合理嵌套:<aa><bb></aa></bb>
    ** 一个xml中,只能有一个根标签,其他标签都是这个标签下面的标签

    ** 在xml中把空格和换行都当成内容来解析:
        *** 下面两段代码含义不一样:
        <aa>http://www.baidu.com</aa>
        <aa>
            <http://www.baidu.com>
        </aa>

    ** xml中标签命名规则
        (1)xml代码区分大小写
            <p> <P>:这两个标签是不一样的
        (2)xml的标签不能以数字和下划线开头
            <2s> <_dfe>:这样是不正确的
        (3)xml的标签不能以xml、XML、Xml等开头
            <xml> <XML> <Xml>:这些是不正确的

6.xml中属性的定义
    * html是标记型文档,可以有属性
    * xml也是标记型文档,可以有属性

    * <person id1="111" id2="222"></person>

    ** 属性定义的要求:
        (1)一个标签上可以有多个属性
            <person id1="111" id2="222"></person>
        (2)属性名称不能相同
        (3)属性名称和属性值之间使用=,属性值使用也好抱起来(可以单引号,也可以是双引号
        (4)xml属性的名称规范和元素的名称规范一致

7.xml的注释
    * 写法:<!-- xml的注释 -->
    ** 注意的地方
        **** 注释不能嵌套
            <!-- <!-- xml的注释 --> -->

8. xml的特殊字符
    * 如果在xml中显示 a<b ,不能正常显示,这里把 < 当作标签
    * 如果要显示,要对特殊字符 < 转义
    * <   &lt;
    * >   &gt;
    * &   &amp;
    * "   &qout;
    * '   &apos;

9.CDATA区
    * 可以解决多个字符都需要转义的操作 if(a<b && b<c && d>f) {}
    * 把这些内容写到CDATA区,就不需要转义了
    ** 写法:
        <![CDATA[  内容  ]]>
        - 代码
        <![CDATA[if(a<b && c<d && e>f)]]>

    ** 把特殊字符,当作文本内容,而不是标签

10.PI指令(处理指令)
    * 可以在xml中设置样式
    * 写法:<?xml-stylesheet type="text/css" href="css的路径"?>

    * 设置样式,只能对英文标签名称作用,对于中文的标签名称不起作用的。

    ** xml的语法的总结
        所有 XML 元素都必须有关闭标签
        XML 标签对大小写敏感
        XML 必须有正确的嵌套顺序
        XML 文档必须有根元素(只有一个)
        XML 属性值需加引号
        特殊字符必须转义 -----CDATA
        XML 中的空格 回车换行在解析时被保留

11.xml的约束
    * 为什么需要约束?
    ** 比如现在定义一个person的xml文件,只想要这个文件里面保存人的恶信息,比如name、age等,但是如果在xml文件中写了一个标签<猫>,发现可以正常显示,因为符合语法规范。但是猫不是人的信息,xml的标签是自定义的,需要技术来规定xml中只能出现的元素,这个时候需要约束。

    * xml的约束技术:dtd约束 和 schema约束(看懂)

12.dtd的快速入门(看懂)
    * 创建一个文件 后缀名.dtd

    步骤:
        (1)看xml中有多少个元素,有几个元素,在dtd文件中写几个<!ELEMENT>
        (2)判断元素是简单元素还是复杂元素
            - 复杂元素:有子元素的元素
                <!ELEMENT 元素名称(子元素)>
            - 简单元素:没有子元素
                <!ELEMENT 元素名称(#PCDATA)>
        (3)需要在xml文件中引入dtd文件
            <!DOCTYPE 根元素名称 SYSTEM "dtd文件的路径">

    ** 打开xml文件使用浏览器打开的,浏览器只负责校验xml的语法,不负责校验约束
    ** 如果想要校验xml的约束,需要使用工具(inteliJ IDEA)

    ** 打开工具
        *** java web目录下,创建项目5.9xml
        *** 在5.9xml的src目录下创建一个xml文件和一个dtd文件
        *** 当xml中引入dtd文件之后,比如只能出现name、age,多写一个a会提示出错

13.dtd的三种引入方式
    (1)引入外部的dtd文件
        <!DOCTYPE 根元素名称 SYSTEM "dtd文件的路径">
    (2)使用内部的dtd文件
        <!DOCTYPE person [
            <!ELEMENT person (name,age)>
            <!ELEMENT name (#PCDATA)>
            <!ELEMENT age (#PCDATA)>
            ]>
    (3)使用外部的dtd文件(网络上的dtd文件)
        <!DOCTYPE 根元素 PUBLIC "DTD名称" "DTD文档的URL">
        - 后面学到框架 struts2 使用配置文件 使用 外部的dtd文件
        - <!DOCTYPE struts PUBLIC  "-//Apache software Foundation//DTD struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd">

14.使用dtd定义元素
    * 语法:<!ELEMENT name (#PCDATA)>    

    * 简单元素:没有子元素的元素
        <!ELEMENT name (#PCDATA)>
        *** (#PCDATA):约束name是字符串类型
        *** EMPTY:元素为空(没有内容)
            - <sex></sex>
        *** ANY:任意

    * 复杂元素:
        <!ELEMENT person (name,age,sex,school)>
            - 子元素只能出现一次
        * <!ELEMENT 元素名称 (子元素)>

        * 表示子元素出现的次数
            + : 表示一次或者多次
            ? : 表示零次或者一次
            * : 表示零次或者多次

        * 子元素直接使用逗号 , 进行隔开
            ** 表示元素出现的顺序

        * 子元素直接使用 | 隔开
            ** 表示元素只能出现其中的任意一个

15.使用dtd定义属性
    * 语法:<!ATTLIST 元素名称
                属性名称 属性类型 属性的约束
            >
    * 属性类型:
        - CDATA:字符串
        - 枚举:表示只能在一定的范围内出现值,但是只能每次出现其中的一个
            ** (aa|bb|cc)
            - <!ATTLIST age
                ID2 (AA|BB|CC) #REQUIRED
            >

        - ID:值只能是字母活着下划线开头
            - <!ATTLIST name
                ID3 ID #REQUIRED
                >

    * 属性的约束
        - #REQUIRED:属性必须存在
        - #IMPLIED:属性可有可无
        - #FIXED:表示 固定值 #FIXED "AAA"
            - 属性的值必须是设定的这个固定值
            - <!ATTLIST birthday
                    ID4 CDATA #FIXED "ABC"
                >
        - 直接值
            * 不写属性,使用直接值
            * 写了属性,使用设置的值
            - <!ATTLIST school
                    ID5 CDATA "WWW"
                >
    - 看懂下面代码
    
    <!ATTLIST 页面作者
        姓名 CDATA #IMPLIED
        年龄 CDATA #IMPLIED
        联系信息 CDATA #REQUIRED
        网站职务 CDATA #FIXED "页面作者"
        个人爱好 CDATA "上网"
    >
16.实体的定义
    * 语法:<!ENTITY 实体名称 "实体的值">
    *** <!ENTITY TEST "CALL ME MAYBE">
    *** 使用实体(写在 标签中间) &实体名称; 如:&TEST;

    ** 注意
        * 定义实体需要写在内部dtd里面,如果写在外部的dtd里面,内容可能会取不到

17.xml解析的简介(java代码)(!!!!!Most Important,面试会问啊!!!)
    * xml是标记型文档
    * js使用dom解析标记型文档?
        - 根据html的层级结构,在内层中分配一个属性结构,把html的标签、属性和文本都封装成对象
        - document对象、element对象、属性对象、文本对象、Node节点对象

    * xml的解析方式(技术):dom 和 sax
        * dom方式分析:跟html的解析方式相似,根据xml的层级结构在内存中分配一个树形结构,把xml的标签、属性和文本都封装成对象
            * 使用dom方式解析xml时,如果文件过大,造成内存溢出
            * 使用dom的优点:方便实现增删改操作

        * sax解析过程:
            *** 采用事件驱动,边读边解析:从上到下,一行一行的解析,解析到某一个对象,把对象名称返回。

            * 使用sax方式不会造成内存溢出,实现查询
            * 使用sax方式,不能实现增删改操作

    * 想要解析xml,首先需要解析器

    ** 不同的公司和组织提供了 针对dom和sax方式的解析起,通过api方式提供

    *** sun公司提供了针对dom和sax解析器 jaxp
    *** dom4j组织,针对dom和sax解析器  dom4j(**** 实际开发 *****)
    *** jdom组织,针对dom和sax解析起   jdom

18.jaxp的api的查看
    ** jaxp是javase的一个部分

    ** jaxp解析器在jdk的javax.xml.parsers包里面
        ** 四个类:分别是针对dom和sax解析使用的类
        *** dom:
            DocumentBuilder:解析器类
                - 这个类事一个抽象类,不能new,此类的实例可以从 DocumentBuilderFactory.newDocumentBuilder()方法获取
                - 一个方法,可以解析xml,parser("xml路径") 返回Document整个文档
                - 返回的document是一个接口,父节点是Node,如果在document里面找不到想要的方法,到Node里面去找

                - 在document里面方法
                     getElementsByTagName(String tagname)
                    -- 这个方法可以得到标签
                    -- 返回集合 NodeList

                     createElement(String tagName)
                    -- 创建标签

                     createTextNode(String data)
                    -- 创建文本

                     appendChild(Node newChild)
                    -- 把文本添加到标签下面

                     removeChild(Node oldChild)
                    -- 删除节点

                     getParentNode()
                    -- 获取父节点

                     NodeList
                    -getLength() 得到集合的长度
                    -item(int index) 下标取到具体的值

                    for(int i=0;i<List.getLength();i++){
                        list.item(i);
                    }

                     getTextContent()
                    - 得到标签里面的内容

            DocumentBuilderFactory:解析器工厂
                - 这个类也是一个抽象类,不能new
                用newInstance()获取 DocumentBuilderFactory 的实例。
        *** sax:
            SAXParser:解析器类
            SAXParserFactory:解析器工厂

19.使用jaxp实现查询操作
    * 查询xml中所有的那么元素的值
        * 步骤
        //查询所有name元素
        /*
        * 1.创建解析器工厂
            DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
        * 2.根据解析器广场创建解析器
            DocumentBuilder builder = builderFactory.newDocumentBuilder();
        * 3.解析xml返回document
            Document document = builder.parse("src/person.xml");
        *
        * 4.得到所有name元素
            NodeList list = document.getElementsByTagName("name");
        * 5.返回集合,遍历集合,得到每一个name
            - 遍历 getLength() item()
            - 得到元素里面值 使用 getTextContent()
        * */

    **** 查询xml中第一个name元素的值
        * 步骤
        /*
        * 1.创建解析器工厂
        * 2.创建解析器
        * 3.解析xml,返回document
        *
        * 4.得到所有name元素
        * 5.返回集合,里面方法item,下标获取具体的元素
        * 6.得到具体的值,使用getTextContent()方法
        * */

20.使用jaxp添加节点
    *** 在第一个p1下面(末尾)添加 <sex>nv</sex>

    ** 步骤
   
	/*
        * 1.创建解析器工厂
        * 2.创建解析器
        * 3.解析xml,返回document
        *
        * 4.获取第一个p1
        *  - 得到所有p1,使用item方法下标得到
        * 5.创建sex标签 createElement
        	Element sex1 = document1.createElement("sex");

        * 6.创建文本 createTextNode
        	Text text1 = document1.createTextNode("nv");

        * 7.把文本添加到sex下面 appendChild
        	sex1.appendChild(text1);
        * 8.把sex添加到第一个p1下面
        	item1.appendChild(sex1);
        *
        * 9.回写(用的时候直接粘贴)
        	TransformerFactory transformerFactory = TransformerFactory.newInstance();
	        Transformer transformer = transformerFactory.newTransformer();
	        //第一个参数:文档,第二个参数:xml文件路径
	        transformer.transform(new DOMSource(document1),new StreamResult("src/person.xml"));
    */
21.使用jaxp修改节点
    *** 修改标签sex里面的性别为nan
    ** 步骤
    /*
        * 1.创建解析器工厂
        * 2.创建解析器
        * 3.解析xml,返回document
        *
        * 4.获得sex item方法
        * 5.修改sex里面的值
            **** setTextContent方法
        *
        * 6.回写
        */

22.使用jaxp删除节点
    *** 删除<sex>nan</sex>节点
    ** 步骤
     /*
        * 1.创建解析器工厂
        * 2.创建解析器
        * 3.解析xml,返回document
        *
        * 4.获得sex item方法
        * 5.获取sex父节点 使用getParentNode()方法
        * 6.删除sex 使用父节点删除 removeChild()方法
        *
        * 7.回写
        */

23.使用jaxp遍历节点
    ** 把xml中所有元素打印出来
    * 步骤
    /*
        * 1.创建解析器工厂
        * 2.创建解析器
        * 3.解析xml,返回document
        *
        * ====使用递归实现====
        * 4.得到根节点
        * 5.得到根节点的子节点
        * 6.得到根节点的子节点的子节点
        *
    */

    public static void listElement() throws Exception{
        DocumentBuilderFactory builderFactory = DocumentBuilderFactory.newInstance();
        DocumentBuilder builder = builderFactory.newDocumentBuilder();
        Document document1 = builder.parse("src/person.xml");

        //编写一个方法实现遍历
        list(document1);
    }

    private static void list(Node node) {
        //判断是元素类型的时候打印
        if(node.getNodeType() == Node.ELEMENT_NODE){
            System.out.println(node.getNodeName());
        }
        //得到一层子节点
        NodeList list = node.getChildNodes();
        //遍历list
        for(int i=0; i<list.getLength(); i++){
            //得到每一个节点
            Node node1 = list.item(i);
            list(node1);
        }
     }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值