2025前端面试-性能优化(HTML与CSS)---003

1.什么是SEO

  • 定义 :Serach Engine Optimization
  • 涉及到的使用: 门户网站或者功能网站(搜索引擎展示的先后顺序,推广 如搜索pdf转化器搜索之后,同质化显示出来的内容先后会决定网站的点击量)

2. SEO有哪些关键点

(从重要到次要依次回答)

1.SSR服务端渲染

2.TDK描述 (title description keywords 标题,描述,关键词)

3.语义化的HTML元素(Header,Nav,Aside,Ariticle,Footer),图片alt,h1,h2的合理使用,

4.编写合理的robots.txt文件

  • 是一个存放在网页根目录中的文本文件(告诉搜索引擎爬虫哪些部分的网页可以被抓取以及哪些不可以

  • 通过指示搜索引擎忽略掉不重要的文件或目录,可以让搜索引擎专注于重要内容的抓取和索引

  • 可以避免一些敏感私有信息不会被无意中索引

  • 如果没有这个文件,可能会降低网站的SEO效率,会让搜索引擎花费更多时间在不重要页面上

5.HTTPS (Google自2014年以来已将HTTPS作为其搜索排名的信号之一,另一个方面更安全

6.内部链接(同一个网站下不同页面)和外部链接(不同网站)

7.sitmap文件,网站导航,响应式处理,都在某种程度上提高网站的权限

8.SEO专员

3. defer和async属性在script标签中分别有什么作用

这两个属性都是用来控制外部脚本文件加载和执行方式的 可以帮助改善页面加载速度

两者之间机制不同,并且应用场景页不同

async通常用于独立的脚本,对于其他脚本甚至DOM没有依赖的脚本(因为这个async属性控制的脚本执行会涉及到影响DOM树的构建)

defert通常用于需要在文档解析之后操作DOM的JS代码,并且会对多个sript文件有顺序要求

现代框架中webpac或者vite会帮助配置 不需要手动配置

  • 浏览器 解析页面 时,遇到script元素停止DOM树的构建,首先把js代码下载并执行,这个过程中会阻塞DOM树的渲染

  • 只有等到JS脚本执 行结束之后才会继续解析执行HTML构建DOM树

    • 为什么?
      1. JS本身可以操作DOM树 ,如果是等到DOM树构建完成并且渲染完成之后操作DOM会出现重绘回流,对于性能消耗会很大
    • 问题:
      1. 现代框架开发中 生成的脚本文件会很大
  • defer 属性告诉浏览器先继续解析HTML,构建DOM Tree 不要等待脚本下载

    • 脚本会由浏览器来进行下载,不会阻塞DOM Tree的构建过程
    • 当脚本提前下载好之后,会等待DOM Tree构建完成,在DOMContentLoaded事件之前先执行defer中的代码
    • (并且多个defer可以保证先后顺序 ,推荐放到head中去
  • Async 属性

    • 下载完成之后就马上执行脚本,不会等待是否已经构建好DOMTree (执行时会阻塞DOM Tree的构建)
    • 并且async脚本是独立的 不会等待其他的脚本执行

4.CSS3 引入的一些主要新特性

5.为什么在移动端使用@2x,@3x的图片(移动端适配

  1. 在移动端设备中,有非常多高分辨率的设备,为了适应不同的像素密度,UI通常会给开发者提供多个版本的图像资源
    1. @1@2 @3 (低中高分辨率)
相关推荐
强强学习1 小时前
HTML5 起步
前端·html·html5
念九_ysl3 小时前
前端循环全解析:JS/ES/TS 循环写法与实战示例
前端·javascript·typescript
招风的黑耳4 小时前
使用Nginx本地部署Axure生成的HTML文件,局域网内浏览器通过IP和地址访问
nginx·html·axure·本地部署
anyup_前端梦工厂5 小时前
了解几个 HTML 标签属性,实现优化页面加载性能
前端·html
前端御书房5 小时前
前端PDF转图片技术调研实战指南:从踩坑到高可用方案的深度解析
前端·javascript
2301_789169545 小时前
angular中使用animation.css实现翻转展示卡片正反两面效果
前端·css·angular.js
风口上的猪20157 小时前
thingboard告警信息格式美化
java·服务器·前端
程序员黄同学7 小时前
请谈谈 Vue 中的响应式原理,如何实现?
前端·javascript·vue.js
爱编程的小庄7 小时前
web网络安全:SQL 注入攻击
前端·sql·web安全
宁波阿成8 小时前
vue3里组件的v-model:value与v-model的区别
前端·javascript·vue.js