前端HTML知识点
1,Doctype作⽤?标准模式与兼容模式各有什么区别?
<!DOCTYPE>声明位于位于HTML⽂档中的第⼀⾏,处于 <html>标签之前。告知浏览器的解析      器⽤什么⽂档标准解析这个⽂档。DOCTYPE不存在或格式不正确会导致⽂档以兼容模式呈现。
标准模式的排版 和JS运作模式都是以该浏览器⽀持的最⾼标准运⾏。在兼容模式中,页⾯以宽松    的向后兼容的⽅式显⽰,模拟⽼式浏览器的⾏为以防⽌站点⽆法⼯作。
2,HTML5 为什么只需要写 <!DOCTYPE HTML>?
HTML5 不基于 SGML(标准通⽤标记语⾔),因此不需要对DTD(⽂档类型定义(Document    Type Definition))进⾏引⽤,但是需要doctype来规范浏览器的⾏为(让浏览器按照它们应该的⽅    式来运⾏);
⽽HTML4.01基于SGML,所以需要对DTD进⾏引⽤,才能告知浏览器⽂档所使⽤的⽂档类型。
HTML 4.01 规定了三种不同的 <!DOCTYPE> 声明,分别是:Strict、Transitional (过渡)和      Frameset(框架)。HTML5 中仅规定了⼀种:<!DOCTYPE html>
margin属性怎么用
3,⾏内元素有哪些?块级元素有哪些? 空(void)元素有那些?
⾸先:CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的      display值,如div的display默认值
为“block”,则为“块级”元素;span默认display属性值      为“inline”,是“⾏内”元素。
(1)⾏内元素有:a b span img input select strong(强调的语⽓)
(2)块级元素有:div ul ol li dl dt dd h1 h2 h3 h4…p
(3)常见的空元素:<br><hr><img><input><link><meta>
鲜为⼈知的是:
<area><base><col><command><embed><keygen><param><source><track><wbr>
4,页⾯导⼊样式时,使⽤link和@import有什么区别?
link属于XHTML标签,除了加载CSS外,还能⽤于定义RSS, 定义rel连接属性等作⽤;⽽@import    是CSS提供的,只能⽤于加载CSS;
页⾯被加载的时,link会同时被加载,⽽@import引⽤的CSS会等到页⾯被加载完再加载;
import是CSS2.1 提出的,只在IE5以上才能被识别,⽽link是XHTML标签,⽆兼容问题;
SGML是标准通⽤标记语⾔ HTML是超⽂本标记语⾔,主要是⽤于规定怎么显⽰⽹页XML是可扩      展标记语⾔ 是未来⽹页语⾔的发展⽅向,可能会替代HTML,他和HTML都是由SGML延伸转变      ⽽来的,你可以理解SGML是最早的版本,但现在已经淘汰不⽤了XML和HTML 的最⼤区别就在    于 XML的标签是可以⾃⼰创建的,数量⽆限多,⽽HTML的标签都是固定的⽽且数量有限。还有      ⼀个是XHTML也是现在基本上所有⽹页都在⽤的标记语⾔,他其实和HTML没什么本质的区别标    签都⼀样,⽤法也都⼀样,就是⽐HTML更严格,⽐如标签必须都⽤⼩写,标签都必须有闭合标      签等
5,介绍⼀下你对浏览器内核的理解?
主要分成两部分:渲染引擎(layout engineer或Rendering Engine)和JS引擎。
渲染引擎:负责取得⽹页的内容(HTML、XML、图像等等)、整理讯息(例如加⼊CSS等),      以及计算⽹页的显⽰⽅式,然后会输出⾄显⽰器或打印机。浏览器的内核的不同对于⽹页的语法      解释会有不同,所以渲染的效果也不相同。所有⽹页浏览器、电⼦邮件客户端以及其它需要编      辑、显⽰⽹络内容的应⽤程序都需要内核。
JS引擎则:解析和执⾏javascript来实现⽹页的动态效果。
最开始渲染引擎和JS引擎并没有区分的很明确,后来JS引擎越来越独⽴,内核就倾向于只指渲染      引擎。
6,常见的浏览器内核有哪些?
Trident内核(IE内核):IE,MaxThon,TT,The World,360,搜狗浏览器等。[⼜称MSHTML]
Gecko内核(Firefox内核):Netscape6及以上版本,FF,MozillaSuite/SeaMonkey等
Presto内核(Opera前内核):Opera7及以上。      [Opera内核原为:Presto,现为:Blink;]
Webkit内核(Safari,Chrome):Safari,Chrome等。  [ Chrome的:Blink(WebKit的分⽀)]
Safari是苹果计算机的操作系统Mac OS中的浏览器
7,html5有哪些新特性、移除了那些元素?如何处理HTML5新标签的浏览器兼容问题?如何区分 HTML 和 HTML5?
* HTML5 现在已经不是 SGML 的⼦集,主要是关于图像,位置,存储,多任务等功能的增加。
绘画 canvas;
⽤于媒介回放的 video 和 audio 元素;
本地离线存储 localStorage 长期存储数据,浏览器关闭后数据不丢失;
sessionStorage 的数据在浏览器关闭后⾃动删除;
语意化更好的内容元素,⽐如 article、footer、header、nav、section;
表单控件,calendar、date、time、email、url、search;
新的技术webworker, websocket, Geolocation;
web worker是运⾏在后台的 JavaScript,独⽴于其他脚本,不会影响页⾯的性能。您可以继续做任何愿意做的事情:点击、选取内容等等,⽽此时 web worker 在后台运⾏
WebSocket协议是基于TCP的⼀种新的⽹络协议。它实现了浏览器与服务器全双⼯(full-duplex)通信——允许服务器主动发送信息给客户端
Geolocation是⼀个基于地理位置的应⽤。
移除的元素:
纯表现的元素:basefont,big,center,font, s,strike,tt,u;
对可⽤性产⽣负⾯影响的元素:frame,frameset,noframes;
* ⽀持HTML5新标签:
IE8/IE7/IE6⽀持通过ateElement⽅法产⽣的标签,
可以利⽤这⼀特性让这些浏览器⽀持HTML5新标签,
浏览器⽀持新标签后,还需要添加标签默认的样式。
当然也可以直接使⽤成熟的框架、⽐如html5shim;
<!--[if lt IE 9]>
<![endif]-->
* 如何区分HTML5: DOCTYPE声明\新增的结构元素\功能元素
H5新特性
表单画布⾳视频地理定位媒体查询 css新特性离线缓存本地存储拖拽
8,简述⼀下你对HTML语义化的理解?
⽤正确的标签做正确的事情。
html语义化让页⾯的内容结构化,结构更清晰,便于对浏览器、搜索引擎解析;
即使在没有样式CSS情况下也以⼀种⽂档格式显⽰,并且是容易阅读的;
搜索引擎的爬⾍也依赖于HTML标记来确定上下⽂和各个关键字的权重,利于SEO;
使阅读源代码的⼈对⽹站更容易将⽹站分块,便于阅读维护理解。
9,HTML5的离线储存怎么使⽤,⼯作原理能不能解释⼀下?
在⽤户没有连⽹时,可以正常访问站点或应⽤,在⽤户与⽹络连接时更新⽤户机器上的缓存⽂件。
原理:HTML5的离线存储是基于⼀个新建的.appcache⽂件的缓存机制(不是存储技术),通过这个⽂件
上的解析清单离线存储资源,这些资源就会像cookie⼀样被存储了下来。之后当⽹络在处于离线状态下时,浏览器会通过被离线存储的数据进⾏页⾯展⽰。
如何使⽤:
页⾯头部像下⾯⼀样加⼊⼀个manifest的属性;
<html lang="en" manifest="demo.appcache">
在cache.manifest⽂件的编写离线存储的资源;
CACHE MANIFEST
#v0.11
CACHE:
js/app.js
css/style.css
NETWORK:
resourse/logo.png
FALLBACK:
/ /offline.html
在离线状态时,操作window.applicationCache进⾏需求实现。
10,浏览器是怎么对HTML5的离线储存资源进⾏管理和加载的呢?
在线的情况下,浏览器发现html头部有manifest属性,它会请求manifest⽂件,如果是第⼀次访问app,那么浏览器就会根据manifest⽂件的内容下载相应的资源并且进⾏离线存储。如果已经访问过app并且资源已经离线存储了,那么浏览器就会使⽤离线的资源加载页⾯,然后浏览器会对⽐新的manifest⽂件与旧的manifest⽂件,如果⽂件没有发⽣改变,就不做任何操作,如果⽂件改变了,那么就会重新下载⽂件中的资源并进⾏离线存储。
离线的情况下,浏览器就直接使⽤离线存储的资源。
11,请描述⼀下 cookies,sessionStorage 和 localStorage 的区别?
cookie是⽹站为了标⽰⽤户⾝份⽽储存在⽤户本地终端(Client Side)上的数据(通常经过加密),cookie还可以设置有效时间
cookie数据始终在同源的http请求中携带(即使不需要),记会在浏览器和服务器间来回传递,
每次ajax请求都会吧cookie传送到后台,cookie⼀般⽤做⽤户登陆,后台可以根据cookie信息判断⽤户是否登陆状态
sessionStorage和localStorage不会⾃动把数据发给服务器,仅在本地保存
区别在于
存储⼤⼩:
cookie数据⼤⼩不能超过4k。
sessionStorage和localStorage 虽然也有存储⼤⼩的限制,但⽐cookie⼤得多,可以达到5M或更⼤。
有期时间:
localStorage    存储持久数据,浏览器关闭后数据不丢失除⾮主动删除数据;
sessionStorage  数据在当前浏览器窗⼝关闭后⾃动删除。
cookie          设置的cookie过期时间之前⼀直有效,即使窗⼝或浏览器关闭
iframe⽤于在⽹页内显⽰⽹页。
12,iframe有那些缺点?iframe⽤于在⽹页内显⽰⽹页。
iframe会阻塞主页⾯的Onload事件;
搜索引擎的检索程序⽆法解读这种页⾯,不利于SEO;
iframe和主页⾯共享连接池,⽽浏览器对相同域的连接有限制,所以会影响页⾯的并⾏加载。
使⽤iframe之前需要考虑这两个缺点。如果需要使⽤iframe,最好是通过javascript
动态给iframe添加src属性值,这样可以绕开以上两个问题。
13,Label的作⽤是什么?是怎么⽤的?
label标签来定义表单控制间的关系,当⽤户选择该标签时,浏览器会⾃动将焦点转到和标签相关的表单控件上。
<label for="Name">Number:</label>
<input type=“text“name="Name" id="Name"/>
<label>Date:<input type="text" name="B"/></label>
14,如何实现浏览器内多个标签页之间的通信?
WebSocket、也可以调⽤localstorge、cookies等本地存储⽅式,还可以使⽤页⾯的路由参数传递
localstorge另⼀个浏览上下⽂⾥被添加、修改或删除时,它都会触发⼀个事件,
我们通过监听事件,控制它的值来进⾏页⾯信息通信;
15,如何在页⾯上实现⼀个圆形的可点击区域?
map+area或者svg
border-radius
纯js实现 需要求⼀个点在不在圆上简单算法、获取⿏标坐标等等
16,title与h1的区别、b与strong的区别、i与em的区别?
title属性没有明确意义只表⽰是个标题,H1则表⽰层次明确的标题,对页⾯信息的抓取也有很⼤的影响;
strong是标明重点内容,有语⽓加强的含义,使⽤阅读设备阅读⽹络时:<strong>会重读,⽽<B>是展⽰强调内容。 i内容展⽰为斜体,em表⽰强调的⽂本;

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。