IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 如何加快首屏渲染,一秒后执行变两秒后执行、链式调用、深度打印Dom节点tagName后端返回大数的解决方法 -> 正文阅读

[JavaScript知识库]如何加快首屏渲染,一秒后执行变两秒后执行、链式调用、深度打印Dom节点tagName后端返回大数的解决方法

白屏时浏览器在做什么?

解析 HTML、下载 CSS、下载 JavaScript、生成 CSSOM、执行 JavaScript、生成布局树、绘制页面一系列操作

1.影响首屏渲染的因素

请求资源过多、资源文件体积过大、脚本的加载和解析阻塞渲染

2.加快首屏渲染的方法

面试官:首屏加载速度慢怎么解决?_豆子前端的博客-CSDN博客_首屏加载慢

  • 减小入口文件体积
  • 静态资源本地缓存
  • UI框架按需加载
  • 图片资源的压缩
  • 图片懒加载、路由懒加载、组件懒加载
  • 组件重复打包
  • 开启GZip压缩
  • 使用SSR,在服务端渲染好一部分数据

settimeout(() => {console.log(1)},1000)怎么让1在2s后打印,不能直接修改时间?

    setTimeout(() => {
        setTimeout(() => {
            console.log(1)
        },1000)
    },1000)

链式调用?

function Man(){
    this.sleep=function(time){
        console.log("sleep",time)
        return this
    }
    this.sayHi=function(){
        console.log("sayHi")
        return this
    }
}
var a=new Man()
a.sleep(3000).sayHi().sleep(1000).sleep(2000).sayHi()

打印DOM文档的所有节点(深度)

function deep(tree){
    if(tree.tagName)console.log(tree.tagName)//换行、文字等也算孩子,所以要判断有没有tagName
    let arr=tree.childNodes
    arr.forEach(element => {
        deep(element)
    });
}
deep(document.body)

?后端返回大数的解决方法:

js能表示的最大安全整数是2^53-1

后端返回的数据是json字符串形式,前端如果直接JSON.parse()就会因为数据存储(IEEE 754:1+11+52)的原因导致精度丢失。前端通常先不进行转换,直接使用字符串,需要相应计算的时候先切分成安全的小数字,再进行计算,使用后进行拼接。

关于大整数处理的插件底层也是这样做的。

es6的大整数已经解决了这个问题

let objstr=JSON.stringify({
    "a":"1418036282449215489"
})
//如果直接存为数字的话,会变成 1418036282449215500
console.log(obj) //字符串:{"a":"1418036282449215489"}
let num=objstr.slice(6,objstr.length-2) 字符串:1418036282449215489
console.log(BigInt(num)) //数字 1418036282449215489n


console.log(BigInt(Math.pow(2,64))) //18446744073709551616n
console.log(Math.pow(2,64)) //18446744073709552000

正则

函数柯里化

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 23:16:14  更:2022-04-01 23:20:30 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:30:04-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码