HTML 标签是否匹配检测代码

HTML 标签是否匹配检测代码,第1张

<HTML><HEAD><TITLE>New Document </TITLE><META NAME="Generator" CONTENT="EditPlus"><META NAME="Author" CONTENT=""><META NAME="Keywords" CONTENT=""><META NAME="Description" CONTENT=""></HEAD><BODY><SCRIPT LANGUAGE="JavaScript"><!-- //去掉字串中的空格 function NoSpace(txt){ return (txt.replace(/[\s]+/g,'')) } //判断<aaa>与</aaa>是配对的html标签 function IsGood(txt1,txt2){ var txt='<'+'/'+txt1.substr(1)return (txt==txt2)?1:0} function chk(){ //s为模拟的html代码 //var s="d<html>fg<table>sdfg<img><tr>asdfg<td>6456</td>dfg</tr>dsfg</table>d</html>fg"var s=NoSpace(oT.value).toLowerCase()var arrMinus=new Array('<img>','<input>','<meta>','<hr>')for (var i=0i<arrMinus.lengthi++){ s=s.replace(arrMinus[i],'')} var arrElement=s.match(/<[/|A-Za-z]+>/ig)//取出所有的<....>格式的字串 var stack=new Array()stack[0]='#'k=0//定义一个顺序栈,栈底放入#,k为栈顶指针 for (var j=0j<arrElement.lengthj++){ if (IsGood(stack[k],arrElement[j])) {k--stack.length--}//如果配对,栈顶元素出栈 else {stack[++k]=arrElement[j]}//如果不配对,新标签入栈 alert(stack[k])//演示栈顶的内容 } (stack[k]=="#")?(document.write("所有的标签匹配")):(document.write("有的标签不匹配"))} //--></SCRIPT><TEXTAREA NAME="oT" ROWS="10" COLS="90"><HTML><META><HEAD><TITLE>New Document </TITLE></HEAD><BODY><img><input></BODY></HTML></TEXTAREA><BR><BR>原理:建一个栈,每次碰到一个新标签,就与栈顶的标签配对,如果配对,栈顶的标签就出栈,如果不配对,这个新标签就进栈,最终,栈如果是空的,说明所有的标签都是配对的,如果栈不空,说明有不配对的地方<BR>框中是模拟的html代码,你可以修改后,点下面的按钮,看是不是匹配。<BR>d出的对话框是演示栈顶的内容<BR>特点:<BR>1、还不能判断<...>哪些是合法的html标签,可以在代码中直接输入合法标签,工作量太大。<BR>2、有的标签是不需配对的,如&ltimg&gt,代码智能判断为匹配的。<BR>3、目前还不支持标签后加属性 <BR><BR><INPUT TYPE="button" value="Start" onclick="chk()"></BODY></HTML>[Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]

HTML介绍:(1):<html>

<head>

<title>Title of page</title>

</head>

<body>

This is my first homepage.

<b>This text is bold</b>

</body>

</html>将此文件保存为“mypage.htm”。启动浏览器。在文件菜单中选择“打开”(或者“打开页面”),这时将出现一个对话框。选择“浏览”(或者“选择文件”),定位到你刚才创建的HTML文件——“mypage.htm”,选择它,单击“打开”。然后在对话框中,你将看到这个文件的地址,比如说:“C:\MyDocuments\mypage.htm”。单击“确定”,浏览器将显示此页面。

--------------------------------------------------------------------------------例子解释HTML文档中,第一个标签是<html>。这个标签告诉浏览器这是HTML文档的开始。HTML文档的最后一个标签是</html>,这个标签告诉浏览器这是HTML文档的终止。在<head>和</head>标签之间文本的是头信息。在浏览器窗口中,头信息是不被显示的。在<title>和</title>标签之间的文本是文档标题,它被显示在浏览器窗口的标题栏。在<body>和</body>标签之间的文本是正文,会被显示在浏览器中。在<b>和</b>标签之间的文本会以加粗字体显示。

---常见问题问:我编写完了HTML文件,但是不能在浏览器中看见结果,为什么?

答:请确认你保存了文件,并且使用了正确的文件名和扩展名,例如:“c:\mypage.htm”,并且确认你用浏览器打开时使用同样的文件名。问:我编辑了HTML文件,但是修改结果并没有在浏览器中显示,为什么?

答:浏览器缓存了你的页面,所以它不需要两次读取同样的页面。你修改了这个页面,浏览器并不知道。请使用“刷新/重载”按钮来强迫浏览器读取编辑过的页面。

-----------------------------------------------------------------------------

HTML基本标签:(2):HTML中最重要的标签是定义标题元素,段落和换行的标签。

标题元素标题元素由标签<h1>到<h6>定义。<h1>定义了最大的标题元素,<h6>定义了最小的。

<h1>This is a heading</h1>

<h2>This is a heading</h2>

<h3>This is a heading</h3>

<h4>This is a heading</h4>

<h5>This is a heading</h5>

<h6>This is a heading</h6>

HTML自动在一个标题元素前后各添加一个空行。

(3):段落段落是用<p>标签定义的。

<p>This is another paragraph</p>HTML自动在一个段落前后各添加一个空行。

--------------------------------------------------------------------------------换行当需要结束一行,并且不想开始新段落时,使用<br>标签。<br>标签不管放在什么位置,都能够强制换行。

<p>This <br>is a para<br>graph with line breaks</p><br>标签是一个空标签,它没有结束标记。

基本注意点——有用的技巧当你写下HTML文本的时候,你不能确知在另外一个浏览器中,这些文本将被如何显示。有人用着大的显示器,有的人用的小一些。每次用户调整窗口大小的时候,文本都将被重新格式化。不要想在编辑器中写一些空行和空格来协助排版。HTML将截掉你文本中的多余空格。不管多少个空格,处理起来只当一个。一点附加信息:在HTML里面,一个空行也只被当作一个空格来处理。使用空段落<p>来插入空白行是一个坏习惯,请使用<br>标签来替代。(但是不要用<br>标签来创建列表,我们后面会专门学习HTML列表的。)你也许注意到了段落可以不写结束标记</p>。别依赖它,HTML的下一个版本将不准你漏掉任何一个结束标签。HTML自动在某些元素前后增加额外的空行,就像在段落和标题元素的前后一样。我们使用了水平线(<hr>标签)来分隔我们教程的章节。

更多示例:a:多个段落:

<html>

<body>

<p>

This paragraph

contains a lot of lines

in the source code,

but the browser

ignores it.

</p>

<p>

This paragraph

contains a lot of spaces

in the source code,

but the browser

ignores it.

</p>

<p>

The number of lines in a paragraph depends on the size of your browser window. If you resize the browser window, the number of lines in this paragraph will change.

</p>

</body>

</html>

(这个例子说明了段落的一些默认行为。)b:换行:

<html>

<body>

<p>

To break<br>lines<br>in a<br>paragraph,<br>use the br tag.

</p>

</body>

</html>

(这个例子说明了在HTML文档中换行的使用。)

c:诗歌的问题: <html>

<body>

<p>

My Bonnie lies over the ocean.

My Bonnie lies over the sea.

My Bonnie lies over the ocean.

Oh, bring back my Bonnie to me.

</p>

<p>Note that your browser simply ignores your formatting!</p>

</body>

</html>

(这个例子说明了HTML显示格式的一些问题。)d:标题元素: <html>

<body>

<h1>This is heading 1</h1>

<h2>This is heading 2</h2>

<h3>This is heading 3</h3>

<h4>This is heading 4</h4>

<h5>This is heading 5</h5>

<h6>This is heading 6</h6>

<p>Use heading tags only for headings. Don't use them just to make something bold. Use other tags for that.</p>

</body>

</html>

(这个例子说明了在HTML中显示标题元素的标签。)e:居中的标题元素:<html>

<body>

<h1 align="center">This is heading 1</h1>

<p>The heading above is aligned to the center of this page. The heading above is aligned to the center of this page. The heading above is aligned to the center of this page.</p>

</body>

</html>

(这个例子显示了一个居中的标题元素。)f:水平线:<html>

<body>

<p>The hr tag defines a horizontal rule:</p>

<hr>

<p>This is a paragraph</p>

<hr>

<p>This is a paragraph</p>

<hr>

<p>This is a paragraph</p>

</body>

</html>

(这个例子说明了如何插入水平线。)

g:隐藏的注释:<html>

<body>

<!--This comment will not be displayed-->

<p>This is a regular paragraph</p>

</body>

</html>

(这个例子说明了在HTML文档中如何插入隐藏的注释。)h:背景色:<html>

<body bgcolor="yellow">

<h2>Look: Colored Background!</h2>

</body>

</html>

(这个例子说明了如何给页面设置背景色。)


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/7396845.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-05
下一篇 2023-04-05

发表评论

登录后才能评论

评论列表(0条)

保存