|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
总的来说,在这一个月左右的时间中,学到的不少,但是也遇到不少的问题,比如批量图片的上传,一直到现在也不懂,如何实现动态的增加上传图片的数量。 1、弁言
HTML复杂易学又通用,普通的PHP法式就是嵌入在HTML言语当中完成的。然而跟着Web愈来愈普遍的使用,HTML的弱点也愈来愈分明了。XML的呈现,填补了这些缺乏,它供应了一个可以处置互联网上全体数据的通用办法。
2、HTML的局限性剖析
1、 HTML的可扩大性差。固然作为普通的使用,HTML应经够用了,然而在处置数学和化学等符号时,HTML有分明的弱点,并且它没法停止扩大,如许使它的开展收到了极大的限制。
2、 链路丧失后不克不及主动改正。因为Web页面的URL地址常常改动,而在改动URL地址时必需手工修正这些信息,不然就会碰到“404URL地址未找到”的信息,这大大减轻了Web页面的保护任务量。
3、 数据搜刮的工夫长。因为HTML次要用来对网页的显示停止掌握,招致了统一个数据在分歧的网页中有分歧的存储格局,如许在停止数据搜刮时就没法疾速找到所需的材料。
4、 HTML对双字节或多国文字的撑持不敷。例如中文信息页面在分歧的平台下会呈现没法显示等成绩。
恰是因为这些弱点,人们研讨了可以取代HTML的Web页面制造言语。个中已投入利用的有:可扩大标志言语XML、层叠款式表(CSS)和静态HTML(DHTML)等。
3、XML的构成
这里扼要罗列几种次要的XML手艺:
1、 DTD(文档类型声明)
DTD的次要功效是界说XML的内容形式;限制XML标志的数据局限;界说属性的数据类型。但因为它不是用XML编写的,因而扩大性对照差;并且只供应了无限的几种数据类型,因而它的感化是无限的。
2、 XML Schema
XML Schema的感化和DTD相似。但分歧的是,Schema文件所描写的是援用它的XML文件中的元素和属性的详细类型。别的,因为它是由XML编写的,Schema和DTD比拟较还有以下长处:
・XML Schema内容模子是开放的,可以随便扩大,而DTD没法解析扩大的内容。
・DTD只能把内容类型界说为一个字符串,而XML Schema答应把内容类型界说为整型、浮点型、布尔型或很多其它的复杂数据类型。
・XML Schema使用Namespaces将文档中特别的节点与Schema相接洽,一个XML文件可以有多个对应的Schema,而一个XML文件只能有一个DTD。
3、 XLink
作为一种Web言语,XML的链接才能长短常主要的。XML的链接和定址机制包含XLink、XPath和XPointer。XLink供应功效壮大的链接办法,可以在文档之间创立单向或多向的庞杂联合关系,还有正文链接、概要链接、扩大链接集等多种链接功效。XPath在XSLT和XPointer中利用,撑持在XML文档中相对节点和节点集的定位。XPointer在XPath的基本上供应对XML文档的内容的外部布局(如一个字符串或选择的一个段落)的定位。XML的链接才能比HTML有了很大的加强。
4、 CSS与XSL
XML的一大特色就是内容与格局分别,也就是说,XML文档中其实不包括若何显示/暗示文档的信息。CSS与XSL(XML Style Language)处理了XML文档的显示成绩。
CSS(层叠款式表)也能够用在HTML和XML中。XSL完整利用XML的语法,功效比CSS要壮大很多。
5、 DOM
文档对象模子(DOM)是一个与平台、言语有关的法式接口,它供应了静态会见和更新文档的内容、布局与作风的手腕。可以对文看成进一步的处置,并将处置的了局更新到暗示页面。
DOM的方针就是为XML和HTML界说一个尺度的编程接口,它包含中心、HTML和XML三局部。DOM的中心局部创立了一套底层的对象集,它们可以暗示任何布局化的文档。HTML和XML供应了高层的接口,可以作为更便利的文档视图。DOM标准由对象和办法构成。法式员利用它们可以更轻易地对特定类型的文档停止会见和操作。
6、 Namespaces
Namespaces是用URL加以区分的、在XML文件的元素和属性中呈现的一切称号的纠合。在XML中,用户可以本人界说标志和元素。因而,假如把多个XML文件兼并为一个,就极可能呈现抵触。Namespaces则处理了这个成绩。
4、PHP对XML的撑持
PHP对XML供应了的壮大的撑持。它利用了一个XML的“解析器”,而且为了撑持这个解析器,它供应了20(PHP4)个XML的解析函数。上面是几个最经常使用的PHP解析函数。
1. xml_parse
boolean xml_parse(int parser, string data, int [isFinal]);
本函数用来解析 XML 格局的文件材料。参数 parser 为解析代码。参数 data 为解析的材料区块 (chunk)。参数 isFinal 可省略,若设为 true 则体系会主动送出最初的材料局部 (piece) 给 data 参数。若无毛病则前往 true 值。
2. xml_parser_create
int xml_parser_create(string [encoding]);
本函数用来初始化一个新的 XML 解析器。参数 encoding 可省略,为 XML 利用的字符集,默许值为 ISO-8859-1,其它另有 US-ASCII、UTF-8 二种。胜利则前往 parser 代码供其它函数利用,掉败则前往 false 值。
3. xml_set_element_handler
boolean xml_set_element_handler(int parser, string startElementHandler, string endElementHandler);
本函数设置装备摆设元素的标头供 xml_parse() 函数利用。参数 parser 为解析代码。参数 startElementHandler 及 endElementHandler 分离为元素入手下手与停止的标头,个中的 startElementHandler 必需包含解析代码、称号、与属性,而 endElementHandler 参数包含懂得析代码及称号二个参数。若无毛病则前往 true 值。
4. xml_set_character_data_handler
boolean xml_set_character_data_handler(int parser, string handler);
本函数设置装备摆设字符材料的标头。参数 parser 为解析代码。参数 handler 包含解析代码及材料字符串等二个元素。若无毛病则前往 true 值。
5. xml_get_error_code
int xml_get_error_code(int parser);
本函数可获得 XML 在处置时的毛病代码。参数 parser 为解析代码。若 parser 有错则前往 false 值,不然就前往毛病代码 (如 XML_ERROR_BINARY_ENTITY_REF .... 等等)。
6. xml_error_string
string xml_error_string(int code);
本函数可获得 XML 在处置时的毛病代码。参数 code 为解析毛病代码。若无毛病前往值为代码的文字描写字符串。
7. xml_get_current_line_number
int xml_get_current_line_number(int parser);
本函数用来获得今朝 XML 解析所正在处置的行号。参数 parser 为解析代码。若 parser 有错则前往 false 值,若无毛病则前往行号数字。
8. xml_parser_free
boolean xml_parser_free(int parser);
本函数用来释放今朝 XML 解析所利用的内存。参数 parser 为解析代码。若没有毛病则前往 true 值,不然前往 false 值。
学校并没有那么多的时间可以让我们在实际开发上面。 |
|