为什么css放上面js放下面

css放上面js放下面的原因:1、在加载html生成DOM tree的时候,可以同时对DOM tree进行渲染,这样可以防止闪跳,白屏或者布局混乱;2、javascript加载后会立即执行,同时会阻塞后面的资源加载。

为什么css放上面js放下面

本文操作环境:Windows7系统、HTML5&&CSS3版,DELL G3电脑。

推荐:css视频教程

href和src的区别

一般加载CSS用href,并放在头部;加载script用src,放在body内的下方。

立即学习“前端免费学习笔记(深入)”;

href

是hypertext reference的缩写,表示超文本引用,用来建立当前元素和文档间的链接。常用的有link,a。

当CSS使用href引用,浏览器会识别该文档问CSS,并行下载,不会停止对当前文档的加载。

src

是source的缩写,是资源,页面必不可少的一部分,src指向的内容会嵌入到文档中当前标签的位置。常用的有img, script, iframe。

当script使用src引用,浏览器解析到该元素时会停止对文档的渲染,直到该资源加载完成。这也是将script放底部而不是头部的原因。

把CSS放头部,script放下方的原因

1、CSS放头部

在加载html生成DOM tree的时候,就可以同时对DOM tree进行渲染。

这样可以防止闪跳,白屏或者布局混乱。

2、javascript放在后面

javascript可能会改变DOM tree的结构,所以需要一个稳定的DOM tree。

javascript加载后会立即执行,同时会阻塞后面的资源加载。(javascript加载和执行的特点)

拓展知识:

1、首先让我们先认识几个常见的问题:

1.在进行页面优化的时候,需要将css放在头部,将js文件放在尾部,这样做为什么能够实现页面的优化?

2.在使用jquery的时候,为什么把函数写在$(document).ready()事件中?

3.javascript会阻塞dom的解析。

当解析过程中遇到标签的时候,便会停止解析过程,转而去处理脚本,

如果脚本是内联的,浏览器会先去执行这段内联的脚本,

如果是外链的,那么先会去加载脚本,然后执行。

在处理完脚本之后,浏览器便继续解析HTML文档。

2.DOMContentLoaded函数和load函数解析

1.DOMContentLoaded事件其实就是dom内容加载完毕。

举个例子来说我们在打开一个网页的时候,

一开始页面是空白的,什么都看不到,一段事件之后页面展示出内容,但是还是有一些图片资源看不到,此时页面是可以进行正常的交互的,

再过一段时间之后,页面上所有的资源都加载完成,继而整个页面加载完成。

从页面空白到展示出页面内容的过程就会触发DOMContentLoaded事件,而这段事件就是HTML文档被加载和解析完成。

2.页面上所有的资源(图片,音频,视频等)被加载以后才会触发load事件,页面的load事件会在DOMContentLoaded被触发之后才触发。

3.关于jquery中的ready函数

jquery中的ready函数其实监听的DOMContentLoaded事件,

所以我们将函数写在ready函数中,可以在页面解析完成之后,

我们可以访问到页面所有的元素,缩短页面的交互时间,提高页面的整体体验

4.为什么将css放在头部,js放在尾部可以增加页面的性能

现在浏览器为了更好的用户体验,渲染引擎会尝试尽快在屏幕上显示内容,

它不会等到所有的HTMl元素解析之后在构建和布局dom树,所以部分内容将被解析并显示。

也就是说浏览器能够渲染不完整的dom树和cssom,尽快的减少白屏的时间。

假如我们将js放在header,js将阻塞解析dom,dom的内容会影响到dom树的绘制,导致dom绘制延后。

所以说我们会将js放在后面,以减少dom绘制的时间,但是不会减少DOMContentLoaded被触发的时间。

以上就是为什么css放上面js放下面的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1617578.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
css怎么让字体变细
上一篇 2025年12月24日 05:53:33
响应式布局有几种方法
下一篇 2025年12月24日 05:53:51

相关推荐

  • 自定义HTML视频控件:精确控制键盘快进/快退行为

    本教程详细讲解如何自定义HTML “ 元素的默认键盘控制行为,特别是左右箭头键的视频快进/快退步长。文章指出,仅使用 `event.preventDefault()` 不足以完全阻止浏览器默认行为,还需要结合 `event.stopPropagation()` 来确保自定义逻辑独立生效,从而实现精…

    2026年5月10日
    000
  • 用css解决标题显示字数超出省略号代替的方法

    标题字数超出场景: 最左边这栏我不行让他换行,怎么办呢? 步骤一:内容超出宽度时隐藏超出部分的内容 步骤二:当对象内文本溢出时显示省略标记(…) 立即学习“前端免费学习笔记(深入)”; 下面是解决办法: table{width:100px;table-layout:fixed;/* 只有…

    2026年5月10日
    000
  • 在HTML文件中嵌入Mermaid图表教程

    本教程详细介绍了如何在HTML文件中直接嵌入和渲染Mermaid图表。通过引入Mermaid CDN库并进行简单的初始化配置,用户可以轻松地在网页中展示流程图、时序图、甘特图等多种类型的图表,无需依赖外部工具或复杂的构建流程,实现图表内容的动态化与可视化。 引言:Mermaid图表与HTML集成 M…

    2026年5月10日
    100
  • 关于CSS选择器种类及使用介绍

    常用的有标签选择器、类选择器、ID选择器等等,其实还有很多,在接下来的文章中为大家详细介绍下这些选择器的种类及其使用 首先说主要都有哪些先择器 1.标签选择器(如:body,p,p,ul,li) 2.类选择器(如:class=”head”,class=”head_…

    用户投稿 2026年5月10日
    000
  • 学习 Django 时的关键主题

    1. Django 基础知识 项目结构:了解 Django 项目的基本结构(例如,settings.py、urls.py、wsgi.py)。应用程序:了解 Django 应用程序如何在项目中工作以及如何创建和管理它们。URL 和路由:定义 URL 模式并将它们链接到视图。视图:编写基于函数的视图(F…

    2026年5月10日
    100
  • Angular中如何通过点击区域外来隐藏组件内容?

    巧妙运用angular指令,轻松实现点击区域外隐藏组件 在Angular应用开发中,常遇到需要在点击组件外部区域时隐藏该组件的需求,例如点击下拉菜单外部关闭菜单。本文将介绍如何使用ng-click-outside指令优雅地解决此问题。 首先,你需要安装ng-click-outside依赖: npm …

    2026年5月10日
    000
  • GolangCookie与Session管理实践

    Golang通过net/http操作Cookie,结合Session实现用户状态管理;2. 推荐使用Redis存储Session,确保分布式环境一致性;3. 设置HttpOnly、Secure和SameSite属性增强安全性;4. 使用crypto/rand生成强随机Session ID并定期刷新有…

    2026年5月10日
    000
  • 如何在点击的Div中获取正确的ID

    本文旨在解决动态生成的HTML元素中,点击事件发生时,如何准确获取与该元素关联的ID值的问题。通过事件委托和DOM遍历,我们将提供一种可靠的方法,确保在复杂的动态环境中,始终能获取到正确的ID,避免因选择器错误而导致的数据获取错误。 在动态生成的HTML结构中,经常会遇到点击事件需要获取特定ID的情…

    2026年5月10日
    000
  • React组件跨域导出与样式封装指南

    本文详细阐述了如何将React组件及其样式安全地导出并嵌入到外部Web页面中,解决了传统方法中样式丢失和命名冲突的问题。通过利用Webpack进行样式内联打包以及CSS Modules实现样式隔离,确保组件在外部环境中保持其预期的视觉效果,同时避免对宿主页面的影响,提供了一套专业且高效的解决方案。 …

    2026年5月10日
    100
  • React组件间事件处理器与状态传递:从父组件到多级子组件的实践指南

    本文探讨在React中如何高效地将事件处理器或其产生的状态从父组件传递给子组件,特别是涉及多级嵌套的情况。文章将详细阐述直接传递事件处理函数和通过状态管理传递事件结果的两种核心模式,并提供清晰的代码示例与注意事项,帮助开发者构建响应式用户界面。 理解React组件通信基础:Props 在React中…

    2026年5月10日
    000
  • 如何使用 CSS 实现渐变边框并显示完整的边框效果?

    css 渐变边框的实现与显示效果 想要实现渐变边框,可以使用 border-image 属性。它可以设置边框图片,而渐变色可以通过 linear-gradient() 函数来定义。 示例代码: border-image: linear-gradient(rgba(255, 255, 255, 0.0…

    2026年5月10日
    000
  • 实现水平滚动文本的淡出效果

    实现水平滚动文本的淡出效果实现水平滚动文本的淡出效果实现水平滚动文本的淡出效果实现水平滚动文本的淡出效果

    本文将介绍如何使用 CSS 实现水平滚动文本的淡出效果,尤其是在非均匀背景下,传统线性渐变方案不适用的情况下。我们将通过结合 linear-gradient 和 background-clip 属性,创建一个在水平滚动时两侧逐渐淡出的文本效果。 实现原理 核心思路是利用 CSS 的 linear-g…

    2026年5月10日 用户投稿
    200
  • Golang包导入路径与命名规范示例

    Go语言中,包导入路径应遵循模块化标准,如标准库直接引用、第三方包用完整路径、内部包通过internal目录隔离;包名需简洁小写且与目录一致,避免模糊命名,推荐语义明确的名称,并在必要时使用别名提升可读性。 在Go语言开发中,包的导入路径和命名直接影响代码的可读性与维护性。合理的规范能让团队协作更顺…

    2026年5月10日
    000
  • CSS打字机效果:完成打字后停止光标闪烁的实现教程

    本教程旨在解决css打字机效果中光标持续闪烁的问题。通过调整css动画的animation-delay和animation-iteration-count属性,可以实现在文本内容完全显示后,让打字光标停止闪烁并最终消失,从而提供一个更自然、完整的动画体验。 在网页开发中,CSS打字机效果是一种常见的…

    2026年5月10日
    000
  • JavaScript定时器实现多图片同步切换教程

    本教程详细讲解如何利用JavaScript的setInterval函数,实现网页中多张图片(如背景图、号召性用语图和顶部图)的同步循环切换。通过维护一个共享的索引,确保所有图片在预设的时间间隔内,按照各自的图片序列同时更新,从而创建流畅且一致的视觉动态效果。 引言 在网页设计中,动态视觉效果能够极大…

    2026年5月10日
    000
  • 掌握CSS层叠上下文:将下拉菜单叠加在地图之上

    本文将深入探讨如何利用css的position和z-index属性,解决将下拉菜单等交互元素精确叠加在全屏背景元素(如地图)上方的问题。通过调整元素的定位方式和层叠顺序,确保下拉菜单在视觉上处于地图之上,实现更灵活和用户友好的界面布局。 在现代网页设计中,将交互式UI元素(如下拉菜单、模态框)叠加在…

    2026年5月10日
    200
  • html5怎么设置框架_html5用iframe或frameset标签嵌入子页面框架【设置】

    HTML5中仅支持iframe嵌入网页内容,需设置src、title属性,用CSS实现响应式布局,通过sandbox增强安全性,以Grid/Flexbox替代frameset,并处理加载失败与跨域问题。 如果您希望在HTML5页面中嵌入其他网页内容,需注意HTML5已废弃frameset和frame…

    2026年5月10日
    000
  • Materialize 折叠面板头部颜色动态修改:基于下拉选择的实现

    本教程旨在解决 Materialize CSS 框架中,根据下拉菜单的选择动态改变折叠面板头部文本颜色的问题。文章将深入探讨在存在嵌套元素及 CSS 特异性影响下,如何精准定位并修改目标元素的样式,提供详细的 JavaScript、HTML 和 CSS 代码示例,确保开发者能够成功实现交互式 UI …

    2026年5月10日
    000
  • Vue 3项目中图像资源的集成与SVG组件化实践

    本教程旨在详细阐述在Vue 3项目中集成和使用图像资源的多种策略,尤其聚焦于SVG图像的特殊处理。我们将涵盖传统的标签加载、CSS background-image应用,并针对Vue 3环境下SVG作为可控组件的导入与使用提供一套清晰的解决方案,强调如何规避旧版加载器不兼容问题,确保SVG资源的正确…

    2026年5月10日
    000
  • php代码如何实现数据统计_php代码制作报表分析的方法

    使用PHP结合数据库查询与逻辑处理可实现数据统计分析及报表展示。首先通过SQL聚合函数在数据库层面处理数据,利用PDO连接MySQL执行如按日统计订单的查询,并将结果用PHP存储为数组,最终渲染至HTML表格呈现基础报表。其次借助PHPOffice/PhpSpreadsheet类库,经Compose…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信