首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JS】547- 200行JS代码,带你实现代码编译(人人都能学会)

    其实我们也经常接触到编译的使用场景: React 中 JSX 转换成 JS 代码; 通过 Babel 将 ES6 及以上规范的代码转换成 ES5 代码; 通过各种 Loader 将 Less / Scss...代码转换成浏览支持的 CSS 代码; 将 TypeScript 转换为 JavaScript 代码。...接下来进入本文主题:「200行JS代码,带你实现代码编译」。 二、编译介绍 2.1 程序运行方式 现代程序主要有两种编译模式:静态编译和动态解释。...angular 编译,这样可以减少我们 JS 脚本库的大小。...最后,文中介绍到的代码,我存放在 Github 上: [learning]the-super-tiny-compiler.js[4] [writing]webpack-compiler.js[5] 六、

    2.6K40

    JS】装饰让你的代码更简洁

    比如: setTimeout(() => { ...代码... // 这里的代码将延迟运行 }, 0); 我很讨厌这样写代码,我希望它变得简洁,所以我们可以把 setTimeout函数抽象成装饰...首先创建一个 timeout生成装饰方法来简化我们的代码(TypeScript): function timeout( milliseconds: number = 0 ) { return...装饰工厂模式就是一个普通的函数,这个函数运行时会返回装饰的函数表达式。 接下来,我们得到被装饰的函数,然后重写它,创造一个包裹 setTimeout的新函数。...结论: 装饰非常强大,它不仅仅适用于各种框架也适用于各种类库,所以在你的代码中试试吧。 ?...---- 往期精选文章 使用虚拟dom和JavaScript构建完全响应式的UI框架 扩展 Vue 组件 使用Three.js制作酷炫无比的无穷隧道特效 一个治愈JavaScript疲劳的学习计划 全栈工程师技能大全

    98720

    调试JS代码

    记录下近期对JS代码的调试过程 性能分析 启动程序之后,打开google浏览对应页面,按F12或者Ctrl+Shift+I进入 开发者工具页面 目前主要使用的功能有: Performance....性能评估,比如我想看下页面刷新的性能瓶颈所在,先点击 按钮,然后进行页面操作,当页面刷新完成,再点击 按钮,则会生成性能报告,可以看到资源消耗,JS代码的执行逻辑等 Sources....性能报告页面的 部分,可以通过点击色块查看其所在的js代码文件,如 点击则会跳转到 功能栏,有了源文件就可以进行断点调试;这里注意部分js文件是压缩后的文件,建议手动修改程序替换成可读性更强的原始代码文件...查看程序的打印输出,比如我想知道某个函数的执行时间,可以在js代码中进行修改 当js代码执行之后,可以在console输出中看到foo的执行时间 Network....代码使用for循环进行操作,也就是线性复杂度,计算耗时随数据量的增大而线性增大 通过debug观察发现颜色数组会有不少重复的数值,而同样的输入会导致相同的输出,然后对整个数据的1M个点进行统计分析,发现重复率相当高

    19K10

    js代码规范

    前言 在js代码开发中,我简单的总结出了以下规则,后面会陆续补充并且对规范进行分类。...js代码建议保存到后缀名.js的文件中 js代码不建议放在html中,原因有:不能被缓存,会增大网页文件的大小,可维护性不高,会影响页面的加载。...js吧任何表达式都当一条简单语句,会导致一些隐性的错误。如果自己没加分号,那么js解释会自动添加分号,按照自己能读懂的断句。 9.2 复合语句 也称为语句块,被包在大括号内部。...不建议修改内建对象的原型链 内建对象的原型链 是比较好的标准 自己不要修改内建对象的相关方法 在内建对象的es5 es6 语法中有哪些 this关键字的使用场景 : 全局变量 ,触发元素,构造本身...尽量使用语法严格模式 消除代码之中的不友好;代码运行更快 ;保证运行的安全 ;为新版本的js做好铺垫。 22.

    8.9K30

    JS代码混淆 | js 逆向系列

    -g uglifyjs example.js -c -m --mangle-props -c 代码压缩 -m 代码混淆 --mangle-props 混淆属性名 -b 美化显示 // 原代码 const...JShaman https://www.jshaman.com/ JShaman 是国内公司开发的js代码加密商业产品 免费版可以直接使用 // 原代码 const person = { age...,通过数组、字典等各种形式存储、拼接、替换等,最终进行还原,这里面没有利用到复杂的语法以及js 语言本身的特性,所以我们一点点解开也学不到什么; 这个代码就不一样了,我们一步一步解开它,尝试去学习其中的思路...我们可以在 debug 的代码中加入 alert(1) 代码,分析代码后发现 alert(T) 是最合适的 这里需要注意,由于后面代码是一个立即调用表达式,所以这里必须得加 ; ,不然会报错 浏览不开浏览调试工具...指定包装类型,上面我说包装就是一个函数吧,从官方配置上来看,只是其中一种类型,还可以是变量包装,但是官方并没有给出变量包装的案例,官网还是拿函数包装举例的 那咱们就自己实践一下 // 原代码

    2.4K10

    JS设置定时_js设置定时

    JS定时的一些特性和如何避免重复设置定时 概述和总结 每个JS定时产生时会被系统分配一个id,这个id是正整数,而且一个页面里面的定时id不重复,我们能用一个变量接收这个id,但是如果重复执行一条接收创建语句...,那么你只能接收到最新创建的定时的id,之前创建的定时的id会被覆盖,但是定时数量在增加,这就会导致界面一些功能错乱,解决方法就是在重复按开始按钮时,如果已经有了一个定时那么就不执行语句,我列出了错误代码和三种解决方法...案例分析 用两个按钮来控制灯泡的闪烁,运用CSS简单美化页面,然后控制功能由JavaScript实现,但在使用JS中的计时时遇到一些问题。也不再废话了, 下面是最开始的代码 /* border-radius:设置边框圆角 margin-top: 设置上外边距 margin-left:设置左外边距 这里边距使用百分比比直接设置..." name="start" id="start"> /* 这里就是JS

    29.9K30

    Js 逆向进阶 | 浅谈 Js 代码保护

    作者:不知世事 原文:https://blog.csdn.net/feibabeibei_beibei/article/details/98232069 JavaScript 代码保护浅谈 国外: 1...vmp 最强的,这种方案其实也是很好理解的,比如对于一个js代码来说,我们只用js操作写一个基于栈的解释,然后对于本身要保护的js进行虚拟化,定义一堆自定义操作,这个时候其实还是比较弱,因为全部是...js 写的暴漏在攻击者面前; 第二阶段: 这个时候的一个大致的想法是我们可以把虚拟机解释这部分用C/c++来实现,通过Emscripten 处理为webasembly,这个时候的分析难度就会增加很多,...如果再结合别的一些保护方案,效果应该会很不错,但是毕竟webasem这种文件的格式是公开的,可能这种方案的持久性不行,并且各个浏览的兼容也是一大问题;当然后期也可以针对webasembly再进行处理,...总结 对于 js 这种语言来说,由于语言本身的特殊性,一定的保护是非常必要的,再结合浏览本身的发展,为了性能会在编译上做处理,引入本地层的东西,比如谷歌的 V8 ,火狐的 asm.js 在安全性上:业务上更多的结合服务端动态特性以及客户端强大的静态代码保护的设计会达到一个比较好的效果

    27.8K20

    js代码混淆工具?

    由于js代码是运行在浏览端的,任何人都可以通过查看网页源码或者使用开发者工具来查看和修改js代码,这给js代码带来了很大的风险。...因此,在选择js混淆工具时,需要根据自己的目标用户和浏览环境,选择合适的js语言标准和浏览兼容性。常用的js混淆工具有哪些?...JShaman: 这是一个商业级的js代码混淆,看起来很专业且没有广告。它提供了在线免费使用和购买商业版两种方式。它能够对js代码进行高级别的加密和保护,并且保证代码运行速度不受影响。...jsfack: 这是一个开源的js代码转换,原理比较简单,其实就是通过特定的字符串加上下标定位字符,再由这些字符替换源代码,从而实现转换。它能够将任何js代码转换成只包含6个字符`[]()!...+`的代码,并且仍然能够在浏览中运行。它看起来很强大且有趣,但是本质上是一种编码,安全性并不高。而且,它只适合少量代码混淆。

    74100

    JS代码之混淆

    AST 在线解析 AST explorer js 在线混淆工具 JavaScript Obfuscator Tool 书籍 《反爬虫 AST 原理与还原混淆实战》 相关混淆代码 kuizuo/js-de-obfuscator...js 代码中混淆与还原的对抗,而所使用的技术便是 AST,通过 AST 能很轻松的将 js代码混淆成难以辨别的代码。...AST 有什么用​ 除了上述的混淆代码,很多文本编辑中也会使用到,例如: 编辑的错误提示、代码格式化、代码高亮、代码自动补全; elint、pretiier 对代码错误或风格的检查; webpack...parser 与 generator​ 前者用于将 js 代码解析成 AST,后者则是将 AST 转为 js 代码,两者的具体参数可通过 babel 手册查看,这就不做过多介绍了。...个人推荐这种写法,因为能有 js代码提示,如果是 TypeScript 效果也一样。

    22K10

    JS代码之还原

    基于 Babel 对 JS 代码进行混淆与还原操作的网站 JS 代码混淆与还原 (kuizuo.cn) 还原前言​ AST 仅仅只是静态分析,但可以将还原出来的代码替换原来的代码,以便更好的动态分析找出相关点...在还原时,并不是所有的代码都能还原成一眼就识破代码执行逻辑的,ast 也并非万能,如果你拥有强大的 js 逆向能力,有时候动态调试甚至比 AST 静态分析来的事半功倍。...贴上代码 git 地址 js-de-obfuscator/example/deobfuscator/cx 注:该 js 文件是通过工具JavaScript Obfuscator Tool进行混淆处理的。...虽然说代码编辑会将其标暗,表示不会执行到,但在混淆中巴不得代码量少一下,所有还是有必要通过 AST 进行操作。...JS 混淆与还原的网站​ 针对上述还原操作其实还不够明显,于是就编写了一个在线对 JS 代码混淆与还原的网站(主要针对还原)– JS 代码混淆与还原 (kuizuo.cn) 其实也就是对上述的还原代码进行封装成工具使用

    19.2K20
    领券