HTML5入门

  • HTML5的初步认识

一、HTML5的初步认识

关于html5的一些历史可以通过这篇博客了解:https://www.cnblogs.com/fly_dragon/archive/2012/05/22/2513716.html

1.为HTML5建立的一些规则:

  • 新特性应该基于HTML、CSS、DOM以及JavaScript
  • 减少对外部插件的需求(比如flash)
  • 更优秀的错误处理
  • 更多取代脚本的标记
  • HTML5应该独立于设备
  • 开发进程应对公众透明

2.HTML5新特性

  • 用于绘画的canvas元素svg
  • 用于媒介回放的video和audio元素
  • 对本地离线存储的更好的支持:localStorage、sessionStorage
  • 新的特殊内容元素,比如article、footer、header、nav、section
  • 新的表单控件,比如calendar、date、time、email、url、search()
  • input type = text button file radio checkbox(html)

新的的特殊内容元素:article、footer、header、nav、section本质上与div没什么区别,只是为了更加方便的阅读代码而产生的语义化标签:(article与section的区别一个相当于div一个相当于p)

<header>头部、首部标签</header>
<nav>导航</nav>
<article>文章(div)</article>
<section>章节(p)</section>
<footer>底部</footer>

在HTML5中还允许自定义标签,自定义的标签属于行级元素,类似span。

<student></student><span></span>

2.HTML5新属性

  • Contenteditable用户能否修改页面上的内容
  • Draggable支持拖放
  • Hidden隐藏
  • Contextmenu为元素设定快捷菜单(目前无浏览器支持contextmenu属性)
  • data-val自定义属性

2.1contenteditable的属性值为boolean类型,当值为true表示当前元素内容可以编辑,默认为false不能编辑:

<div contenteditable="true">这个div可以编辑:</div>

实现效果:

以下是基于contenteditable属性实现的富文本编辑器的代码:

  1 <!DOCTYPE html>
  2 <html>
  3 <head>
  4     <meta charset="utf-8">
  5     <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6     <title>富文本编辑器【Rich Text Editor】</title>
  7     <link rel="stylesheet" href="">
  8     <script type="text/javascript">
  9         var oDoc,sDefTxt;
 10         function initDoc(){
 11             oDoc = document.getElementById("textBox");
 12             sDefTxt = oDoc.innerHTML;
 13             if(document.compForm.switchMode.checked){
 14                 setDocMode(true);
 15             }
 16         }
 17         function formatDoc(sCmd, sValue){
 18             if(validateMode()){
 19                 document.execCommand(sCmd, false, sValue);
 20                 oDoc.focus();
 21             }
 22         }
 23         function validateMode(){
 24             if(!document.compForm.switchMode.checked){
 25                 return true;
 26             }
 27             alert("Uncheck\"Show Html\".");
 28             oDoc.focus();
 29             return false;
 30         }
 31         function setDocMode(bToSource){
 32             var oContent;
 33             if(bToSource){
 34                 oContent = document.createTextNode(oDoc.innerHTML);
 35                 oDoc.innerHTML = "";
 36                 var oPre = document.createElement("pre");
 37                 oDoc.contentEditable = false;
 38                 oPre.id = "sourceText";
 39                 oPre.contentEditable = true;
 40                 oPre.appendChild(oContent);
 41                 oDoc.appendChild(oPre);
 42                 document.execCommand("defaultParagraphSeparator", false, "div");
 43             }else{
 44                 if(document.all){
 45                     oDoc.innerHTML = oDoc.innerText;
 46                 }else{
 47                     oContent = document.createRange();
 48                     oContent.selectNodeContents(oDoc.firstChild);
 49                     oDoc.innerHTML = oContent.toString();
 50                 }
 51                 oDoc.contentEditable = true;
 52             }
 53             oDoc.focus();
 54         }
 55         function printDoc(){
 56             if(!validateMode()){
 57                 return ;
 58             }
 59             var oPrntWin = windowl.open("","_blank","width=450,height=470,left=400,top=100,menubar=yes,toolbar=no,location=no,scrollbars=yes");
 60             oPrntWin.document.open();
 61             oPrntWin.document.write("<!doctype html><html><title>Print<\/title><\/head><body onload=\"print();\">" + oDoc.innerHTML + "<\/body><\/html>");
 62             oPrntWin.document.close();
 63         }
 64     </script>
 65     <style type="text/css">
 66         .intLink {
 67             cursor: pointer;
 68         }
 69         img.intLink {
 70             border: 0;
 71         }
 72         #toolBar1 select {
 73             font-size:10px;
 74         }
 75         #textBox {
 76           width: 540px;
 77           height: 200px;
 78           border: 1px #000000 solid;
 79           padding: 12px;
 80           overflow: scroll;
 81         }
 82         #textBox #sourceText {
 83           padding: 0;
 84           margin: 0;
 85           min-width: 498px;
 86           min-height: 200px;
 87         }
 88         #editMode label {
 89             cursor: pointer;
 90         }
 91     </style>
 92 </head>
 93 <body >
 94     <form name="compForm" method="post" action="sample.php" onsubmit="if(validateMode()){this.myDoc.value=oDoc.innerHTML;return true;}return false;">
 95     <input type="hidden" name="myDoc">
 96     <div id="toolBar1">
 97         <select onchange="formatDoc(‘formatblock‘,this[this.selectedIndex].value);this.selectedIndex=0;">
 98             <option selected>- formatting -</option>
 99             <option value="h1">Title 1 &lt;h1&gt;</option>
100             <option value="h2">Title 2 &lt;h2&gt;</option>
101             <option value="h3">Title 3 &lt;h3&gt;</option>
102             <option value="h4">Title 4 &lt;h4&gt;</option>
103             <option value="h5">Title 5 &lt;h5&gt;</option>
104             <option value="h6">Subtitle &lt;h6&gt;</option>
105             <option value="p">Paragraph &lt;p&gt;</option>
106             <option value="pre">Preformatted &lt;pre&gt;</option>
107         </select>
108         <select onchange="formatDoc(‘fontname‘,this[this.selectedIndex].value);this.selectedIndex=0;">
109             <option class="heading" selected>- font -</option>
110             <option>Arial</option>
111             <option>Arial Black</option>
112             <option>Courier New</option>
113             <option>Times New Roman</option>
114         </select>
115         <select onchange="formatDoc(‘fontsize‘,this[this.selectedIndex].value);this.selectedIndex=0;">
116             <option class="heading" selected>- size -</option>
117             <option value="1">Very small</option>
118             <option value="2">A bit small</option>
119             <option value="3">Normal</option>
120             <option value="4">Medium-large</option>
121             <option value="5">Big</option>
122             <option value="6">Very big</option>
123             <option value="7">Maximum</option>
124         </select>
125         <select onchange="formatDoc(‘forecolor‘,this[this.selectedIndex].value);this.selectedIndex=0;">
126             <option class="heading" selected>- color -</option>
127             <option value="red">Red</option>
128             <option value="blue">Blue</option>
129             <option value="green">Green</option>
130             <option value="black">Black</option>
131         </select>
132         <select onchange="formatDoc(‘backcolor‘,this[this.selectedIndex].value);this.selectedIndex=0;">
133             <option class="heading" selected>- background -</option>
134             <option value="red">Red</option>
135             <option value="green">Green</option>
136             <option value="black">Black</option>
137         </select>
138         <div id="toolBar2">
139             <img class="intLink" title="Clean" onclick="if(validateMode()&&confirm(‘Are you sure?‘)){oDoc.innerHTML=sDefTxt};" src="" />
140             <img class="intLink" title="Print" onclick="printDoc();" src="">
141             <img class="intLink" title="Undo" onclick="formatDoc(‘undo‘);" src="" />
142             <img class="intLink" title="Redo" onclick="formatDoc(‘redo‘);" src="" />
143             <img class="intLink" title="Remove formatting" onclick="formatDoc(‘removeFormat‘)" src="">
144             <img class="intLink" title="Bold" onclick="formatDoc(‘bold‘);" src="" />
145             <img class="intLink" title="Italic" onclick="formatDoc(‘italic‘);" src="" />
146             <img class="intLink" title="Underline" onclick="formatDoc(‘underline‘);" src="" />
147             <img class="intLink" title="Left align" onclick="formatDoc(‘justifyleft‘);" src="" />
148             <img class="intLink" title="Center align" onclick="formatDoc(‘justifycenter‘);" src="" />
149             <img class="intLink" title="Right align" onclick="formatDoc(‘justifyright‘);" src="" />
150             <img class="intLink" title="Numbered list" onclick="formatDoc(‘insertorderedlist‘);" src="" />
151             <img class="intLink" title="Dotted list" onclick="formatDoc(‘insertunorderedlist‘);" src="" />
152             <img class="intLink" title="Quote" onclick="formatDoc(‘formatblock‘,‘blockquote‘);" src="" />
153             <img class="intLink" title="Delete indentation" onclick="formatDoc(‘outdent‘);" src="" />
154             <img class="intLink" title="Add indentation" onclick="formatDoc(‘indent‘);" src="" />
155             <img class="intLink" title="Hyperlink" onclick="var sLnk=prompt(‘Write the URL here‘,‘http:\/\/‘);if(sLnk&&sLnk!=‘‘&&sLnk!=‘http://‘){formatDoc(‘createlink‘,sLnk)}" src="" />
156             <img class="intLink" title="Cut" onclick="formatDoc(‘cut‘);" src="" />
157             <img class="intLink" title="Copy" onclick="formatDoc(‘copy‘);" src="" />
158             <img class="intLink" title="Paste" onclick="formatDoc(‘paste‘);" src="" />
159         </div>
160         <div id="textBox" contenteditable="true"><p>Lorem ipsum</p></div>
161         <p id="editMode"><input type="checkbox" name="switchMode" id="switchBox" onchange="setDocMode(this.checked);" /> <label for="switchBox">Show HTML</label></p>
162         <p><input type="submit" value="Send" /></p>
163     </form>
164 </body>
165 </html>

富文本编辑器代码

2.2关于Draggable属性实现元素拖拽:

  2.2.1属性:draggable: auto | true | false

  2.2.2拖拽事件:

  • dragstart 在元素开始被拖动时触发
  • dragend 在拖动操作完成时触发
  • drag 在元素被拖动时触发

  2.2.3释放区域事件:

  • dragenter 被拖动元素进入到释放区所占据得屏幕空间时触发
  • dragover 当被拖动元素在释放区内移动时触发
  • dragleave 当被拖动元素没有放下就离开释放区时触发
  • drop 当被拖动元素在释放区里放下时触发

 1 <!DOCTYPE HTML>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <title>菜鸟教程(runoob.com)</title>
 6 <style>
 7 .droptarget {
 8     float: left;
 9     width: 100px;
10     height: 35px;
11     margin: 15px;
12     padding: 10px;
13     border: 1px solid #aaaaaa;
14 }
15 </style>
16 </head>
17 <body>
18
19 <p>在两个矩形框中来回拖动 p 元素:</p>
20 <div class="droptarget">
21     <p draggable="true" id="dragtarget">拖动我!</p>
22 </div>
23 <div class="droptarget"></div>
24 <p style="clear:both;"><strong>注意:</strong>Internet Explorer 8 及更早 IE 版本或 Safari 5.1 及更早版本的浏览器不支持 drag 事件。</p>
25 <p id="demo"></p>
26 <script>
27 /* 拖动时触发*/
28 document.addEventListener("dragstart", function(event) {
29     //dataTransfer.setData()方法设置数据类型和拖动的数据
30     console.log(event.dataTransfer);
31     event.dataTransfer.setData("Text", event.target.id);
32     // 拖动 p 元素时输出一些文本
33     document.getElementById("demo").innerHTML = "开始拖动 p 元素.";
34     //修改拖动元素的透明度
35     event.target.style.opacity = "0.4";
36 });
37 //在拖动p元素的同时,改变输出文本的颜色
38 document.addEventListener("drag", function(event) {
39     document.getElementById("demo").style.color = "red";
40 });
41 // 当拖完p元素输出一些文本元素和重置透明度
42 document.addEventListener("dragend", function(event) {
43     document.getElementById("demo").innerHTML = "完成 p 元素的拖动";
44     event.target.style.opacity = "1";
45 });
46 /* 拖动完成后触发 */
47 // 当p元素完成拖动进入droptarget,改变div的边框样式
48 document.addEventListener("dragenter", function(event) {
49     if ( event.target.className == "droptarget" ) {
50         event.target.style.border = "3px dotted red";
51     }
52 });
53 // 默认情况下,数据/元素不能在其他元素中被拖放。对于drop我们必须防止元素的默认处理
54 document.addEventListener("dragover", function(event) {
55     event.preventDefault();
56 });
57 // 当可拖放的p元素离开droptarget,重置div的边框样式
58 document.addEventListener("dragleave", function(event) {
59     if ( event.target.className == "droptarget" ) {
60         event.target.style.border = "";
61     }
62 });
63 /*对于drop,防止浏览器的默认处理数据(在drop中链接是默认打开)
64 复位输出文本的颜色和DIV的边框颜色
65 利用dataTransfer.getData()方法获得拖放数据
66 拖拖的数据元素id(“drag1”)
67 拖拽元素附加到drop元素*/
68 document.addEventListener("drop", function(event) {
69     event.preventDefault();
70     if ( event.target.className == "droptarget" ) {
71         document.getElementById("demo").style.color = "";
72         event.target.style.border = "";
73         var data = event.dataTransfer.getData("Text");
74         event.target.appendChild(document.getElementById(data));
75     }
76 });
77 </script>
78
79 </body>
80 </html>

来自一个手册得完整示例

  》》示例链接:https://www.runoob.com/try/try.php?filename=tryjsref_ondrag_all

2.3Hidden实现的元素隐藏本质上就是基于display的样式属性none实现的,这个隐藏的元素依然存在于文档结构中,只是display属性被设置为none了而已。

2.4自定义属性:

<div data-val="demo"></div>
document.getElementsByTagName(‘div‘)[0].getAttribute(‘data-val‘);//demo

原文地址:https://www.cnblogs.com/ZheOneAndOnly/p/11264585.html

时间: 2024-11-09 10:20:48

HTML5入门的相关文章

【活动】不用买书,不用花钱,可以免费看HTML5入门连载了

清华大学出版社推出的<HTML 5网页开发实例详解>适合HTML 5开发初学者和前端开发工程师.本书一经上市,就获得了读者的一致好评,为感谢读者,推出本书的连载活动.   本书术新颖.与时俱进,结合时下最热门的技术,如Node.js.响应式设计.移动开发.MVC,让读者在学习HTML 5的同时,了解熟识更多相关的世界先进技术.对于无法全面讲解的一些框架,还给出了GitHub的详细地址供读者参考. 本书贴近读者.贴近实际,大量成熟第三方组件和框架的使用和说明,帮助读者快速找到问题的最优解决方案,

10分钟HTML5入门基础知识(一)

毫无疑问,对于开发人员而言,HTML5已是一个热点话题.如果你需要快速了解HTML5的功能的基本原理,阅读本文是你最好的选择. 本文来自The Code Project的付费搜索位置,由Solution Center提供.这里的文章致力于向大家提供我们认为对开发人员来说有用和有价值的产品和服务的相关信息由IE9和HTML5 / CSS3 Zone带来 . 本文会涵盖新的语义标签.为绘图和动画而设计的画布(canvas).音频和视频支持,以及在旧版浏览器上如何使用HTML5.看完这些内容所用的时间

HTML5入门1

<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <meta name="keywords" content="这是我的网站" /> <title>我的HTML5</title> </head> <body> <header>logo图片</header>

HTML5 -入门 (----------------------css样式(1)---------------------—)

---恢复内容开始--- 一css基础入门与css选择器 CSS英文全拼:cascading style sheet 层叠样式表. 在html中使用:要在head中写style标签,所有样式放在style标签中. <style>       color: red;  设置文本颜色 font-size: 30px; 设置文本大小 设置背景颜色 background-color: blue; font-weight: bold; 设置文本粗体 font-style: italic; 设置文本斜体

HTML5 入门基础

HTML5概述HTML5於2004年被WHATWG(网页超文本技术工作小组)提出,於2007年被W3C接纳.在2008年1月22日,第一份正式草案已公布.WHATWG表示该规范是目前正在进行的工作,仍须多年的努力. HTML 版本从 Web 诞生早期至今,已经发展出多个 HTML 版本:1.HTML           19912.HTML+         19933.HTML2.0      1995.1         RFC4.HTML3.2      1996.1         W3

HTML5 入门笔记

1.各种表签的含义与写法: 注释:<!-- .. -->   声明版本为5:<!DOCTYPE html> 字体设置:<meta charset="utf-8" /> 属性:  所有元素的全局属性; 只适用于某个元素的专用属性;  事件处理器的内容属性; <div> 用于划分区域,但不能表示区域的含义;倾向于格式化划分文档; <section> 表示文档任意的逻辑分区;属于全局属性 <article> 内容相对于其

HTML5入门指南

如今WEB技术风云变化,HTML5异军突起,我将带领各位领略HTML5的风采魅力. HTML5到底是什么? 一般广义而言的HTML5则包含了HTML.CSS和JavaScript三个部分,而不只是第一印象仅仅HTML部分而已,在CSS 3和JavaScript层面也有许多的创新,让整个网页从布局到处理都更加给力,新囊括的技术让之前实现相当困难且安全性危机重重的功能变为了现实, HTML5好处-为什么要用HTML5 THML5在布局上更得体,记得以前的主流table过渡到主流div:今的布局对搜索

由浅入深学Spring MVC HTML5入门教程

开发快报: websocket 强制下线功能,玩转websocket技术 ------------------------------------------------------------------------------------------------------------------------- A 代码生成器(开发利器);   增删改查的处理类,service层,mybatis的xml,SQL( mysql   和oracle)脚本,   jsp页面 都生成 就不用写搬砖的

HTML5学习总结——HTML5入门与新增标签

一.HTML5概要 1.1.为什么需要HTML5 概念: HTML5 是继 HTML4.01, XHTML 1.0 和 DOM 2 HTML 后的又一个重要版本, 旨在消除富 Internet 程序(RIA)对 Flash, Silverlight, JavaFX 一类浏览器插件的依赖. 1991年HTML1.0标准出现1997年HTML4.0发布,4.0标准下的浏览器局限性Flash (安全与稳定堪忧.耗电.触摸.不开放)SilverlightJavaApplet2008年HTML5出现, W

Html5入门应用技巧,初学者必读

Web技术的发展速度太快了,如果你不与时俱进,就会被淘汰.因此,为了应对即将到来的HTML5,本文总结了22个HTML5的初级技巧,希望能对你进一步学习好HTML5会有所帮助. 1. 新的Doctype声明 XHTML的声明太长了,我相信很少会有前端开发人员能手写出这个Doctype声明. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""> HTML5的Doctype声明很短,看到这个声