发布日期:2024-03-11 来源: 网络 阅读量()
你有哪些性能优化的方法? ? (1) 减少http请求次数:CSS Sprites, JS、CSS源码压缩、图片大小控制合适;网页Gzip,CDN托管,data缓存,图片服务器。 ? ? (2) 前端模板 JS+数据,减少由于HTML标签导致的带宽浪费,前端用变量保存AJAX请求结果,每次操作本地变量,不用请求,减少请求次数 ? ? (3) 用innerHTML代替DOM操作,减少DOM操作次数,优化javascript性能。 ? ? (4) 当需要设置的样式很多时设置className而不是直接操作style。 ? ? (5) 少用全局变量、缓存DOM节点查找的结果。减少IO读取操作。 ? ? (6) 避免使用CSS Expression(css表达式)又称Dynamicproperties(动态属性)。 ? ? (7) 图片预加载,将样式表放在顶部,将脚本放在底部? 加上时间戳。 一个页面从输入 URL 到页面加载显示完成,这个过程中都发生了什么? ? 分为4个步骤: ? (1),当发送一个URL请求时,不管这个URL是Web页面的URL还是Web页面上每个资源的URL,浏览器都会开启一个线程来处理这个请求,同时在远程DNS服务器上启动一个DNS查询。这能使浏览器获得请求对应的IP地址。 ? (2), 浏览器与远程Web服务器通过TCP三次握手协商来建立一个TCP/IP连接。该握手包括一个同步报文,一个同步-应答报文和一个应答报文,这三个报文在 浏览器和服务器之间传递。该握手首先由客户端尝试建立起通信,而后服务器应答并接受客户端的请求,最后由客户端发出该请求已经被接受的报文。 ? (3),一旦TCP/IP连接建立,浏览器会通过该连接向远程服务器发送HTTP的GET请求。远程服务器找到资源并使用HTTP响应返回该资源,值为200的HTTP响应状态表示一个正确的响应。 ? (4),此时,Web服务器提供资源服务,客户端开始下载资源。 ? 请求返回后,便进入了我们关注的前端模块 简单来说,浏览器会解析HTML生成DOM Tree,其次会根据CSS生成CSS Rule Tree,而javascript又可以根据DOM API操作DOM 平时如何管理你的项目? 先期团队必须确定好全局样式(globe.css),编码模式(utf-8)等; ? ? 编写习惯必须一致(例如都是采用继承式的写法,单样式都写成一行); ? ? 标注样式编写人,各模块都及时标注(标注关键样式调用的地方); ? ? 页面进行标注(例如 页面 模块 开始和结束); ? ? CSS跟HTML 分文件夹并行存放,命名都得统一(例如style.css); ? ? JS 分文件夹存放 命名以该JS功能为准的英文翻译。 ? ? 图片采用整合的 images.png png8 格式文件使用 尽量整合在一起使用方便将来的管理 说说最近最流行的一些东西吧?常去哪些网站? Node.js、Mongodb、npm、MVVM、MEAN、three.js,React 。 网站:w3cfuns,sf,hacknews,CSDN,慕课,博客园,InfoQ,w3cplus等