美文网首页
HTML执行顺序

HTML执行顺序

作者: 捕梦少女的梦想 | 来源:发表于2018-12-21 14:37 被阅读0次

html的基本结构

<html>
    <head>
        <!-- 头部中包含的标记是页面的标题、序言、说明等内容,它本身不作为内容来显示,但影响网页显示的效果 -->
    </head>
    <body>
        <!-- 显示实际内容 -->
    </body>
</html>

①html:贯穿整个页面

②css:三种声明方式

  • 外联样式表:在head便签中 用link标签的href属性来引用后缀名为.css的css样式文件
  • 内联样式表:在head标签下的style标签中,选择器 + 样式声明
  • 内部样式表:在标签的style属性中添加css样式声明
    ③JavaScript:在<script>标签中,可以在head标签中,也可以在body标签中(区别一会再说)
目前为止,在整个html页面中,可以写html代码、css样式、JS脚本语言

写的位置:

  • html贯穿整个页面,
  • css可以定义在head头标签中,也可以在定义在html标签的属性中
  • JavaScript定义在<script>标签中,<script>标签既能在head标签中定义也能在body标签中定义

加载顺序:

<html>
    <head>
        <!-- 引用外部JS文件 -->
        <script src="..........."></script>
        <!--引用外部css样式 -->
        <link href="............."/>
        <style>
               ..............
        </style>
        <script>
               ..............
        </script>
    </head>
    <body>
        <script>
               ..............
        </script>
    </body>
</html>

从上到下运行,先解析head标签中的代码,

(1)head标签中会包含一些引用外部文件的代码,从开始运行就会下载这些被引用的外部文件

当遇到script标签的时候,浏览器暂停解析(不是暂停下载),将控制权交给JavaScript引擎(解释器)
如果<script>标签引用了外部脚本,就下载该脚本,否则就直接执行,执行完毕后将控制权交给浏览器渲染引擎

(2)当head中代码解析完毕,会开始解析body中的代码

如果此时head中引用的外部文件没有下载完,将会继续下载
浏览器解析body代码中的元素,会按照head中声明一部分样式去解析
如果此时遇到body标签中的<script>,同样会将控制权交给JavaScript引擎来解析JavaScript
解析完毕后将控制权交还给浏览器渲染引擎。
当body中的代码全部执行完毕、并且整个页面的css样式加载完毕后,css会重新渲染整个页面的html元素。

(3)按照之前的描述,<script>写到body标签内靠后比较好,

因为JavaScript 会操作html元素,如果在body加载完之前写JavaScript,会造成JavaScript找不到页面元素
但是我们经常将<script>写到head中,body中不会有大量的js代码,body中的html代码结构会比较清晰
  • window.onload: 等待页面中的所有内容加载完毕之后才会执行
  • $(document).ready(): 页面中所有DOM结构绘制完毕之后就能够执行
可以这样理解:window.onload$(document).ready()/$(function(){});相当于 写在body 内 最靠后的<script>代码段

Html、js的加载顺序:

<html>
<head>
<script>
    alert("script-head");
</script>
</head>
<body onload="alert('html-tag');">
<script>
    alert("script-body");
</script>
</body>
<script>
    alert("script-body-outer");
</script>
</html>
<script>
    alert("script-html-outer");
</script>
输出结果:
script-head、script-body、script-body-outer、script-html-outer、html-tag

从上面输出结果可以明显看到:

js在页面装载时执行的顺序就是其引入标记<script />的出现顺序,<script />标记里面的或者通过src引入的外部JS,都是按照其语句出现的顺序执行,而且执行过程是文档装载的一部分。只有全部js脚本按顺序加载完毕后才开始html标签内容的加载过程。

相关文章

  • HTML执行顺序

    html的基本结构 ①html:贯穿整个页面 ②css:三种声明方式 外联样式表:在head便签中 用link标签...

  • vue生命周期函数区别作用

    created:html加载完成之前,执行。执行顺序:父组件-子组件 mounted:html加载完成后执行。执行...

  • vue常用方法整理

    created:html加载完成之前,执行。执行顺序:父组件-子组件 mounted:html加载完成后执行。执行...

  • vue中created,mounted,methods,watc

    created:html加载完成之前,执行。执行顺序:父组件-子组件 mounted:html加载完成后执行。执行...

  • Vue生命周期介绍

    jscreated :html加载完成之前,执行。执行顺序:父组件-子组件mounted:html加载完成后执行。...

  • JS相关概念

    CSS和JS在网页中的放置顺序是怎样的? 首先要区分css和js的执行顺序 html文件是自上而下的执行方式,但引...

  • Dom加载解析

    加载顺序 解析HTML结构; 加载外部脚本和样式表文件; 解析并执行脚本代码; 构造HTML DOM模型; 加载图...

  • js 事件执行顺序

    为什么需要addEventListener? 先来看一个片段: html代码 事件执行顺序 用on的代码 wind...

  • script标签的async和defer

    script标签用于加载脚本与执行脚本,直接使用script脚本的话,HTML会按照顺序来加载并执行脚本,在脚本加...

  • hive sql执行顺序

    mysq和hive的sql执行顺序对比 msyql语句执行顺序代码写的顺序: 代码的执行顺序: hive 语句执行...

网友评论

      本文标题:HTML执行顺序

      本文链接:https://www.haomeiwen.com/subject/nqbmkqtx.html