1.HTML5语义化

什么是语义化

  用合理、正确的标签来展示内容,比如h1~h6定义标题

好处

  • 易于用户阅读,样式丢失的时候能让页面呈现清晰的结构。
  • 有利于SEO,搜索引擎根据标签来确定上下文和各个关键字的权重。
  • 方便其他设备解析,如盲人阅读器根据语义渲染网页
  • 有利于开发和维护,语义化更具可读性,代码更好维护,与CSS3关系更和谐。

详细介绍地址:https://link.zhihu.com/?target=http%3A//www.daqianduan.com/6549.html

2.为什么最好把 CSS 的<link>标签放在<head></head>之间?为什么最好把 JS 的<script>标签恰好放在</body>之前,有例外情况吗?

<link>放在<head>

  把<link>标签放在<head></head>之间是规范要求的内容。此外,这种做法可以让页面逐步呈现,提高了用户体验。如果将将样式表放在文档底部附近,会使许多浏览器(包括 Internet Explorer)不能逐步呈现页面。一些浏览器会阻止渲染,以避免在页面样式发生变化时,重新绘制页面中的元素。这种做法可以防止呈现给用户空白的页面或没有样式的内容。

<script>标签恰好放在</body>之前

脚本在下载和执行期间会阻止 HTML 解析。把<script>标签放在底部,保证 HTML 首先完成解析,将页面尽早呈现给用户。

例外情况是当你的脚本里包含document.write()时。但是现在,document.write()不推荐使用。同时,将<script>标签放在底部,意味着浏览器不能开始下载脚本,直到整个文档(document)被解析。也许,对此比较好的做法是,<script>使用defer属性,放在<head>中。

什么是渐进式渲染(progressive rendering)?

渐进式渲染是用于提高网页性能(尤其是提高用户感知的加载速度),以尽快呈现页面的技术。

在以前互联网带宽较小的时期,这种技术更为普遍。如今,移动终端的盛行,而移动网络往往不稳定,渐进式渲染在现代前端开发中仍然有用武之地。

一些举例:

图片懒加载——页面上的图片不会一次性全部加载。当用户滚动页面到图片部分时,JavaScript 将加载并显示图像。

确定显示内容的优先级(分层次渲染)——为了尽快将页面呈现给用户,页面只包含基本的最少量的 CSS、脚本和内容,然后可以使用延迟加载脚本或监听DOMContentLoaded/load事件加载其他资源和内容。

异步加载 HTML 片段——当页面通过后台渲染时,把 HTML 拆分,通过异步请求,分块发送给浏览器。

img中的alt和元素的title属性作用

img的alt属性

如果无法显示图像,浏览器将显示alt指定的内容

元素title属性
在鼠标移到元素上时显示title的内容

href和src区别

href
href标识超文本引用,用在link和a等元素上,href是引用和页面关联,是在当前元素和引用资源之间建立联系
若在文档中添加href ,浏览器会识别该文档为 CSS 文件,就会并行下载资源并且不会停止对当前文档的处理。这也是为什么建议使用 link 方式加载 CSS,而不是使用 @import 方式。

src
src表示引用资源,替换当前元素,用在img,script,iframe上,src是页面内容不可缺少的一部分。
当浏览器解析到src ,会暂停其他资源的下载和处理(图片不会暂停其他资源下载),直到将该资源加载、编译、执行完毕,类似于将所指向资源应用到当前内容。这也是为什么建议把 js 脚本放在底部而不是头部的原因。

行内元素和块级元素有哪些

行内元素

一个行内元素只占据它对应标签的边框所包含的空间
一般情况下,行内元素只能包含数据和其他行内元素

b, big, i, small, tt
abbr, acronym, cite, code, dfn, em, kbd, strong, samp, var
a, bdo, br, img, map, object, q, script, span, sub, sup
button, input, label, select, textarea

块级元素

占据一整行,高度、行高、内边距和外边距都可以改变,可以容纳块级标签和其他行内标签

header,form,ul,ol,table,article,div,hr,aside,figure,canvas,video,audio,footer

iframe框架有那些优缺点

优点:

  • iframe能够原封不动的把嵌入的网页展现出来。
  • 如果有多个网页引用iframe,那么你只需要修改iframe的内容,就可以实现调用的每一个页面内容的更改,方便快捷。
  • 网页如果为了统一风格,头部和版本都是一样的,就可以写成一个页面,用iframe来嵌套,可以增加代码的可重用。
  • 如果遇到加载缓慢的第三方内容如图标和广告,这些问题可以由iframe来解决。

缺点:

  • 搜索引擎的爬虫程序无法解读这种页面
  • 框架结构中出现各种滚动条
  • 使用框架结构时,保证设置正确的导航链接。
  • iframe页面会增加服务器的http请求


最新文章

  1. GSM07.10协议中串口复用的注意事项
  2. Java基础学习(一)
  3. 【MongoDB】2.可视化工具的安装和使用
  4. 9.请写出PHP5权限控制修饰符
  5. Android功能模块化之生成验证码Bitmap
  6. 定位- CLGeoencoder - 反编码
  7. Python新手学习基础之运算符——成员运算与身份运算
  8. android AsyncTask 详细例子(2)
  9. zendStudio安装Xdebug项目断点调试
  10. Linux下OpenCV的环境搭建(转)
  11. git for windows上传项目到github
  12. ActiveMq笔记1-消息可靠性理论
  13. jvm学习记录-对象的创建、对象的内存布局、对象的访问定位
  14. mysql海量数据的优化
  15. C语言 变量的作用域和生命周期(转)
  16. [物理学与PDEs]第4章第2节 反应流体力学方程组 2.1 粘性热传导反应流体力学方程组
  17. P2860 [USACO06JAN]冗余路径Redundant Paths
  18. CentoOS6.6安装netcat
  19. Dubbo与Zookeeper、SpringMVC整合和使用(负载均衡、容错)(略有修改)
  20. JavaScript权威指南--类和模块

热门文章

  1. 如何在JS代码中消除for循环
  2. JS内置对象-Array之indexOf和lastIndexOf
  3. ubuntu16.04没有办法使用CRT,或者SSH工具的解决办法
  4. 稳定易用的 Django 分页库,完善分页功能
  5. 中国 700 万开发者中,370 万在使用 VS Code
  6. AWS re:Invent 2019参会有感
  7. es6 数组去重
  8. .Net中WebService的Demo示例
  9. Jetpack架构组件(二)Lifecycle使用
  10. Cocos Creator | 炮弹发射效果模拟