已转开发,博客新地址:http://welcomezhang.iteye.com/

浅谈web开发基础[精]

上一篇 / 下一篇  2011-08-14 16:57:35 / 精华(3) / 个人分类:web基础

9k1W h!oOKHbn0鉴于现在的网页设计,一般采用内容与表现相分离,即网页的组成包含:内容HTML+ 样式CSS + 脚本JS(客户端) + 服务器端开发语言PHP/ASP/JSP。本文将主要涉及到HTMLXML、CSS、JavaScript、AJAX、PHP/ASP/JSP的一些基础知识
51Testing软件测试网i*p6k*Ih"@(e+T
浏览器解析原理
0Ro)R+aw$c3tz'I&IRR0
服务器接收到HTML->解析HTML结构建DOM树->解析CSS构建渲染树->为渲染树生成布局->绘制渲染树;在构建DOM树的同时,如果有JS,同时调用JS引擎解析。
]G,L;Sx)I3|&`0HTML文件,在html文件的开头处一般会包含文档类型。常用过渡类型,支持html4.0的标签。其他文档类型有严格类型(Strict)和框架(Frameset)。51Testing软件测试网Rz? Y+W:Oo
一个HTML文件,包含head和body两部分。外部文件(css和js)的引用、定义,以及网页的title,都是在head里定义的。Body部分,则是网页展示的内容。51Testing软件测试网Ph9[S8zU7^ \#T
HTML文件的Head部分,包含文档编码、CSS和JS的定义或引用:
&v(g T,j y0文档编码,html引用文件(如CSS)的编码必须和本文档编码一致,否则可能出现乱码。51Testing软件测试网,D#] i!N7d;DD!L

Z9\R)}D051Testing软件测试网0Wi ha%i8t
一、HTML:HyperText Marking Langusge超文本标记语言51Testing软件测试网8n!fb*yv/W
HTML是被设计用来显示数据的,重点是:显示数据以及如何显示数据更好上面。还记得刚学习网页制作时,接触得最多的便是HTML;时至今日,对静态网页的制作其依然不过时。51Testing软件测试网&a n j? KD*e)ePrq
HTML对标签的大小写不敏感,但是XHTML规范中,标签要求必须小写。
Ll`&^9u | A0
HTML元素是通过使用 HTML 标签进行定义的,所有的标签定义在内,HTMl标签在页面中必须是结束的,如果标签没有闭合,造成的后果就是页面样式错乱。
IU`c5r_0HTML文档的body,是用户在浏览器中可见的部分。
$T8x*x2DF'zLs0一般的网站整体可以分为上中下结构,即:头部、中间主体、底部。那么我们在body中可以用三个div块来划分,分别给它们起名为:头部(header)、主体(maincontent)、询问(footer)。51Testing软件测试网YEK4]^/FA
对比表格布局,用div+css布局构建的网页以够简化代码,加快显示速度。
+Y@'gN&A4x&\9`0
,}#UJ(XYH$v0|q0
二、XML:eXtensible Marking Langusge,可扩展的标记语言
XML是被设计用来描述数据的,重点是:什么是数据,如何存放数据。
j%F ^*e` T:{4T:bd,ZG*yi0
XML只是用来组织、存储和发送信息的,但事实上XML确实什么都不做。
下面的例子是Ordm给Lin的便条,使用的是XML格式:<note>
    <to>Lin</to>   
    <from>Ordm</from>
    <from>Ordm</from>
X/`5q r2xuk#]0
    <heading>Reminder</heading>51Testing软件测试网t2h7fO#C8Wy
    <body>Don't forget me this weekend!</body>
o,Go o!]2U0
</note>
H%f`wi/s7HY$}0
这个便条有信息头,又信息主体,还包括发送人和接收人。尽管如此,这个XML文档仍然什么都不做,他只是用XML标记存储信息的文件。有人已经编写出来发送和接收并且显示这种格式信息的软件。
XML是自由的、可以扩展的。
5}X(Y h6h0^0
XML标记并不是预先规定好的,你必须创造你自己的标记。在HTML文档中必须使用规则中定义好的标记。比如:<P><br><a></a>等等。XML允许你定义自己的标记以及文档结构。比如在上面例子中的"<to>"、"<from>"标记都不是在XML规范中事先定义好的。这些标记都是XML文档的作者“创造”出来的。

XML是HTML的补充。
5P%Y3PpiR0
XML并不是HTML的替代品,理解这一点非常重要。在将来的网页开发中,XML将被用来描述、存储数据,而HTML则是用来格式化和显示数据的。对于XML最好的形容可能是:XML是一种跨平台的,与软、硬件无关的,处理信息的工具。

XML将成为最普遍的数据操纵和数据传输的工具。51Testing软件测试网Y)h"Sj:Y,j
XML在未来Web开发中的应用无处不在。XML发展的非常迅速,这实在令人感到惊奇,有很多的软件开发商都采用了XML标准。我们相信,在未来的Web开发中,XML将和HTML一样受到重视,他们都是Web技术的基础。


三、CSS:Cascading Style. Sheet,层叠样式表
_hkRE0
CSS基础这里就不多说了,整一本css手册便OK;在此主要说明HTML使用CSS的4种方式。51Testing软件测试网zm]9vCG$K8U
1.链入外部样式表文件Linking to a Style. Sheet)
8d,k d-iN@{T2Sc0
<link href="css/test.css" type="text/css"/>
2.定义内部样式块对象Embedding a Style. Block)51Testing软件测试网hSw{w3i\
<title>引用内部样式测试</title>51Testing软件测试网?@2q-XTRX&e}OW
</head>
3` n!P1G0i%f0 <body>
$G N.z?.Le0<font>testing font</font>
3.内联定义(Inline styles)
51Testing软件测试网6gO)B!Bg
3.内联定义(Inline styles)51Testing软件测试网GH7O S8e[-o'h
<p style="background-color: #FFCC66;">测试内联定义</p>
4.导入样式(Import Styles):与链入外部样式的功能基本相同,只是语法和实现方式上有差别.51Testing软件测试网kb.P(RY
<head>  51Testing软件测试网)k0t;] ^#Y+l#N0J:d
   <title>test importing styles</title>51Testing软件测试网f F Hw'h])_z'h
  <style>51Testing软件测试网;K*K%v'^g6fH
   @import url(css/test.css);
*N1G"^ i2C[ qe0  @import url("css/test.css") ;//单引号也可以
P"kn;z0U0  @import css/test.css;51Testing软件测试网 } i7bg Tm
  @import "css/test.css"; //单引号也可以 51Testing软件测试网/qZX7r Z2rr2ag
    </style>
([*w%Abs0</head>51Testing软件测试网+Y7CJ@;L y\
几种方式的优先级:内联样式优先级最高,其次是外部链接样式,再次是内联式,最后是导入样式

8zZ Z |0pp5r#T8c0
四、JavaScript,原名LiveScript,简称JS.51Testing软件测试网UK_:V'o~D
JavaScript是一种基于对象和事件驱动并具有相对安全性的客户端脚本语言。同时也是一种广泛用于客户端Web开发的脚本语言,常用来给HTML网页添加动态功能,比如响应用户的各种操作。
Y;v,nCd od;e(LZ01.类似于引用css的4种方式,使用js也有3种方式。51Testing软件测试网#j'l4]G g {U
a.链入外部JS文件51Testing软件测试网[)[ L\N3[4nw
<head> 51Testing软件测试网 T&@ G {f(x,`,t,l g!m
<script. language="JavaScript" src="test.js"></script> 
"^7OI#{ E$ca"X0</head> 
b.引用内部JS文件51Testing软件测试网+r9NdG)?(} v1S z6r
编写第一个JavaScript程序
;JS6~"ea1Z'd/U0  <html>
!OU6qI1K0  <head>
R%F E\$cJ5U0  <script. type="text/javascript">
U[#~.k6q)c~(p!y0  <!--
Ru}aYO,}0  function checkForm(form)
6}1q w/V7|Ab0   {51Testing软件测试网0t5GX?z4v@
if(form.username.value==''){51Testing软件测试网~D7i_/^j6I
   alert('用户名不能为空!');51Testing软件测试网kW0k?`:kW"lRs
           form.username.focus();51Testing软件测试网.Z?o:x(EU tp
           return false;
S |'G JAK S0          }51Testing软件测试网CJoo.x*SN
        ......51Testing软件测试网*T\E0MD.WG]
    }51Testing软件测试网9qTu#cq })m$h
  -->
$Ch#cA$V0  </script>51Testing软件测试网)Cj O Xu^L L%D
  </head>
YL@ E~(f%]0  <body>
C#k(PoH;L0      <form. method="POST" nsubmit="returm checkForm(this);">51Testing软件测试网.B K$O JE;{2E
      </form>
O;V~IZ j^0  </body>51Testing软件测试网3O5};f]D*aK6n
  </html>
c.内联JS51Testing软件测试网$S!D Xji1W
<input type="button" name="register" nclick="javascript.:location.href='register.php'" value= "register ">
2.Java、Javascrīpt和Jscrīpt的区别
v#gk9^*Z7`Y5JC!C-L0首先,这三者没有必然的联系,它们是完全不同的事物,它们是分别由不同公司开发的,在函数方面有相同的地方,也有很多不同之处。Java是由Sun公司创立、开发;Javascrīpt则是Sun和Netscape公司共同开发的产品;Jscrīpt是微软对ECMA262语言规范的一种实现。这三者的共同点是,语法与C语言相似。JS是Javascrīpt的简称。51Testing软件测试网!L4] T3dF"Yr
其次,Jscrīpt应用于ASP,运行于服务器端。而Java、Javascrīpt都是运行于客户端。Sun公司后来又推出了JSP,以Java语言为基础,运行于服务器端。运行于服务器端的网页是动态网页,所以以Jscrīpt为基础的ASP、以Java为基础的JSP是动态网页,而Java、Javascrīpt则是静态网页。
3.常用的javascript库:jquery库、prototype


五、AJAX(Asynchronous JavaScript. and XML),异步JavaScript和XML。51Testing软件测试网f0i;|n b_X\"h
AJAX是一种创建交互式网页应用的网页开发技术。通过 AJAX,您的 JavaScript. 可使用 JavaScript. 的 XMLHttpRequest 对象来直接与服务器进行通信。通过这个对象,您的JavaScript. 可在不重载页面的情况与 Web 服务器交换数据。AJAX 在浏览器与 Web 服务器之间使用异步数据传输(HTTP 请求),这样就可使网页从服务器请求少量的信息,而不是整个页面。AJAX 可使因特网应用程序更小、更快,更友好。
根据Ajax提出者Jesse James Garrett建议,AJAX使用:
B%\PerJ3Rp0  1、使用XHTML+CSS来表示信息;51Testing软件测试网7mE&j Og)Y?.d,s
  2、使用JavaScript操作DOM(Document Object Model)进行动态显示及交互;
*B+o*`[:E0  3、使用XML和XSLT进行数据交换及相关操作;51Testing软件测试网2Q!ugv1F@
  4、使用XMLHttpRequest对象与Web服务器进行异步数据交换;
5X`'Y)K't"Z0  5、使用JavaScript将所有的东西绑定在一起。
%wt+d&GjN nV0 
W w1r+d _5_051Testing软件测试网3e E2sJGH
六、PHP(Personal Hypertext Preprocessor),超文本预处理语言。
   ASP(Active Server Pages),动态服务器页面。
   JSP(Java Server Pages),Java服务器页面。

F1K3Xpnn)g0   JSP(Java Server Pages),Java服务器页面。
3L+]9P(g3HI0PHP是一种跨平台的服务器端的嵌入式脚本语言。它大量地借用C, Java和Perl语言的语法, 并耦合PHP自己的特性,使WEB开发者能够快速地写出动态产生页面。开源、免费、它支持目前绝大多数数据库51Testing软件测试网+D!t_I&k'j-{
ASP采用脚本语言VBScript作为自己的开发语言。51Testing软件测试网6U)_;XQ.vp@Dt2u
JSP是Sun公司推出的新一代网站开发语言,Sun公司借助自己在Java上的不凡造诣,将Java从Java应用程序和Java Applet之外,又有新的硕果,就是JSP。JSP可以在Serverlet和JavaBean的支持下,完成功能强大的站点程序。51Testing软件测试网Q5`_2_z?|2u

PHP技术特点
1.数据库连接 
  PHP可以编译成具有与许多数据库相连接的函数。PHP与MySQL是现在绝佳的组合。你还可以自己编写外围的函数取间接存取数据库。通过这样的途径当你更换使用的数据库时,可以轻松地更改编码以适应这样的变。PHPLIB就是最常用的可以提供一般事务需要的一系列基库。但PHP提供的数据库接口支持彼此不统一,比如对Oracle,MySQL,Sybase的接口,彼此都不一样。这也是PHP的一个弱点。 
2.面向对象编程 
  PHP提供了类和对象。基于web的编程工作非常需要面向对象编程能力。PHP支持构造器、提取类等。 

ASP技术特点
1. 使用 VBScript. 、 JScript. 等简单易懂的脚本语言,结合 HTML 代码,即可快速地完成网站的应用程序。 
2. 无须 compile 编译,容易编写,可在服务器端直接执行。 
3. 使用普通的文本编辑器,如 Windows 的记事本,即可进行编辑设计。
4. 与浏览器无关 (Browser Independence), 用户端只要使用可执行 HTML 码的浏览器,即可浏览 Active Server Pages 所设计的网页内容。 Active Server Pages 所使用的脚本语言 (VBScript. 、 Jscript) 均在 WEB 服务器端执行,用户端的浏览器不需要能够执行这些脚本语言。 
5.Active Server Pages 能与任何 ActiveX scripting 语言相容。除了可使用 VBScript. 或 JScript. 语言来设计外,还通过 plug-in 的方式,使用由第三方所提供的其他脚本语言,譬如 REXX 、 Perl 、 Tcl 等。脚本引擎是处理脚本程序的 COM(Component Object Model) 物件。 
6. 可使用服务器端的脚本来产生客户端的脚本。 
7.ActiveX Server Components(ActiveX 服务器元件 ) 具有无限可扩充性。可以使用 Visual Basic、 Java、Visual C++、COBOL等编程语言来编写你所需要的ActiveX Server Component 。
n(_jD7Y@#w%~EpY0
"@1gC []0
JSP技术特点
  1. 将内容的产生和显示进行分离
  使用JSP技术,Web页面开发人员可以使用HTML或者XML标识来设计和格式化最终页面。使用JSP标识或者小脚本来产生页面上的动态内容。产生内容的逻辑被封装在标识和JavaBeans群组件中,并且捆绑在小脚本中,所有的脚本在服务器端执行。
  2. 强调可重用的群组件
  绝大多数JSP页面依赖于可重用且跨平台的组件(如:JavaBeans或者Enterprise JavaBeans)来执行应用程序所要求的更为复杂的处理。开发人员能够共享和交换执行普通操作的组件,或者使得这些组件为更多的使用者或者用户团体所使用。基于组件的方法加速了总体开发过程,并且使得各种群组织在他们现有的技能和优化结果的开发努力中得到平衡。
  3. 采用标识简化页面开发
  Web页面开发人员不会都是熟悉脚本语言的编程人员。JavaServer Page技术封装了许多功能,这些功能是在易用的、与JSP相关的XML标识中进行动态内容生成所需要的。标准的JSP标识能够访问和实例化JavaBeans组件,设置或者检索组件属性,下载Applet,以及执行用其他方法更难于编码和耗时的功能。 
x*\kK:OF0
+}[h*U\)n9@d?0参考众多文章资料,在此一一谢过!

b,u i'g}0

i+J| \5M8Fs0

TAG: ajax AJAX ASP CSS css HTML html js JS JSP PHP php web Web 基础

 

评分:0

我来说两句

Open Toolbar