HTML

浏览器内核:

IE:trident         Firefox : gecko        Safari/chrome : webkit        Opera : presto(新版使用与chrome一样的基于webkit开发的blink内核)。

<!DOCTYPE>:

声明位于文档最顶部的位置,用于告知浏览器使用标准模式还是怪异模式来解析HTML或XHTML文档。

怪异模式、标准模式:

怪异模式(Quirks):在IE6一下浏览器由于对css的解析能力不好,IE产生冠以模式来解析浏览器,在怪异模式下, width 和 height 值为 content+padding+border 。并且为行内元素设置                                宽高可以生效。(应该还有很多,一时间想不起了~等我查完后补上)。

标准模式(Standards):为W3C的标准模式, width 和 height 值只是content值,所以如果为元素设置 padding 值的话页面显示的宽高就会大于你设置的width和height。这种情况需要计算可能会比较麻烦,所以css3加入新的css属性 box-sizing 具体css属性将在css篇进行详述。

块元素、行内元素:

块元素:  div p h1 h2 h3 h4 h5 h6 ul ol li address form table section article aside header hgroup footer nav (section之后为HTML5新增,关于HTML5的梳理在下面)。

行内元素: span tr td th a label textarea input slelect img time (textarea之后的因为是替换元素或叫做内联块元素,可以使用css为其设置宽高,但不会占据一整行)。

标签语义化:

1.去掉或样式丢失的时候能让页面呈现清晰的结构

2.屏幕阅读器(如果访客有视障)会完全根据你的标记来“读”你的网页

3.搜索引擎依赖于标记来确定上下文和各个关键字的权重

4.便于团队开发和维护

HTML5

HTML5新增:

结构标签:section  article  aside  header  hgroup  footer  nav  figure

表单标签:<input type = "email"> type值的增加  email(必须输入Email地址)url(必须输入URL地址)number(必须输入数值)date(选取年月日)month(选取年月)week(选                 取周和年)time(选取时间小时和分钟)datetime(选取UTC时间)datetime-local(选取本地时间)

功能标签:video(视频播放)audio(音频播放)mark(高亮文字)time(时间日期)canvas(画布)command(命令按钮)

还有很多,因为不常使用所以没有记住,有想全面了解的童鞋可以去看书《HTML5与CSS3权威指南》。

HTML5废除标签:

单纯为了展示样式的,可以使用css替代的标签被废除:basefont  big  center  font  s  strike  tt  u

不再使用frame框架

只有部分浏览器支持的标签:applet  bgsound  blink  marquee

其他:rb  acronym  dir  isindex  listing  xmp  nextid  plaintext

canvas:

 <canvas id="canvas">浏览器不支持canvas时出现这行文字</canvas> 
var canvas = document.getElementById('canvas');//获取画布
var context = canvas.getContext('2d');//设置2d上下文
canvas.width = 500;//画布宽度
canvas.height = 500;//画布高度
//线条绘制
context.moveTo(0,50);//起点
context.lineTo(100,50);//终点
context.strokeStyle = "#f00";//线条样式
context.stroke();//线条绘制
//填充绘制
context.moveTo(10,70);//起点
context.lineTo(60,70);//..
context.lineTo(60,120);//..
context.lineTo(10,120);//..
context.lineTo(10,70);//回到起点形成矩形
context.fillStyle = "#ff0";//填充样式
context.fill();//填充绘制
//矩形绘制函数
context.strokeRect(70,150,70,70);//空心
context.fillRect(150,150,70,70);//实心
//圆形绘制
context.beginPath();//开始一个绘制
context.arc(150,300,50,0,2*Math.PI);
context.stroke();
context.closePath();//结束一个绘制
//线性渐变
context.beginPath();
var g1 = context.createLinearGradient(0,0,100,100);//xStart,yStart,xEnd,yEnd
g1.addColorStop(0,"#f00");//offset(0-1),color
g1.addColorStop(1,"#ff0");//offset(0-1),color
context.fillStyle = g1;//设置样式
context.fillRect(100,0,200,50);
context.closePath();
//径向渐变
context.beginPath();
var g2 = context.createRadialGradient(350,0,0,400,50,80);//xStart,yStart,radiusStart,xEnd,yEnd,radiusEnd
g2.addColorStop(0,"blue");
g2.addColorStop(1,"green");
context.fillStyle = g2;
context.arc(400,50,50,0,2*Math.PI);
context.fill();
//图形变形
//context.translate(x,y);//平移
//context.scale(x,y);//扩大
//context.rotate(angle);//旋转的角度
//文字
context.font = "bold 40px Arial";//字体
context.shadowColor = "#3c3c3c";//阴影颜色
context.shadowOffsetX = 2;//阴影X轴偏移
context.shadowOffsetY = 2;//阴影Y轴偏移
context.shadowBlur = 2;//阴影模糊程度
context.fillText("text",100,400);//绘制文字
//剪辑区域
//context.clip();

HTML存储:

localstorage:

 function saveStorage(){
var data = new Object;
data.name = document.getElementById('name').value;
data.email = document.getElementById('email').value;
data.tel = document.getElementById('tel').value;
data.memo = document.getElementById('memo').value;
console.log(data);
var str = JSON.stringify(data);//把对象解析成字符串
console.log(str);
localStorage.setItem(data.name,str);
alert('数据已保存~');
loadStorage('show');
}
function loadStorage(id){
var show = document.getElementById(id);
var result = '<table border="1">';
for(var i=0;i<localStorage.length;i++){
var key = localStorage.key(i);
var value = localStorage.getItem(key);
var data = JSON.parse(value);//从字符串解析出json对象
result += '<tr><td>姓名:' +data.name +'</td>';
result += "<td>EMAIL:" +data.email +'</td>';
result += "<td>电话号码:"+data.tel + '</td>';
result += "<td>备注:"+data.memo + '</td></tr>';
}
result+='</table>';
show.innerHTML = result;
}
function findStorage(id){
var find = document.getElementById('find').value;
var str = localStorage.getItem(find);
var data = JSON.parse(str);//从字符串解析出json对象
var result = "姓名:" +data.name +'<br />';
result += "EMAIL:" +data.email +'<br />';
result += "电话号码:"+data.tel + '<br />';
result += "备注:"+data.memo + '<br />';
var target = document.getElementById(id);
target.innerHTML = result;
}
function clearStorage(){
localStorage.clear();
alert('数据清除成功~');
loadStorage('show');
loadStorage('find');
}

sessionStorage:
     与localStorage使用方法相同,区别在于session是存储在浏览器上,是临时存储,localStorage是永久存储。

知识梳理HTML篇的更多相关文章

  1. 知识梳理——CSS篇

    css引入方法 内嵌 <head> <meta charset="UTF-8"> <title>Document</title> & ...

  2. 知识梳理——HTML篇

    浏览器内核: IE: trident Fixfox: gecko Safari: webkit Opera: 以前是presto,现已改用Google Chrome的Blink Chrome: Bli ...

  3. [C# 基础知识梳理系列]专题六:泛型基础篇——为什么引入泛型

    引言: 前面专题主要介绍了C#1中的2个核心特性——委托和事件,然而在C# 2.0中又引入一个很重要的特性,它就是泛型,大家在平常的操作中肯定会经常碰到并使用它,如果你对于它的一些相关特性还不是很了解 ...

  4. Oracle知识梳理(三)操作篇:SQL基础操作汇总

    Oracle知识梳理(三)操作篇:SQL基础操作汇总 一.表操作 1.表的创建(CREATE TABLE): 基本语句格式:       CREATE TABLE  table_name ( col_ ...

  5. Jmeter 接口测试知识梳理——应用基础篇

    Jmeter 使用也有很长时间了,但是一直没有做一下知识梳理,近期会对公司同事做一下这方面的培训,借此机会,把使用过程中应用到的知识,或是遇到的问题,整理出来,方便大家学习! Jmeter 接口测试知 ...

  6. Jmeter 接口测试知识梳理——持续集成篇

    Jmeter 使用也有很长时间了,但是一直没有做一下知识梳理,近期会对公司同事做一下这方面的培训,借此机会,把使用过程中应用到的知识,或是遇到的问题,整理出来,方便大家学习! Jmeter + Ant ...

  7. Jmeter 接口测试知识梳理——环境搭建篇

    Jmeter 使用也有很长时间了,但是一直没有做一下知识梳理,近期会对公司同事做一下这方面的培训,借此机会,把使用过程中应用到的知识,或是遇到的问题,整理出来,方便大家学习! 环境搭建篇 很多文章介绍 ...

  8. C#基础知识梳理索引

    C#基础知识梳理索引 一 引子 之前曾写了一篇随笔<.NET平台技术体系梳理+初学者学习路径推荐+我们的愿景与目标> 三个月过去了,目标使更多的编程初学者,轻松高效地掌握C#开发的基础,重 ...

  9. Babel7知识梳理

    Babel7 知识梳理 对 Babel 的配置项的作用不那么了解,是否会影响日常开发呢?老实说,大多情况下没有特别大的影响(毕竟有搜索引擎). 不过呢,还是想更进一步了解下,于是最近认真阅读了 Bab ...

随机推荐

  1. phpcms /api/phpsso.php SQL Injection Vul

    catalogue . 漏洞描述 . 漏洞触发条件 . 漏洞影响范围 . 漏洞代码分析 . 防御方法 . 攻防思考 1. 漏洞描述 Relevant Link:2. 漏洞触发条件3. 漏洞影响范围4. ...

  2. phpMyadmin /scripts/setup.php Execute Arbitrary PHP Code Via A Crafted POST Request CVE-2010-3055

    目录 . 漏洞描述 . 漏洞触发条件 . 漏洞影响范围 . 漏洞代码分析 . 防御方法 . 攻防思考 1. 漏洞描述 The configuration setup script (aka scrip ...

  3. windows核心编程读后感(待续)

    自从大一读那本超厚的C程序设计以后,从来没有像这样慢慢地读一本书了.windows核心这本书足足看了2个多星期.一张张慢慢看,做笔记.感觉学到了很多基础的知识,关于内核方面的没有啥可以做实验的,都在看 ...

  4. CentOS关机

    1. 关机前准备 1.1 查看有谁在线 who 1.2 查看网络联机状态 netstat -a 1.3 查看后台正在执行的程序 ps -aux 1.4 向所有在线用户发出警告信息 shutdown - ...

  5. HDU 4223 Dynamic Programming?(最小连续子序列和的绝对值O(NlogN))

    传送门 Description Dynamic Programming, short for DP, is the favorite of iSea. It is a method for solvi ...

  6. HDU 1425 sort(堆排序/快排/最大堆/最小堆)

    传送门 Description 给你n个整数,请按从大到小的顺序输出其中前m大的数. Input 每组测试数据有两行,第一行有两个数n,m(0<n,m<1000000),第二行包含n个各不 ...

  7. [Android] HttpURLConnection & HttpClient & Socket

    Android的三种网络联接方式 1.标准Java接口:java.net.*提供相关的类//定义地址URL url = new URL("http://www.google.com" ...

  8. mysql 生成排名字段

    假设有test表,下图为表机构和数据,score表示积分.现在要查询积分排名为第几的id?? 查询语句 select id,score,(@rowno:=@rowno+1) as rowno from ...

  9. Nginx系列1之部分模块详解

    1 内核模块: 名称: daemon 语法: daemon on |off 默认值: on 功能: 决定nginx 在前台执行还是后台守护进程执行的 ================== 名称: En ...

  10. python学习笔记-(三)条件判断和循环

    1.条件判断语句 Python中条件选择语句的关键字为:if .elif .else这三个.其基本形式如下: age_of_cc = 27 age = int(input("guessage ...