img标签的title和alt有什么区别
title
通常当鼠标滑动
到元素上的时候显示alt
是<img>
的特有属性,是图片内容的等价描述,用于图片无法加载时显示、读屏器阅读图片。可提图片高可访问性,除了纯装饰图片外都必须设置有意义的值,搜索引擎会重点分析。
语义化的理解
- 用正确的标签做正确的事情!
- HTML语义化就是让页面的
内容结构化
,便于对浏览器、搜索引擎解析; - 在没有样式CSS情况下也以一种
文档格式
显示,并且是容易阅读的。 - 搜索引擎的爬虫依赖于标记来确定上下文和各个关键字的权重,利于
SEO
。 - 使阅读源代码的人对网站更容易将网站
分块
,便于阅读维护理解
html5有哪些新特性、移除了那些元素?
-
HTML5
现在已经不是 SGML 的子集,主要是关于图像,位置,存储,多任务等功能的增加- 新增选择器 document.
querySelector
、document.querySelectorAll
- 拖拽释放(
Drag
anddrop
) API - 媒体播放的
video
和audio
- 本地存储
localStorage
和sessionStorage
- 离线应用
manifest
- 桌面通知
Notifications
- 语意化标签
article
、footer
、header
、nav
、section
- 增强表单控件
calendar
、date
、time
、email、url、search - 地理位置 Geolocation
- 多任务 webworker
- 全双工通信协议
websocket
- 历史管理 history
- 跨域资源共享(CORS) Access-Control-Allow-Origin
- 页面可见性改变事件 visibilitychange
- 跨窗口通信 PostMessage
- Form Data 对象
- 绘画
canvas
- 新增选择器 document.
-
移除的元素:
- 纯表现的元素:basefont、big、center、font、 s、strike、tt、u
- 对可用性产生负面影响的元素:
frame
、frameset、noframes
-
支持HTML5新标签:
- IE8/IE7/IE6支持通过document.createElement方法产生的标签
- 可以利用这一特性让这些浏览器支持HTML5新标签
- 当然也可以直接使用成熟的框架、比如
html5shim
如何区分 HTML 和 HTML5
DOCTYPE
声明、新增的结构元素、功能元素
HTML5的离线储存怎么使用,工作原理能不能解释一下?
- 在用户没有与因特网连接时,可以正常访问站点或应用,在用户与因特网连接时,更新用户机器上的缓存文件
- 原理:HTML5的离线存储是基于一个新建的
.appcache
文件的缓存机制(不是存储技术),通过这个文件上的解析清单离线存储资源,这些资源就会像cookie一样被存储了下来。之后当网络在处于离线状态下时,浏览器会通过被离线存储数据
进行页面展示 - 如何使用:
- 页面头部像下面一样加入一个
manifest
的属性; - 在
cache.manifest
文件的编写离线存储的资源 - 在离线状态时,操作
window.applicationCache
进行需求实现
- 页面头部像下面一样加入一个
CACHE MANIFEST
#v0.11
CACHE:
js/app.js
css/style.css
NETWORK:
resourse/logo.png
FALLBACK:
/offline.html
iframe有那些缺点?
- iframe会阻塞主页面的
Onload
事件 - 搜索引擎的检索程序无法解读这种页面,
不利于SEO
- iframe和主页面共享连接池,而浏览器对相同域的连接有限制,所以会影响页面的
并行加载
- 使用iframe之前需要考虑这两个缺点。如果需要使用iframe,最好是通过
javascript
动态给iframe添加src
属性值,这样可以绕开以上两个问题
xhtml和html有什么区别?
链接
HTML
:超文本标记语言
XML
: 可扩展标记语言
XHTML
: 可扩展超文本标记语言
- 一个是功能上的差别
- 主要是XHTML可兼容各大浏览器、手机以及PDA,并且浏览器也能快速正确地编译网页
- 另外是书写习惯的差别
- XHTML 元素必须被正确地嵌套,闭合,区分大小写,文档必须拥有根元素
Doctype作用? 严格模式与混杂模式如何区分?它们有何意义?
- 页面被加载的时,link会同时被加载,而@imort页面被加载的时,link会同时被加载,而
@import
引用的CSS会等到页面被加载完
再加载 import只在IE5
以上才能识别,而link
是XHTML标签,无兼容问题 link方式的样式的权重
高于@import的权重 <!DOCTYPE>
声明位于文档中的最前面,处于<html>
标签之前。告知浏览器的解析器, 用什么文档类型 规范来解析这个文档- 严格模式的排版和 JS 运作模式是 以该浏览器
支持
的最高标准运行 document.compatMode
= ‘CSS1Compat’ - 在混杂模式中,页面以宽松的向后兼容的方式显示。模拟老式浏览器的行为以防止站点无法工作。
DOCTYPE
不存在或格式不正确会导致文档以混杂模式呈现 document.compatMode
= ‘BackCompat’
行内元素有哪些?块级元素有哪些? 空(void)元素有那些?行内元素和块级元素有什么区别?
- 行内元素有:a b
span
imginput
select strong - 块级元素有:div ul ol li dl dt dd h1 h2 h3 h4… p
- 行块元素:img,input,select,textarea
- 空元素:br,hr,link,meta
- 排列方式:
- 块盒独占一行,行盒,行块盒并排显示,且行块盒标签间换行会解析为
空格
- 块盒独占一行,行盒,行块盒并排显示,且行块盒标签间换行会解析为
- 宽高边距设置:
- 行盒宽高由内容撑开,块盒和行块盒可设置宽高
- 行盒padding,margin水平方向有效,垂直方向仅会影响
背景
,不占据空间- 行块盒不支持 margin:auto,位置受
text-align
影响 - 行块盒撑开腹肌高度不精确(img)
- 行块盒不支持 margin:auto,位置受
- 默认宽度
- 块级元素的 width 默认为 100%,行盒及行块盒根据其自身的内容来决定其宽度
HTML全局属性(global attribute)有哪些
class
:为元素设置类名data-*
: 为元素增加自定义属性draggable
: 设置元素是否可拖拽id
: 元素id,文档内唯一style
: 行内css样式title
: 元素相关的建议信息
Canvas和SVG有什么区别?
svg
绘制出来的每一个图形的元素都是独立的DOM节点,能够方便的绑定事件或用来修改。canvas
输出的是一整幅画布- svg输出的图形是
矢量图形
,后期可以修改参数来自由放大缩小,不会失真和锯齿。而canvas输出标量画布
,就像一张图片一样,放大会失真或者锯齿
如何在页面上实现一个圆形的可点击区域?
- svg
- border-radius
- canvas
viewport
<meta name="viewport" content="width=device-width,initial-scale=1.0,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no" />
// width 设置viewport宽度,为一个正整数,或字符串‘device-width’
// device-width 设备宽度
// height 设置viewport高度,一般设置了宽度,会自动解析出高度,可以不用设置
// initial-scale 默认缩放比例(初始缩放比例),为一个数字,可以带小数
// minimum-scale 允许用户最小缩放比例,为一个数字,可以带小数
// maximum-scale 允许用户最大缩放比例,为一个数字,可以带小数
// user-scalable 是否允许手动缩放
怎样处理 移动端 1px 被 渲染成 2px问题
- 局部处理
- meta标签中的 viewport属性 ,initial-scale 设置为 1
- rem按照设计稿标准走,外加利用
transfrom
的scale(0.5) 缩小一倍即可;
- 全局处理
- mata标签中的 viewport属性 ,
initial-scale
设置为 0.5 - rem 按照设计稿标准走即可
- mata标签中的 viewport属性 ,
meta viewport相关
<!DOCTYPE html> <!--H5标准声明,使用 HTML5 doctype,不区分大小写-->
<head lang="en"> <!--标准的 lang 属性写法-->
<meta charset=’utf-8′> <!--声明文档使用的字符编码-->
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1″/> <!--优先使用 IE 最新版本和 Chrome-->
<meta name="description" content="不超过150个字符"/> <!--页面描述-->
<meta name="keywords" content=""/> <!-- 页面关键词-->
<meta name="author" content="name, email@gmail.com"/> <!--网页作者-->
<meta name="robots" content="index,follow"/> <!--搜索引擎抓取-->
<meta name="viewport" content="initial-scale=1, maximum-scale=3, minimum-scale=1, user-scalable=no"> <!--为移动设备添加 viewport-->
<meta name="apple-mobile-web-app-title" content="标题"> <!--iOS 设备 begin-->
<meta name="apple-mobile-web-app-capable" content="yes"/> <!--添加到主屏后的标题(iOS 6 新增)
是否启用 WebApp 全屏模式,删除苹果默认的工具栏和菜单栏-->
<meta name="apple-itunes-app" content="app-id=myAppStoreID, affiliate-data=myAffiliateData, app-argument=myURL">
<!--添加智能 App 广告条 Smart App Banner(iOS 6+ Safari)-->
<meta name="apple-mobile-web-app-status-bar-style" content="black"/>
<meta name="format-detection" content="telphone=no, email=no"/> <!--设置苹果工具栏颜色-->
<meta name="renderer" content="webkit"> <!-- 启用360浏览器的极速模式(webkit)-->
<meta http-equiv="X-UA-Compatible" content="IE=edge"> <!--避免IE使用兼容模式-->
<meta http-equiv="Cache-Control" content="no-siteapp" /> <!--不让百度转码-->
<meta name="HandheldFriendly" content="true"> <!--针对手持设备优化,主要是针对一些老的不识别viewport的浏览器,比如黑莓-->
<meta name="MobileOptimized" content="320″> <!--微软的老式浏览器-->
<meta name="screen-orientation" content="portrait"> <!--uc强制竖屏-->
<meta name="x5-orientation" content="portrait"> <!--QQ强制竖屏-->
<meta name="full-screen" content="yes"> <!--UC强制全屏-->
<meta name="x5-fullscreen" content="true"> <!--QQ强制全屏-->
<meta name="browsermode" content="application"> <!--UC应用模式-->
<meta name="x5-page-mode" content="app"> <!-- QQ应用模式-->
<meta name="msapplication-tap-highlight" content="no"> <!--windows phone 点击无高亮
设置页面不缓存-->
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0″>
div+css的布局较table布局有什么优点?
- 改版的时候更方便 只要改
css
文件。 - 页面加载速度更快、结构化清晰、页面显示简洁。
- 表现与结构相分离。
- 易于优化(
seo
)搜索引擎更友好,排名更容易靠前。
简述一下src与href的区别
-
src
用于替换当前元素,href
用于在当前文档和引用资源之间确立联系。 -
src是source的缩写,指向
外部资源的位置
,指向的内容将会嵌入到文档中当前标签所在位置;在请求src资源时会将其指向的资源下载并应用到文档内,例如js脚本,img图片和frame等元素。
<script src ="js.js"></script>
当浏览器解析到该元素时,会暂停其他资源的下载和处理
,直到将该资源加载、编译、执行完毕,图片和框架等元素也如此,类似于将所指向资源嵌入当前标签内。这也是为什么将js脚本放在底部而不是头部 -
href
是Hypertext Reference的缩写,指向网络资源所在位置
,建立和当前元素(锚点)或当前文档(链接)之间的链接,如果我们在文档中添加 -
<link href="common.css" rel="stylesheet"/>
那么浏览器会识别该文档为css
文件,就会并行下载资源
并且不会停止对当前文档的处理。这也是为什么建议使用link方式来加载css,而不是使用@import方式