码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 前端知识记录


    JS

    import VS require

    简介

    • require/exports 是 CommonJS/AMD 中为了解决模块化语法而引入的。
    • import/export 是ES6引入的新规范(涉及浏览器引擎兼容问题)。

    调用时机

    • require 是运行时调用,所以理论上可以运作在代码的任何地方。
    • import 是编译时调用,所以必须放在文件的开头。

    本质

    • require 是赋值过程,其实require的结果就是对象、数字、字符串、函数等,再把结果赋值给某个变量。它是普通的值拷贝传递。
    • import 是解构过程。使用import导入模块的属性或者方法是引用传递。且import是read-only的,值是单向传递的。default是ES6 模块化所独有的关键字,export default {} 输出默认的接口对象,如果没有命名,则在import时可以自定义一个名称用来关联这个对象。

    require

    在模块中,将所要导出的数据存放在module的export属性中,在经过CommonJs/AMD规范的处理,在需要的页面中使用require指定到该模块,即可导出模块中的export属性并执行赋值操作(值拷贝)。

    // module.js
    module.exports = {
        a: function() {
            console.log('exports from module');
        }
    }
    
    // sample.js
    var obj = require('./module.js');
    obj.a()  // exports from module
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    import

    // module.js
    export function test(args) {
      console.log(args);
    }
    // 定义一个默认导出文件, 一个文件只能定义一次
    export default {
      a: function() {
        console.log('export from module');
      }
    }
    export const name = 'gzc'
    
    // 使用_导出export default的内容
    import _, { test, name } from './a.js'
    test(`my name is ${name}`)  // 模板字符串中使用${}加入变量
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    简书:JS中的「import」和「require 」

    html2canvas:HTML截图

    截图

    方法一:

    function convert() {
    	html2canvas(document.body).then(canvas => {
    		document.body.appendChild(canvas)
    	});
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    html2canvas(document.querySelector("#capture")).then(canvas => {
        var image = new Image();
        image.src = canvas.toDataURL("image/png");  // 获取存储路径
        document.body.appendChild(image)
    });
    
    • 1
    • 2
    • 3
    • 4
    • 5

    方法二(特定元素):

    html2canvas(document.querySelector("#capture")).then(canvas => {
      document.body.appendChild(canvas)
    });
    
    • 1
    • 2
    • 3

    保存到文件(引入FileSaver.js) 未实现

    https://github.com/eligrey/FileSaver.js

    需要先通过node.js安装

    npm install file-saver --save
    bower install file-saver
    
    • 1
    • 2
    import { saveAs } from 'file-saver';
    FileSaver saveAs(Blob/File/Url, optional DOMString filename, optional Object { autoBom })
    var FileSaver = require('file-saver');
    function TakeScreenshot()
    {
    	html2canvas(document.body).then(function(canvas) {
    		canvas.toBlob(function(blob) {
    			saveAs(blob, "test.png");
    		});
    	});
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    方法二(下载到浏览器默认路径)

    let aLink=document.createElement('a');
    aLink.href='imgUrl.png'//设置下载的图片链接
    aLink.download='imgName.png'//设置图片下载之后的名称
    aLink.click()//触发点击事件
    
    • 1
    • 2
    • 3
    • 4

    JS - 使用 html2canvas 将页面保存成图片(或对指定元素截图)
    fileSaverJS 客户端保存文件

    HTML转pdf

    工具

    https://github.com/wuxue107/bookjs-eazy
    https://gitee.com/wuxue107/screenshot-api-server

    HTML转图片

    https://phantomjs.org/

  • 相关阅读:
    Flink SQL(四) 连接到外部系统Elasticsearch和HBase
    平平无奇的项目「GitHub 热点速览 v.22.10」
    基于AlgoT1设备实践多源融合定位算法(GNSS+INS+VISION)
    2022年软件测试行业就业发展前景,软件测试前景好吗?我该学什么?
    Spring和Spring Boot之间的区别(小结)
    7.网络原理之TCP_IP(上)
    Nginx正向代理配置(http)
    MyBatis的各种查询功能
    【docker专栏6】详解docker容器状态转换管理命令
    Crypto/加密货币 应用
  • 原文地址:https://blog.csdn.net/qq_21980099/article/details/125482502
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号