流是一种处理读写文件、网络通信或任何端到端信息交换的有效方式。 流的独特之处在于,它不像传统的程序那样一次将一个文件读入内存,而是逐块读取数据、处理其内容,而不是将其全部保存在内存中。...这使得流在处理大量数据时非常强大,例如,文件可能大于你的空闲内存,不可能将整个文件读入内存来处理,这时候流就发挥作用了。...例如fs.createWriteStream() 可以使用流将数据写入文件。 可读流: 可读取数据的流。例如fs.createReadStream() 可以从文件读取内容。...双工流: 既可读又可写的流。例如 net.Socket。 转换流: 可以在数据写入和读取时修改或转换数据的流。例如,在文件压缩操作中,可以向文件写入压缩数据,并从文件中读取解压数据。...如果你用过 Node.js,可能已经遇到过流了。例如,在基于 Node.js 的 HTTP 服务器中,request 是可读流,response 是可写流。还有fs 模块,能同时处理可读和可写文件流。
想要知道这些事件是在什么时候进行调用的,就需要了解一下“事件流”的概念。 事件流 事件流描述的就是从页面中接收事件的顺序。...而早期的IE和Netscape提出了完全相反的事件流概念,IE事件流是事件冒泡,而Netscape的事件流就是事件捕获。...DOM2级事件规定的事件流包括三个阶段: + 事件捕获阶段 + 处于目标阶段 + 事件冒泡阶段 注意:warning::先捕获后冒泡,但是在目标节点上谁写在前面谁先执行。...绑定方式有如下两种 行内绑定(内联模型): 通过在JS中选中某个节点,然后给节点添加onclick属性 "btnClick()">按钮 function btnClick(){...console.log("hello"); } script> 复制代码 动态脚本: 通过在JS中选中某个节点,然后给节点添加onclick属性 "btn">按钮 var btn =
1.事件流 事件发生时会在元素节点与根节点之间按照特定的顺序传播,路径所经过的所有节点都会收到该事件,这个传播过程即DOM事件流。...2.两种事件流模型 1.冒泡型事件流:事件的传播是从最特定的事件目标到最不特定的事件目标。即从DOM树的叶子到根 2.捕获型事件流:事件的传播是从最不特定的事件目标到最特定的事件目标。
模板的制作一般都需要设计师先在Photoshop等软件中制作好设计好,然后再一定的方式来还原设计稿,要么需要编码要么需要在某些应用中按照设计稿重画设计生成模板数据,都还是比较麻烦的,我们能不能通过psd文件直接生成模板呢...要做到这点我们就需要解析psd文件,而psd文件是Photoshop软件的涉及保存文件,浏览器并不能直接识别,所幸的是psd.js赋予了我们这样的能力。...foxpsd是一个用来解析PhotoShop的PSD文件的 JavaScript 库,支持在浏览器上运行以及Node.js环境中使用,通过psd.js我们可以处理PSD文档并得到关键数据,例如: 1、文件结构...2、文件大小 3、图层/目录大小+定位 4、图层/目录名 5、图层/目录可见性和不透明度 6、字体数据 7、文本内容 8、字体种类,大小,颜色 9、颜色模式和相应数值 10、矢量蒙版数据 11、平面图像数据...12、图层组合 一、服务端使用 1、安装 PSD.js没有原生依赖项,我们可以通过npm install psd –save来安装psd.js并将其加入到我们的项目依赖中。
写在书上 保存下来防止丢失 image.png image.png image.png image.png image.png image.png image....
事件流 事件流需要从事件讲起。 JavaScript 与 HTML 之间的交互是通过事件实现的。 “事件就是文档或者浏览器窗口中发生的一些特定的交互瞬间。...而事件流描述的是从页面接收事件的顺序。 有意思的是,当时不同的开发团队对于事件流提出了完全相反的概念,主要分为IE事件流——冒泡,Netscape Communicator事件流——捕获。 1....DOM事件流 在 DOM 事件流中,实际目标(div)在捕获阶段不会接收到事件,意味着在捕获阶段事件从 document 到 html 再到 body 就会停止。...输出结果 可是,当我们将子级的冒泡和捕获在js中位置调换后,输出的则是……子级先冒泡,再捕获!如下: ? 输出结果2 这是什么原因呢?? 下期——事件处理顺序,进一步揭晓。...点击下面链接 查看历史文章 git 基础操作 js处理微信分享配置 小程序生命周期
1、前言: 新接手一个老项目,需要改造pdf文件的预览效果,接口直接返回的pdf文件的文件流base64字符串,前端只能拿到base64来进行预览。...pdf.js是一款非常优秀的pdf解析工具,但不支持直接预览文件流,这里需要对pdf.js稍微改造。...,放在webapp下面,我把下载以后的文件解压重新命名为pdfjs文件夹,如图 3、保存pdf文件流 我这里是一个接口返回包括内容详情,图片,pdf文件等所有内容,点击一条pdf记录,跳转打开新的标签页进行预览...因此把接口返回的pdf文件流base64编码先本地缓存.跳转到我们下载的pdf文件夹里面的【viewer.html】文件。...var rawLength = raw.length; //转换成pdf.js能直接解析的Uint8Array类型 var array = new Uint8Array(
在前一篇介绍ClassFileParser类时简单提了一下_stream属性,这个属性保存的是字节码文件流。...如果要读取Class文件的内容,首先需要获取文件对应的字节流,ClassFileStream 内部维护了一个buffer,该buffer指向Class文件所对应的字节流。...st.print_raw(h_name->as_utf8()); st.print_raw(".class"); const char* name = st.as_string(); // 通过st获取对应的文件名...= NULL) { break; } e = e->next(); } } ... } 遍历class_path找到要加载的类文件,获取到文件的绝对路径后就创建...这样就可以通过循环遍历链表上的结构,直到查找到某个路径下名称为name的文件为止,这时候open_stream()函数会返回ClassFileStream实例。
文件和文件流 1....文件流 文件流的分类: 根据功能分为:输入流(读取文件) 和 输出流(写入文件) 根据操作内容:字符流(读取字符数组) 和 字节流(读取字节数组) 字节输入流,字节输出流,字符输入流,字符输出流...=-1); //文件流是必须要关闭的(像水管子一样) is.close(); 利用字节输出流实现文件的写入 //利用字节输出流实现文件内容的写入(OutputStream 接口的FileOutputStream...(info.getBytes()); //写入完毕后,关闭 os.flush(); //清空缓存区 os.close(); } 利用字节输入流和字节输出流实现文件的拷贝 //利用字节输入输入输出流...(只能读取字符文件的信息) //使用字符流读取文件 public static void testReader() throws Exception{ //创建文件对象 File file =
什么是事件流 在JavaScript中事件流是指一个事件沿特定数据结构传播的一个过程。整个事件流总共包含三个阶段(从dome2来说):1.事件捕获阶段、2.处于事件目标阶段、3.事件冒泡阶段。...下面我们来看一个图,只要是谈到事件流都会看到的一个图: ?...从这个图里面我们可以清晰的看到整个事件流的执行过程,首先是从window开始,一步步的从上向下执行,此过程就是事件捕获阶段,当到达了事件的位置以后则处于事件目标阶段,之后会在向上冒泡,进入事件的冒泡阶段...触碰完成以后再把手拿出来,正好是一个相反的过程,这就与我们的事件流机制是一个道理。 事件绑定 下面来看一下下面这个示例代码: <!
JS事件流模型 事件捕获Event Capturing是一种从上而下的传播方式,以click事件为例,其会从最外层根节向内传播到达点击的节点,为从最外层节点逐渐向内传播直到目标节点的方式。...DOCTYPE html> JS事件流模型 div{...DOCTYPE html> JS事件流模型 div{...DOCTYPE html> JS事件流模型 div{
工作形式: 因为在TS流里可以填入很多种东西,所以有必要有一种机制来确定怎么来标识这些数据。制定TS流标准的机构就规定了一些数据结构来定义。...比如: PSI(Program Specific Information)表,所以解析起来就像这样: 先接收一个负载里为PAT的数据包,在整个数据包里找到一个PMT包的ID。...根据填入的数据类型的ID的不同,在TS流复合多种信息是可行的。关键就是找到标识的ID号。 ...这是一个调整TS流数据包头的函数,这里牵扯到位段调整的问题。...现在看看我们的TS流片断例子,看来正好是47 40 00开头的,一个TS流的头部占据了4个字节。剩下的负载部分的内容由PID来决定,例子看来就是一个PAT表。
在VBAProject中,dir流保存了一些VBA代码的重要信息,所以解析VBAProject的时候一并进行了解析。 dir流的结构请参考官方文档的2.3.4.2 dir Stream。...这里主要解析VBA模块的3个信息: Public Enum ModuleTypeEnum ProceduralModule = &H21 ClassModule = &H22 'document...ModuleInfo SName As String Offset As Long IType As ModuleTypeEnum End Type Offset:VBA代码在具体的模块流中起始的位置...) = &H0) p = p + 1 If p > iLen - 1 Then GetModuleInfo = "DIR流:...解析moduleName出错了。"
文章目录 一、文件输入输出流 1、文件输入输出流简介 2、继承结构 3、文件输入输出流对象 二、文件打开与关闭 1、文件打开 2、创建文件流对象同时指定参数打开文件 3、调用文件流对象 open 函数打开文件...4、关闭文件流 三、Visual Studio 2019 中创建文件 一、文件输入输出流 1、文件输入输出流简介 文件 IO 流 , 主要定义在 fstream.h 头文件中 , 该头文件中定义了以下三个类...open 函数打开文件 2、创建文件流对象同时指定参数打开文件 创建文件流对象同时指定参数打开文件 : 在 创建文件流对象 时 在 构造函数 参数中 , 设置 文件路径 和 访问方式 ; 代码示例 :...创建文件输出流对象并打开文件 : // 创建 文件输出流 对象 // 1....第二种方式 文件输出流 // 创建 文件输出流 对象 并打开 // 1. 首先 , 创建 文件输出流 对象 // 2.
上篇文章给大家介绍了如何借助nodejs平台解析操作excel,今天给大家介绍如何在浏览器端使用js解析操作excel。...在文章开始之前我们要搞明白一件事情,那就是在浏览器端用js操作excel主要来做什么呢? 主要做两件事情读和写,对就是这两件事情,在浏览器端针对Excel操作的所有需求无非就是读和写。...页面中引入这个js文件之后会有一个全局变量XLSX ? , 这个全局变量有许多属性方法如图: ? 咱们只介绍最常用的三个,上图已经用红线画出来了,read,utils,writeFile三个方法。...可以通过一个上传文件的input元素或者拖拽对象。 这里为了简便我们就通过一个上传文件的input元素来获取File对象。...以上便是浏览器借助js读取excel文件,代码量不多但稍微有点繁琐,涉及到了FileReader这个html5的新特性。
在 Node.js 中可以通过 buffer.constants.MAX\_LENGTH 查看某套开发环境最多可支持多少字节的缓冲区。.../main.js ./test.txt 就可以把 test.txt 文件压缩成 .gz 格式的压缩包了。...流模式压缩文件// main.jsimport { createGzip } from 'node:zlib';import { createReadStream, createWriteStream...Node.js 平台里面每一种流对象,在类型上都属于下面这四个基本抽象类中的一个,这些类是由 stream 核心模块提供的:ReadableWritableDuplexTransform每个 stream...假如我们要实现这样一种 Writable 流,接收下面这种格式的对象:{ path: content: }每收到这样一个对象,我们就会把 path 所指的路径下创建一份文件
流的历史演变 流不是 Node.js 特有的概念。它们是几十年前在 Unix 操作系统中引入的,程序可以通过管道运算符(|)对流进行相互交互。...在 Node 中,我们使用传统的 readFile 去读取文件的话,会将文件从头到尾都读到内存中,当所有内容都被读取完毕之后才会对加载到内存中的文件内容进行统一处理。...这样做会有两个缺点: 内存方面:占用大量内存 时间方面:需要等待数据的整个有效负载都加载完才会开始处理数据 为了解决上述问题,Node.js 效仿并实现了流的概念,在 Node.js 流中,一共有四种类型的流...那么 Node.js 流是怎样实现基于 EventEmitter 创建实例的呢?...总结 Node.js 为了解决内存问题和时间问题,实现了自己的流,从而可以将数据一小块一小块的读到内存里给消费者消费 流并不是 Node.js 特有的概念,它们是几十年前在 Unix 操作系统中引入的
作者简介:盛科网络 王俊杰 01 流控技术概要 1.1 流控技术与RDMA 随着数据中心网络技术和带宽不断发展,流控技术在网络中发挥着越来越重要的作用,但一直未曾有过很大变革。...基于TCP的RDMA,本质上是将“无损”寄托在TCP的可靠性上,而基于RoCEv2的无损网络则是将“无损”放在了流控机制。本文所提及的流控技术,主要是指基于RoCEv2的流控技术。...总结来说,RDMA网络实现“低时延”,“无丢包”,“高吞吐”的关键是流控技术。 02 流控技术原理 2.1 PFC ?...Congestion Notification Packets)报文,ECN字段为01,要求报文不能被网路丢弃; 交换机收到CNP 报文后正常转发该报文; 发送服务器收到ECN 标记为01 的CNP 报文解析后对相应的数据流限速算法...在保障数据流低时延转发情况下,TIMELY能够保证链路高吞吐率和数据流之间的公平性。 ?
JS的解析 学习目标: 了解 定位js的方法 了解 添加断点观察js的执行过程的方法 应用 js2py获取js的方法 1 确定js的位置 对于前面人人网的案例,我们知道了url地址中有部分参数,但是参数是如何生成的呢...找到js的位置之后,我们可以来通过观察js的位置,找到js具体在如何执行,后续我们可以通过python程序来模拟js的执行,或者是使用类似js2py直接把js代码转化为python程序去执行 观察js...rKey 方法: get 根据获取信息对密码进行加密 2.1 准备用户名和密码 2.2 使用js2py生成js的执行环境:context 2.3 拷贝使用到js文件的内容到本项目中 2.4 读取js文件的内容...文件到本地: BigInt.js RSA.js Barrett.js import requests import json import js2py # - 实现思路: # -...生成js的执行环境:context context = js2py.EvalJs() # - 拷贝使用到js文件的内容到本项目中 # - 读取js文件的内容,使用context来执行它们
博客地址:https://ainyi.com/60 分享一次纯 css 瀑布流 和 js 瀑布流 纯 css 写瀑布流 1.multi-columns 方式: 通过 Multi-columns 相关的属性...看到这里,我们可以发现,使用纯 css 写瀑布流,每一块 item 都是从上往下排列,不能做到从左往右排列: ? 这样子若是动态加载图片的瀑布流,体验就会很不好 我们想要的是这样: ?...这样做只能通过 js 来写瀑布流 js 写瀑布流: html 结构与上面类似,这里我用图片来做示例: 1 2 <...100% { 25 transform: scale(1.07); 26 } 27 } js...瀑布流实现方式: css 的绝对定位方式:根据每张图片的位置设置 top 和 left 值: 1 //瀑布流效果 2 //这里有一个坑(已经修复): 3 //因为是动态加载远程图片,在未加载完全无法获取图片宽高
领取专属 10元无门槛券
手把手带您无忧上云