- 前端技术分享:页面性能优化问题复盘
有道AI情报局
有道技术团队前端性能优化javascript
项目背景在code_pc项目中,前端需要使用rrweb对老师教学内容进行录制,学员可以进行录制回放。为减小录制文件体积,当前的录制策略是先录制一次全量快照,后续录制增量快照,录制阶段实际就是通过MutationObserver监听DOM元素变化,然后将一个个事件push到数组中。为了进行持久化存储,可以将录制数据压缩后序列化为JSON文件。老师会将JSON文件放入课件包中,打成压缩包上传到教务系统
- 一道经典的异步试题
华子Code1024
javascript前端面试
JavaScript任务可以分为同步任务和异步任务异步任务:微任务和宏任务微任务:Promise回调:当一个异步操作通过`newPromise`函数执行并返回后,可以注册一个回调函数以在异步操作完成时被调用。Node.js中process.nextTick:这是一个在Node.js中用于运行微任务的机制。MutationObserver对DOM变更的监听:这个API可以用来监听文档中元素的属性或子
- 微任务与宏任务
风与烈酒
前端
微任务和宏任务都是JavaScript中的任务队列,用于处理异步代码。微任务是指在当前任务执行完成后立即执行的任务。常见的微任务包括Promise的回调函数、MutationObserver的回调函数等。微任务会在浏览器的重绘前执行。宏任务是指需要在当前任务队列执行完毕后再执行的任务。常见的宏任务包括setTimeout、setInterval、I/O操作等。宏任务会在浏览器的重绘前执行。在Jav
- 监听项目中指定属性数据,点击或模块显示时
闲来无事垂钓
javascript学习笔记前端javascriptobserve
当项目中,需要获取某个页面上、某个标签上、有指定自定义属性时,需要在点击该元素时进行公共逻辑处理,或该元素在显示的时候进行逻辑处理,这时可以定义一个公共的方法,在每个页面引用,并写入数据即可(通过IntersectionObserver监听页面元素是否显示,MutationObserver监听DOM元素等实现)效果图找到页面中标签含有自定义属性sen-trace="tracesen_bi"获取到s
- ywl-watermark-vue基于vue指令实现水印功能(vue2/vue3),防止手动删除水印
打响第一枪
vue.js前端javascript
在开发vue项目中,可能会根据项目的需求对页面添加水印效果,下面将介绍一种基于vue指令而实现水印的方法(通用于vue2和vue3),利用MutationObserver监控水印DOM发生变化时,重新渲染水印,防止用户从DOM中直接删除水印。一、vue指令ywl-watermark-vuehttps://www.npmjs.com/package/ywl-watermark-vue二、安装使用np
- Promise的几道基础题
已注 销
前端
eventloop它的执行顺序:一开始整个脚本作为一个宏任务执行执行过程中同步代码直接执行,宏任务进入宏任务队列,微任务进入微任务队列当前宏任务执行完出队,检查微任务列表,有则依次执行,直到全部执行完执行浏览器UI线程的渲染工作检查是否有WebWorker任务,有则执行执行完本轮的宏任务,回到2,依此循环,直到宏任务和微任务队列都为空微任务包括:MutationObserver、Promise.t
- JavaScript中最重要的5个Observer,看这一篇就够了
秋名山大前端
javascript前端
MutationObserver简介:MutationObserver用于监听DOM对象的变更,包括节点属性的变化、子节点的增删改等。提供了方便的方式监听DOM变化。API介绍:MutationObserver(callback):创建新的实例,传入变动时的回调函数。observe(target,config):开始观察指定目标节点,传入目标节点和配置对象。disconnect():停止观察,断开
- Promise面试题合集(问题+答案)
已注 销
面试前端
eventloop它的执行顺序:一开始整个脚本作为一个宏任务执行执行过程中同步代码直接执行,宏任务进入宏任务队列,微任务进入微任务队列当前宏任务执行完出队,检查微任务列表,有则依次执行,直到全部执行完执行浏览器UI线程的渲染工作检查是否有WebWorker任务,有则执行执行完本轮的宏任务,回到2,依此循环,直到宏任务和微任务队列都为空微任务包括:MutationObserver、Promise.t
- Vue.nextTick
你看这个L好帅
思考什么是nextTick?为什么要用它?什么是nextTick?vue官方给出的:在下一次DOM更新循环结束之后的延迟回调。再修改数据之后立即使用这个方法,获取更新过后的DOM首先了解一下JS的运行机制补充MutationObserver(MutationObserver是HTML5新增的属性,用于监听DOM修改事件,能够监听到节点的属性、文本内容、子节点等的改动,是一个功能强大的利器)为什么要
- 常用API
kjl536566
杂记javascript
IntersectionObserver交叉观察主要侦听元素是否在视口内MutationObserver主要侦听子集的变化还要属性的变化以及增删改查ResizeObserver主要侦听元素的变化(宽高..)以及增删改查
- React中使用window.MutationObserver监听Demo变化处理
懒惰的狮子
constcontainerRef:any=useRef(null)constmutationObserver=()=>{letMutationObserver=window.MutationObserverconstoptions={//配置参数attributes:true,//属性的变动characterData:true,//节点内容或节点文本的变动subtree:true//布尔值,表示
- MutationObserver详解
小蛮牧码者
jsjavascript前端开发语言
MutationObserver用来监视DOM变动。DOM的任何变动,比如节点的增减、属性的变动、文本内容的变动都会触发MutationObserver事件。但是,它与事件有一个本质不同:事件是同步触发,也就是说,DOM的变动立刻会触发相应的事件;MutationObserver则是异步触发,DOM的变动并不会马上触发,而是要等到当前所有DOM操作都结束才触发。MutationObserver有以
- 一文带你彻底掌握前端必问面试题之宏任务和微任务
ATalk机器人
javascript
宏任务和微任务是JavaScript中的两种任务调度机制。宏任务(macrotask)是指由浏览器提供的任务队列中的任务,例如script标签中的代码、setTimeout、setInterval、I/O操作等。宏任务会在当前执行栈执行完毕后执行。微任务(microtask)是指由JavaScript引擎提供的任务队列中的任务,例如Promise的回调函数、MutationObserver的回调函
- MutationObserver 监视 DOM 树改变的api
嘤嘤怪呆呆狗
jsjavascript前端html
1、介绍MutationObserver是一个构造函数,可以用来监听某个节点的变化,当节点发生变化时,可以执行一些回调函数。它不会立即执行,需要调用MutationObserver的observe方法,传入你想要监听的节点,以及一些配置,然后当节点发生变化时,就会执行你传入的回调函数。2、基本使用MutationObserver的构造函数的入参是数组MutationObserver的observe
- setTimeout、Promise、Async/Await 的区别
李小白呀
事件循环中分为宏任务队列和微任务队列宏任务(macrotask):在新标准中叫task主要包括:script(整体代码),setTimeout,setInterval,setImmediate,I/O,uirendering微任务(microtask):在新标准中叫jobs主要包括:process.nextTick,Promise,MutationObserver(html5新特性)setTime
- js监听div元素的宽高变化, window.onresize是监听浏览器窗口的变化
未来可期wlkq
javascript开发语言ecmascript
mounted(){letrecordExecutionsNum=0;letMutationObserver=window.MutationObserver||window.WebKitMutationObserver||window.MozMutationObserverletelement=document.getElementById('asset-list-search')this.obs
- 前端学习笔记--面试题系列总结
weixin_43209472
前端学习笔记前端学习笔记
eventloop它的执行顺序:一开始整个脚本作为一个宏任务执行执行过程中同步代码直接执行,宏任务进入宏任务队列,微任务进入微任务队列当前宏任务执行完出队,检查微任务列表,有则依次执行,直到全部执行完执行浏览器UI线程的渲染工作检查是否有WebWorker任务,有则执行执行完本轮的宏任务,回到2,依此循环,直到宏任务和微任务队列都为空微任务包括:MutationObserver、Promise.t
- 一篇文章理解Promise原理
Mr.怪兽
ui前端javascriptes6
前提掌握知识:微任务包括:MutationObserver、Promise.then()或reject()、Promise为基础开发的其它技术,比如fetchAPI、V8的垃圾回收过程、Node独有的process.nextTick。宏任务包括:script、setTimeout、setInterval、setImmediate、I/O、UIrendering。javascript中事件循环(ev
- MutationObserver详解
Mr_linjw
前端javascripthtml5
MutationObserverAPI让我们能监听DOM树变化,该API设计用来替换掉在DOM3事件规范中引入的Mutationevents。Mutationevents是同步触发的,每次变动都会触发一次调用。MutationObserverAPI是异步触发的,DOM的变动并不会马上触发,而是要等到当前所有DOM操作都结束才触发。所以MutationObserver相比Mutationevents
- javascript 宏任务与微任务
平安2020
1.由宿主环境发起的称为宏观任务2.由javascript引擎发起的称为微观任务事件循环宏观任务有:浏览器nodesetTimeout✔️✔️setInterval✔️✔️setImmediate✘✔️requestAnimationFrame✔️✘微观任务有:浏览器nodeprocess.nextTick✘✔️MutationObserver✔️✘Promise✔️✔️setTimeout(()
- 微任务创建 -- queueMicrotask()
willwe
javascript
微任务创建方式:Promise.then(()=>{})MutationObserver()queueMicrotask()本文主要介绍queueMicrotask()的使用。queueMicrotask的使用Window或Worker接口的queueMicrotask()方法,将微任务加入队列以在控制返回浏览器的事件循环之前的安全时间执行。语法:queueMicrotask(()=>{/*…*/
- 监听DOM尺寸变化 - ResizeObserver
莫道 开发
前端javascript开发语言ecmascript
一、与MutationObserverApi的区别MutationObserver主要用来监听DOM元素的属性和节点变化的,非DOM样式尺寸,可查看之前一篇blog-DOM规范-MutationObserver接口观察DOM元素的属性和节点变化ResizeObserver主要用来监听DOM元素的内容区域的尺寸变化,可以监听到Element的内容区域或SVGElement的边界框改变二、用法1.构造
- JS手写Promise 包含实例方法(catch,finally)和静态方法(resolve,reject,race,all,allSetted,any)
、信仰_
javascript前端开发语言
//异步执行使用三种异步解决方案queueMicrotask/MutationObserver/setTimeout由于前面两种低版本浏览器不支持用setTimeout兜底functionrunAsynctask(callback){//如果当前浏览器支持queueMicortask那么queueMicrotask==='function'成立直接使用queueMicortask处理异步if(ty
- 宏队列与微队列
海之深处爱之港湾
一、原理图image.png二、定义说明JS中用来存储待执行回调函数的队列包含2个不同特定的列队宏列队:用来保存待执行的宏任务(回调),比如:定时器回调、DOM事件回调、ajax回调微列队:用来保存待执行的微任务(回调),比如:promise的回调、MutationObserver的回调JS引擎首先必须先执行所有的初始化同步任务代码每次准备取出第一个宏任务执行前,都要将所有的微任务一个一个取出来执
- 前端JavaScript中MutationObserver:监测DOM变化的强大工具
岸边的风
javaScript前端ES6javascript开发语言ecmascript
岸边的风:个人主页个人专栏:《VUE》《javaScript》⛺️生活的理想,就是为了理想的生活!目录引言1.MutationObserver简介2.MutationObserver的属性3.MutationObserver的应用场景3.1动态内容加载3.2表单验证3.响应式布局3.4自定义组件开发4.使用MutationObserver的示例4.1监测元素属性变化4.2监测子元素的添加或移除4.
- React(React Hook)+Typescript 监听dom元素变化
nomooo
主要用到的js技术部分:MutationObserver接口提供了监视对DOM树所做更改的能力。它被设计为旧的MutationEvents功能的替代品,该功能是DOM3Events规范的一部分。tsx部分:使用了Reacthook的函数,详情见https://zh-hans.reactjs.org/docs/hooks-reference.htmlimportReact,{useEffect,us
- JavaScript 操作DOM元素及DOM元素相关属性
i小杨
javascript开发语言ecmascript
js动态监听dom元素的高度变化.相关文章参考文章@ALISONLY参考文章@盏茶作酒kk相关知识window.onsize=function(){}缺点:只能监听视口的变化不能监听dom元素的变化.MutationObserver优点:MutationObserver可以用来监听整个DOM中的变化。ResizeObserver缺点:兼容性不好。exportdefault{methods:{han
- DOM 监测
逛街的猫啊
DOM监测变化
如何定义DOM监测:新加DOMDOM属性变更移除DOM通常有两种方式,早期使用DOM事件监听节点的变化,目前已不再推荐。当前推荐使用MutationObserver。一、DOM事件事件作用注意事项DOMNodeInsertedIntoDocument用于检测节点的插入当Node被插入到Document时,才会触发此事件DOMNodeInserted用于检测节点的插入当Node被插入到Documen
- Antd面包屑,超出宽度省略号
ATWLee
React技术栈相关JSAntDesign前端javascriptreact.jsantd
业务需求:面包屑超出宽度,左侧出现省略号。实现效果实现原理先调整面包屑样式,使其弹性布局不换行给面包屑外面盒子一个ref,面包屑同级有个隐藏的span,内容是…省略号通过MutationObserver监听这个盒子的内容改变当内容超出盒子宽度之后,打开省略号,并修改弹性布局主轴从行尾开始核心代码MutationObserver对象监听dom元素内容MutationObserver代码import{
- 【JavaScript】MutationObserver的简易封装
陀螺蚁
Web前端javascript前端vue.js
MutationObserver是JS的API,可以用于观察文档中的DOM树变化,并在这些变化发生时执行特定的回调函数。使用//选择需要观察变动的节点consttargetNode=document.getElementById("some-id");//观察器的配置(需要观察什么变动)constconfig={attributes:true,childList:true,subtree:true
- scala的option和some
矮蛋蛋
编程scala
原文地址:
http://blog.sina.com.cn/s/blog_68af3f090100qkt8.html
对于学习 Scala 的 Java™ 开发人员来说,对象是一个比较自然、简单的入口点。在 本系列 前几期文章中,我介绍了 Scala 中一些面向对象的编程方法,这些方法实际上与 Java 编程的区别不是很大。我还向您展示了 Scala 如何重新应用传统的面向对象概念,找到其缺点
- NullPointerException
Cb123456
androidBaseAdapter
java.lang.NullPointerException: Attempt to invoke virtual method 'int android.view.View.getImportantForAccessibility()' on a null object reference
出现以上异常.然后就在baidu上
- PHP使用文件和目录
天子之骄
php文件和目录读取和写入php验证文件php锁定文件
PHP使用文件和目录
1.使用include()包含文件
(1):使用include()从一个被包含文档返回一个值
(2):在控制结构中使用include()
include_once()函数需要一个包含文件的路径,此外,第一次调用它的情况和include()一样,如果在脚本执行中再次对同一个文件调用,那么这个文件不会再次包含。
在php.ini文件中设置
- SQL SELECT DISTINCT 语句
何必如此
sql
SELECT DISTINCT 语句用于返回唯一不同的值。
SQL SELECT DISTINCT 语句
在表中,一个列可能会包含多个重复值,有时您也许希望仅仅列出不同(distinct)的值。
DISTINCT 关键词用于返回唯一不同的值。
SQL SELECT DISTINCT 语法
SELECT DISTINCT column_name,column_name
F
- java冒泡排序
3213213333332132
java冒泡排序
package com.algorithm;
/**
* @Description 冒泡
* @author FuJianyong
* 2015-1-22上午09:58:39
*/
public class MaoPao {
public static void main(String[] args) {
int[] mao = {17,50,26,18,9,10
- struts2.18 +json,struts2-json-plugin-2.1.8.1.jar配置及问题!
7454103
DAOspringAjaxjsonqq
struts2.18 出来有段时间了! (貌似是 稳定版)
闲时研究下下! 貌似 sruts2 搭配 json 做 ajax 很吃香!
实践了下下! 不当之处请绕过! 呵呵
网上一大堆 struts2+json 不过大多的json 插件 都是 jsonplugin.34.jar
strut
- struts2 数据标签说明
darkranger
jspbeanstrutsservletScheme
数据标签主要用于提供各种数据访问相关的功能,包括显示一个Action里的属性,以及生成国际化输出等功能
数据标签主要包括:
action :该标签用于在JSP页面中直接调用一个Action,通过指定executeResult参数,还可将该Action的处理结果包含到本页面来。
bean :该标签用于创建一个javabean实例。如果指定了id属性,则可以将创建的javabean实例放入Sta
- 链表.简单的链表节点构建
aijuans
编程技巧
/*编程环境WIN-TC*/ #include "stdio.h" #include "conio.h"
#define NODE(name, key_word, help) \ Node name[1]={{NULL, NULL, NULL, key_word, help}}
typedef struct node { &nbs
- tomcat下jndi的三种配置方式
avords
tomcat
jndi(Java Naming and Directory Interface,Java命名和目录接口)是一组在Java应用中访问命名和目录服务的API。命名服务将名称和对象联系起来,使得我们可以用名称
访问对象。目录服务是一种命名服务,在这种服务里,对象不但有名称,还有属性。
tomcat配置
- 关于敏捷的一些想法
houxinyou
敏捷
从网上看到这样一句话:“敏捷开发的最重要目标就是:满足用户多变的需求,说白了就是最大程度的让客户满意。”
感觉表达的不太清楚。
感觉容易被人误解的地方主要在“用户多变的需求”上。
第一种多变,实际上就是没有从根本上了解了用户的需求。用户的需求实际是稳定的,只是比较多,也比较混乱,用户一般只能了解自己的那一小部分,所以没有用户能清楚的表达出整体需求。而由于各种条件的,用户表达自己那一部分时也有
- 富养还是穷养,决定孩子的一生
bijian1013
教育人生
是什么决定孩子未来物质能否丰盛?为什么说寒门很难出贵子,三代才能出贵族?真的是父母必须有钱,才能大概率保证孩子未来富有吗?-----作者:@李雪爱与自由
事实并非由物质决定,而是由心灵决定。一朋友富有而且修养气质很好,兄弟姐妹也都如此。她的童年时代,物质上大家都很贫乏,但妈妈总是保持生活中的美感,时不时给孩子们带回一些美好小玩意,从来不对孩子传递生活艰辛、金钱来之不易、要懂得珍惜
- oracle 日期时间格式转化
征客丶
oracle
oracle 系统时间有 SYSDATE 与 SYSTIMESTAMP;
SYSDATE:不支持毫秒,取的是系统时间;
SYSTIMESTAMP:支持毫秒,日期,时间是给时区转换的,秒和毫秒是取的系统的。
日期转字符窜:
一、不取毫秒:
TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS')
简要说明,
YYYY 年
MM 月
- 【Scala六】分析Spark源代码总结的Scala语法四
bit1129
scala
1. apply语法
FileShuffleBlockManager中定义的类ShuffleFileGroup,定义:
private class ShuffleFileGroup(val shuffleId: Int, val fileId: Int, val files: Array[File]) {
...
def apply(bucketId
- Erlang中有意思的bug
bookjovi
erlang
代码中常有一些很搞笑的bug,如下面的一行代码被调用两次(Erlang beam)
commit f667e4a47b07b07ed035073b94d699ff5fe0ba9b
Author: Jovi Zhang <
[email protected]>
Date: Fri Dec 2 16:19:22 2011 +0100
erts:
- 移位打印10进制数转16进制-2008-08-18
ljy325
java基础
/**
* Description 移位打印10进制的16进制形式
* Creation Date 15-08-2008 9:00
* @author 卢俊宇
* @version 1.0
*
*/
public class PrintHex {
// 备选字符
static final char di
- 读《研磨设计模式》-代码笔记-组合模式
bylijinnan
java设计模式
声明: 本文只为方便我个人查阅和理解,详细的分析以及源代码请移步 原作者的博客http://chjavach.iteye.com/
import java.util.ArrayList;
import java.util.List;
abstract class Component {
public abstract void printStruct(Str
- 利用cmd命令将.class文件打包成jar
chenyu19891124
cmdjar
cmd命令打jar是如下实现:
在运行里输入cmd,利用cmd命令进入到本地的工作盘符。(如我的是D盘下的文件有此路径 D:\workspace\prpall\WEB-INF\classes)
现在是想把D:\workspace\prpall\WEB-INF\classes路径下所有的文件打包成prpall.jar。然后继续如下操作:
cd D: 回车
cd workspace/prpal
- [原创]JWFD v0.96 工作流系统二次开发包 for Eclipse 简要说明
comsci
eclipse设计模式算法工作swing
JWFD v0.96 工作流系统二次开发包 for Eclipse 简要说明
&nb
- SecureCRT右键粘贴的设置
daizj
secureCRT右键粘贴
一般都习惯鼠标右键自动粘贴的功能,对于SecureCRT6.7.5 ,这个功能也已经是默认配置了。
老版本的SecureCRT其实也有这个功能,只是不是默认设置,很多人不知道罢了。
菜单:
Options->Global Options ...->Terminal
右边有个Mouse的选项块。
Copy on Select
Paste on Right/Middle
- Linux 软链接和硬链接
dongwei_6688
linux
1.Linux链接概念Linux链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link)。默认情况下,ln命令产生硬链接。
【硬连接】硬连接指通过索引节点来进行连接。在Linux的文件系统中,保存在磁盘分区中的文件不管是什么类型都给它分配一个编号,称为索引节点号(Inode Index)。在Linux中,多个文件名指向同一索引节点是存在的。一般这种连
- DIV底部自适应
dcj3sjt126com
JavaScript
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml&q
- Centos6.5使用yum安装mysql——快速上手必备
dcj3sjt126com
mysql
第1步、yum安装mysql
[root@stonex ~]# yum -y install mysql-server
安装结果:
Installed:
mysql-server.x86_64 0:5.1.73-3.el6_5 &nb
- 如何调试JDK源码
frank1234
jdk
相信各位小伙伴们跟我一样,想通过JDK源码来学习Java,比如collections包,java.util.concurrent包。
可惜的是sun提供的jdk并不能查看运行中的局部变量,需要重新编译一下rt.jar。
下面是编译jdk的具体步骤:
1.把C:\java\jdk1.6.0_26\sr
- Maximal Rectangle
hcx2013
max
Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing all ones and return its area.
public class Solution {
public int maximalRectangle(char[][] matrix)
- Spring MVC测试框架详解——服务端测试
jinnianshilongnian
spring mvc test
随着RESTful Web Service的流行,测试对外的Service是否满足期望也变的必要的。从Spring 3.2开始Spring了Spring Web测试框架,如果版本低于3.2,请使用spring-test-mvc项目(合并到spring3.2中了)。
Spring MVC测试框架提供了对服务器端和客户端(基于RestTemplate的客户端)提供了支持。
&nbs
- Linux64位操作系统(CentOS6.6)上如何编译hadoop2.4.0
liyong0802
hadoop
一、准备编译软件
1.在官网下载jdk1.7、maven3.2.1、ant1.9.4,解压设置好环境变量就可以用。
环境变量设置如下:
(1)执行vim /etc/profile
(2)在文件尾部加入:
export JAVA_HOME=/home/spark/jdk1.7
export MAVEN_HOME=/ho
- StatusBar 字体白色
pangyulei
status
[[UIApplication sharedApplication] setStatusBarStyle:UIStatusBarStyleLightContent];
/*you'll also need to set UIViewControllerBasedStatusBarAppearance to NO in the plist file if you use this method
- 如何分析Java虚拟机死锁
sesame
javathreadoracle虚拟机jdbc
英文资料:
Thread Dump and Concurrency Locks
Thread dumps are very useful for diagnosing synchronization related problems such as deadlocks on object monitors. Ctrl-\ on Solaris/Linux or Ctrl-B
- 位运算简介及实用技巧(一):基础篇
tw_wangzhengquan
位运算
http://www.matrix67.com/blog/archives/263
去年年底写的关于位运算的日志是这个Blog里少数大受欢迎的文章之一,很多人都希望我能不断完善那篇文章。后来我看到了不少其它的资料,学习到了更多关于位运算的知识,有了重新整理位运算技巧的想法。从今天起我就开始写这一系列位运算讲解文章,与其说是原来那篇文章的follow-up,不如说是一个r
- jsearch的索引文件结构
yangshangchuan
搜索引擎jsearch全文检索信息检索word分词
jsearch是一个高性能的全文检索工具包,基于倒排索引,基于java8,类似于lucene,但更轻量级。
jsearch的索引文件结构定义如下:
1、一个词的索引由=分割的三部分组成: 第一部分是词 第二部分是这个词在多少