JS技巧之一行赋值语句能玩出多少花样

 更新时间:2022年10月18日 11:49:13   作者:w2sfot  
很多前端只会谢谢页面,一让他们接触js,就非常害怕,下面这篇文章主要给大家介绍了关于JS技巧之一行赋值语句能玩出多少花样的相关资料,需要的朋友可以参考下

前言

今天,来做个测试,看看一行简单的JS赋值语句,有多少种写法。

测试语句,仅三行:

var a=1;
a=2;
console.log(a);

针对第二行a=2赋值,看能变多少花样。

第一种变化、写入到自执行函数中:

var a=1;
(function(){
a=2;
})();
console.log(a);

第二种变化、用eval执行:

var a=1;
eval(a=2);
console.log(a);

这两种,都比较初级,小白等级的程序员也能轻松看懂。

接下来,提升一些难度。

第三种变化、变形的eval执行:

对eval中的赋值语句,进行一些变化。

var a=1;
var b=["a","=",2];
eval(b[0]+b[1]+b[2]);
console.log(a);

但eval,似乎也就能玩到这个水准。下面再展示些难度更高的。

第四种变化、利用构造函数:

var a=1;
[].constructor.constructor(a=2);
console.log(a);

或:

var a=1;
[].constructor.constructor(a=2)();
console.log(a);

第五种变化、构造函数再升级:

var a=1;
var b=["a","=",2];
[].constructor.constructor(b[0]+b[1]+b[2])();
console.log(a);

如同eval执行内容变化一样,对构造执行代码也用数组内容拼接的方式进行变形:

第六种变化、构造函数变形:

将构造字符也放入数组中:

var a=1;
var b=["a","=",2,"constructor"];
[][b[3]][b[3]](b[0]+b[1]+b[2])();
console.log(a);

第七种变化、混淆加密:

将上面的JS代码用JShaman进行混淆加密:

得么混淆加密的JS代码,这时数值也被加密:

/*Obfuscated by JShaman.com*/
var a=0x2c0f8^0x2c0f9;
var b=['a','=',0xe3b2c^0xe3b2e,'constructor'];
[][b[0xa8ddf^0xa8ddc]][b[0xb3a35^0xb3a36]](b[0x3333f^0x3333f]+b[0x84d18^0x84d19]+b[0x50958^0x5095a])();
console['log'](a);

玩这些花样有什么用处吗?

当然是有的,最后得到的代码,完全看不出是在执行a=2,赋值操作被隐藏了:

当需要对代码进行加密,防止被他人任意阅读时,这是很有用的方法。

你还有什么新奇的写法吗,欢迎探讨交流。

总结

到此这篇关于JS技巧之一行赋值语句能玩出多少花样的文章就介绍到这了,更多相关JS赋值语句内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 微信小程序自定义联系人弹窗

    微信小程序自定义联系人弹窗

    这篇文章主要为大家详细介绍了微信小程序自定义联系人弹窗,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-05-05
  • JavaScript+Canvas实现酷炫的粒子和流星效果

    JavaScript+Canvas实现酷炫的粒子和流星效果

    这篇文章主要为大家详细介绍了如何利用JavaScript和Canvas实现酷炫的粒子和流星动画效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-01-01
  • JSP跨iframe如何传递参数实现代码

    JSP跨iframe如何传递参数实现代码

    表单与操作页面分离,按钮按下,click 或者onclick事件触发,传递一个唯一性的参数至子页面JSP,感兴趣的朋友可以了解下
    2013-09-09
  • 今天是星期几的4种JS代码写法

    今天是星期几的4种JS代码写法

    这篇文章介绍了今天是星期几的4种JS代码写法,有需要的朋友可以参考一下
    2013-09-09
  • javascript温习的一些笔记 基础常用知识小结

    javascript温习的一些笔记 基础常用知识小结

    在电脑上找到多年前的javascript的一些小笔记,因为要将笔记本上面的文件整理一下, 不用的删除掉, 所以将此篇笔记再发布一下,存档到自己的博客吧, 电脑上的文件就删除了
    2011-06-06
  • JS实现上传文件显示进度条

    JS实现上传文件显示进度条

    这篇文章主要为大家详细介绍了JS实现上传文件显示进度条,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07
  • 浅谈JavaScript中内存泄漏的几种情况

    浅谈JavaScript中内存泄漏的几种情况

    本文主要介绍了浅谈JavaScript中内存泄漏的几种情况,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • TypeScript判断对象类型的4种方式代码

    TypeScript判断对象类型的4种方式代码

    这篇文章主要给大家介绍了关于TypeScript判断对象类型的4种方式代码,TypeScript能根据一些简单的规则推断(检查)变量的类型,你可以通过实践很快的了解它们,需要的朋友可以参考下
    2023-07-07
  • javascript贪吃蛇完整版(源码)

    javascript贪吃蛇完整版(源码)

    这篇文章主要是对javascript贪吃蛇完整版(源码)进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2013-12-12
  • layui 实现table翻页滚动条位置保持不变的例子

    layui 实现table翻页滚动条位置保持不变的例子

    今天小编就为大家分享一篇layui 实现table翻页滚动条位置保持不变的例子,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-09-09

最新评论