首页
学习
活动
专区
圈层
工具
发布
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    用Node.js把HTML转成PDF格式

    翻译:疯狂的技术宅 原文:https://blog.risingstack.com/pdf-from-html-node-js-puppeteer/ 在本文中,我将展示如何使用 Node.js、Puppeteer...方案1:从 DOM 制作屏幕截图 方案2:仅使用 PDF 库 最终方案3:Node.js、Puppeteer 和 Headless Chrome 样式控制 将文件发送到客户端并保存 在 Docker...在客户端和服务器端都可以生成PDF文件。但是让后端处理它可能更有意义,因为你并不想耗尽用户浏览器可以提供的所有资源。 即便如此,我仍然会展示这两种方法的解决方案。...最终方案3:基于 Node.js 的 Puppeteer 和 Headless Chrome 什么是 Puppeteer?...它本质上是一个可以从 Node.js 运行的浏览器。如果你读过它的文档,其中首先提到的就是你可以用 Puppeteer 来生成页面的截图和PDF。优秀!这正是我们想要的。

    8K30

    html5之客户端存储

    WebStorage介绍 所谓的WebStorage指的是客户端存储,在这里指的是浏览器端存储,比如在网站上自动登陆这些功能,其实就是把一些少量的数据存储在浏览器等客户端中,这样可以减少没必要的请求到服务器...,降低服务器的压力,给用户提供更好的体验....插件 session(会话)Storage: H5新增 存储量5M左右 只会在浏览器存储数据(浏览器的内存中) 只会由浏览器端创建 存储时间是打开浏览器开始关闭浏览器消失 方法简洁明了 容易操作...key); 清除数据: window.sessionStorage.clear(); 获取key: window.sessionStorage.key(n从0开始); 应用场景: 存储一些少量临时的数据...(比较少用) 总结 localStorage和sessionStorage只能存储json 存储的数据不能太多 太多浏览器会卡

    1.7K10

    《Node.js权威指南》:获取客户端请求信息

    上一篇《《Node.js权威指南》:如何创建HTTP服务器》中概括的介绍了创建HTTP服务器的套路,包括创建http服务器对象,用服务器对象监听客户端连接事件、错误事件和服务器关闭事件等,整体示例如下:...获取客户端请求信息 HTTP服务器接收到客户端请求时调用的回调函数中的第一个参数值是一个http.IncomingMessage对象,该对象用于读取客户端请求流中的数据。...当从客户端请求流中读取到新数据时触发data事件,当读取完客户端请求流中的数据时触发end事件。...url:该属性值是客户端发送请求时使用的url参数字符串,例如/、/abc/1、post/new?param=value等。这个属性非常重要,通常用来判断客户端请求的页面和需要执行的处理。...headers:该属性值是客户端发送的请求头对象,存放客户端发送的所有请求头信息,包括cookie信息和浏览器的各种信息。 socket:该属性值是服务器端用于监听客户端请求的socket对象。

    7.5K10

    使用 Node.js 实现一个简单的 ZooKeeper 客户端

    ,一旦创建这个 znode 的客户端与服务器失去联系,这个 znode 也将自动删除,Zookeeper 的客户端和服务器通信采用长连接方式,每个客户端和服务器通过心跳来保持连接,这个连接状态称为 session...,包括这个目录节点中存储的数据的修改,子节点目录的变化等,一旦变化可以通知设置监控的客户端,这个是 Zookeeper 的核心特性,Zookeeper 的很多功能都是基于这个特性实现的。...Node.js应用与ZooKeeper Server进行通信 那么当Node.js应用作为整个异构分布式系统中的一环,需要作为客户端去操作ZooKeeper Server上的znode时,应该如何实现?...本文只描述怎样使用Node.js实现ZooKeeper客户端角色。...node-zookeeper node-zookeeper是ZooKeeper的一个Node.js客户端实现,这个模块是基于ZooKeeper原生提供的C API来实现的。

    3.9K00

    使用Node.js实现一个简单的ZooKeeper客户端

    中存储的数据可以有多个版本,也就是一个访问路径中可以存储多份数据 znode 可以是临时节点,一旦创建这个 znode 的客户端与服务器失去联系,这个 znode 也将自动删除,Zookeeper 的客户端和服务器通信采用长连接方式...Node.js应用与ZooKeeper Server进行通信 那么当Node.js应用作为整个异构分布式系统中的一环,需要作为客户端去操作ZooKeeper Server上的znode时,应该如何实现?...说实话,上文介绍了这么多ZooKeeper的原理,其实作为客户端只需要单纯的把znode作为文件来操作就好,并且可以监听znode的改变,十分方便。...本文只描述怎样使用Node.js实现ZooKeeper客户端角色。...node-zookeeper node-zookeeper是ZooKeeper的一个Node.js客户端实现,这个模块是基于ZooKeeper原生提供的C API来实现的。

    1.9K00

    使用Node.js实现一个简单的ZooKeeper客户端

    中存储的数据可以有多个版本,也就是一个访问路径中可以存储多份数据 znode 可以是临时节点,一旦创建这个 znode 的客户端与服务器失去联系,这个 znode 也将自动删除,Zookeeper 的客户端和服务器通信采用长连接方式...Node.js应用与ZooKeeper Server进行通信 那么当Node.js应用作为整个异构分布式系统中的一环,需要作为客户端去操作ZooKeeper Server上的znode时,应该如何实现?...说实话,上文介绍了这么多ZooKeeper的原理,其实作为客户端只需要单纯的把znode作为文件来操作就好,并且可以监听znode的改变,十分方便。...本文只描述怎样使用Node.js实现ZooKeeper客户端角色。...node-zookeeper node-zookeeper是ZooKeeper的一个Node.js客户端实现,这个模块是基于ZooKeeper原生提供的C API来实现的。

    1.9K20

    HTML5之客户端存储数据

    在客户端存储数据 HTML5 提供了两种在客户端存储数据的新方法:localStorage - 没有时间限制的数据存储;sessionStorage - 针对一个 session 的数据存储之前,这些都是由...cookie 完成的。...但是 cookie 不适合大量数据的存储,因为它们由每个对服务器的请求来传递,这使得 cookie 速度很慢而且效率也不高。...在 HTML5 中,数据不是由每个服务器请求传递的,而是只有在请求时使用数据。它使在不影响网站性能的情况下存储大量数据成为可能。对于不同的网站,数据存储于不同的区域,并且一个网站只能访问其自身的数据。...HTML5 使用 JavaScript 来存储和访问数据。 localStorage 方法 localStorage 方法存储的数据没有时间限制。第二天、第二周或下一年之后,数据依然可用。

    1.9K40

    HTML5的五种客户端离线存储方案

    最近折腾HTML5游戏需要离线存储功能,便把目前可用的几种HTML5存储方式研究了下,基于HT for Web写了个综合的实例,分别利用了Cookie、WebStorage、IndexedDB以及FileSystem...http://www.hightopo.com/guide/guide/core/serialization/examples/example_exportimport.html HTML5的存储还有一种...Browser-Side的存储方式还在快速的发展中,其实除了以上几种外还有Application Cache,相信将来还会有新秀出现,虽然“云”是大趋势,但客户端并非要走极端的“瘦”方案,这么多年冒出了这么多客户端存储方式...,说明让客户端更强大的市场需求是强烈的,当然目前动荡阶段苦逼的是客户端程序员,除了要适配Mouse和Touch,还要适配各种屏,如今还得考虑适配各种存储,希望本文能在大家选型客户端存储方案时有点帮助,最后上段基于...HT for Web操作HTML5存储示例的视频效果:http://v.youku.com/v_show/id_XODUzODU2MTY0.html http://www.hightopo.com/guide

    2.2K50

    HTML5的五种客户端离线存储方案

    最近折腾HTML5游戏需要离线存储功能,便把目前可用的几种HTML5存储方式研究了下,基于HT for Web写了个综合的实例,分别利用了Cookie、WebStorage、IndexedDB以及FileSystem...http://www.hightopo.com/guide/guide/core/serialization/examples/example_exportimport.html HTML5的存储还有一种...:http://www.hightopo.com/persistent/类似目录的访问,因此也可以动态生成图片到本地文件,然后通过filesystem:http:***的URL方式直接赋值给img的html...,其实除了以上几种外还有Application Cache,相信将来还会有新秀出现,虽然“云”是大趋势,但客户端并非要走极端的“瘦”方案,这么多年冒出了这么多客户端存储方式,说明让客户端更强大的市场需求是强烈的...,当然目前动荡阶段苦逼的是客户端程序员,除了要适配Mouse和Touch,还要适配各种屏,如今还得考虑适配各种存储,希望本文能在大家选型客户端存储方案时有点帮助,最后上段基于HT for Web操作HTML5

    2.6K20

    python生成带有表格的图片

    因为工作中需要,需要生成一个带表格的图片 例如: 直接在html中写一个table标签,然后单独把表格部分保存成图片 或者是直接将excel中的内容保存成一个图片 刚开始的思路,是直接生成一个带有table...标签的html文件,然后将这个文件转成图片,经过查找资料发现需要安装webkit2png,而这个库又依赖其他的东西,遂放弃。...当初的目标是直接生成一个图片,并且是只需要安装python依赖库就行,而不需要在系统层面安装相应的依赖包 后来考虑使用Python的图片处理库Pillow,和生成表格式的库prattytable,下面的图片是最终生成的图片效果...,来确定图片的最终大小 img_size = draw.multiline_textsize(tab_info, font=font) # 图片初始化的大小为10-10,现在根据图片内容要重新设置图片的大小...但是还有一点问题,在使用中文时,表格会又一些错列,应该是使用字体的事,因为我没有找到合适的字体,所以这个问题暂时没有解决。

    6.4K20

    Node.js爬虫抓取数据 -- HTML 实体编码处理办法

    cheerio DOM化并解析的时候 1.假如使用了 .text()方法,则一般不会有html实体编码的问题出现 2.如果使用了 .html()方法,则很多情况下(多数是非英文的时候)都会出现,这时,可能就需要转义一番了...\w+的格式 所以就用正则转换一番 var body = .......//这里就是请求后获得的返回数据,或者那些 .html()后获取的 //一般可以先转换为标准unicode格式(有需要就添加:当返回的数据呈现太多\\\u 之类的时) body=unescape(body.replace...16:10)); }); ok ~ 当然了,网上也有很多个转换的版本,适用的就行了 后记: 当使用爬虫抓取网页数据时,cheerio模块是经常使用到底,它像jq那样方便快捷 (...但有些功能并未支持或者换了某种形式,比如 jq的 jQuery('.myClass').prop('outerHTML') ,cheerio则等价于 jQuery.html('.myClass') http

    1.9K10

    什么是带有SSCC的DESADV?

    零售商的物流挑战 在我们开始详细研究DESADV与SSCC之前,首先需要了解背景。近年来,零售业发生了实质性的变化。大多数小型杂货店的市场份额逐渐减少,大型零售商的分店占据了市场。...这个号码作为一个带有条形码的实物机读贴纸,安装在货物上,也包含在DESADV信息中。 这样就可以如下图所示,将货物送到仓库:在左侧,我们可以看到货物已经到达仓库,并被分配到正确的货架上。...带有SSCC的GS1标签示例如下图所示: 在DESADV中使用SSCC 什么时候DESADV报文用于宣布交货呢?...3.带有运输结构的每个托盘的SSCC 该选项清楚地描述了运输结构的层次结构,直至货盘的内容。DESADV将包含有关物品编号和每个托盘的箱子总数的信息。...以上是对于带有SSCC(系列货运包装箱代码)的DESADV的介绍,更多关于EDI相关信息,欢迎持续关注。

    2K30

    带有Apache Spark的Lambda架构

    目标 市场上的许多玩家已经建立了成功的MapReduce工作流程来每天处理以TB计的历史数据。但是谁愿意等待24小时才能获得最新的分析结果?...现实生活中有一些很好的例子: Oozie编排的工作流程每天运行并处理高达150 TB的数据以生成分析结果 bash管理的工作流程每天运行并处理高达8 TB的数据以生成分析结果 现在是2016年!...] 这看起来相当不错,但它仍然是一种传统的批处理方式,具有所有已知的缺点,主要原因是客户端的数据在批处理花费大量时间完成之前的数据处理时,新的数据已经进入而导致数据过时。...它是一种旨在通过利用批处理和流处理这两者的优势来处理大量数据的数据处理架构。 我强烈建议阅读Nathan Marz的书,因为它从提出者的角度提供了Lambda Architecture的完整表述。...– 1 morningatlohika – 1 spark – 1 查询 当客户端为了实时得到所有的Hash标签的统计结果进行查询时,我们只需要将批量视图与实时视图合并即可。

    2.8K50
    领券