V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
guibin1989
V2EX  ›  JavaScript

不懂就问,在某公司提供的 demo 中看到这种写法,有什么作用?

  •  1
     
  •   guibin1989 · 2020-06-15 17:50:59 +08:00 · 8235 次点击
    这是一个创建于 1608 天前的主题,其中的信息可能已经有所发展或是发生改变。

    NCQz9K.png

    第 1 条附言  ·  2020-06-16 10:11:18 +08:00
    谢谢大家,主要是没想到提供 demo 代码怎么会给一份压缩版的
    40 条回复    2020-06-16 16:55:20 +08:00
    luobo
        1
    luobo  
       2020-06-15 17:53:43 +08:00
    .........................你猜
    KasonPasser
        2
    KasonPasser  
       2020-06-15 17:54:17 +08:00
    节省字符。
    true => 4
    !1 => 2 省了 2 个
    false => 5
    !0 => 2 省了 3 个
    Q2F5emxo
        3
    Q2F5emxo  
       2020-06-15 17:54:46 +08:00
    .........................你猜
    Zoro76
        4
    Zoro76  
       2020-06-15 17:55:07 +08:00
    就 true,false 在项目中这么写纯铁憨憨。
    nidaye999
        5
    nidaye999  
       2020-06-15 17:55:17 +08:00   ❤️ 3
    没什么作用,看样子好像是混淆过的, 就是隐式转换布尔值。
    xuanchen
        6
    xuanchen  
       2020-06-15 17:55:38 +08:00
    减少文件大小
    smilenceX
        7
    smilenceX  
       2020-06-15 17:56:03 +08:00   ❤️ 22
    虚假的节省字符:!1
    真正的节省字符:0
    TomVista
        8
    TomVista  
       2020-06-15 17:56:38 +08:00
    省一个按键的动作:dog
    itskingname
        9
    itskingname  
       2020-06-15 17:57:09 +08:00
    @KasonPasser 你似乎写反了。!0 是 true,!1 是 false
    DOLLOR
        10
    DOLLOR  
       2020-06-15 17:58:24 +08:00 via iPhone   ❤️ 6
    看那参数名、变量名就知道,你这代码是混淆过的,是混淆工具把 true 和 false 变成!0 和!1 的,并不是当时开发者这么写的。
    ccvzz
        11
    ccvzz  
       2020-06-15 18:03:23 +08:00 via Android
    写完以后发现写错了,前面加个!,省得打退格了

    true 改 false:退格*4+字母*5
    1 改 0:退格*1+数字*1 ( 2 次键入)
    1 改!1:左移(或直接鼠标点击)+!( 1 或 2 次键入)
    高下立判(强行洗地)
    KasonPasser
        12
    KasonPasser  
       2020-06-15 18:11:14 +08:00
    @itskingname 是的,写反了。上了一整天班,脑子不灵了。
    shuangya
        13
    shuangya  
       2020-06-15 18:14:02 +08:00 via Android   ❤️ 1
    混淆过的。
    混淆工具这样干的原因是,节省字符,同时不影响原本的数据类型。
    开发者自己肯定不是这样写的。
    TangMonk
        14
    TangMonk  
       2020-06-15 18:20:39 +08:00
    好像是 uglify-js 处理过的
    en20
        15
    en20  
       2020-06-15 18:29:36 +08:00 via iPhone
    没啥意义,不如直接写 true,false 来的直观。最后代码也会压缩 uglify,省字符的事已经帮你做了。
    lemon6
        16
    lemon6  
       2020-06-15 21:02:17 +08:00 via Android
    代码被压缩或者混淆了
    killmojo
        17
    killmojo  
       2020-06-15 23:06:39 +08:00
    压缩的代码又被格式化了一遍,看样子没混淆
    fox0001
        18
    fox0001  
       2020-06-15 23:50:38 +08:00 via Android   ❤️ 3
    @smilenceX #7 加上!号,是考虑了数据类型的问题
    autoxbc
        19
    autoxbc  
       2020-06-15 23:59:38 +08:00   ❤️ 1
    看来有很多人分不清压缩和混淆
    dawn009
        20
    dawn009  
       2020-06-16 00:34:23 +08:00   ❤️ 2
    @smilenceX
    !1 是布尔型,0 是整型,类型不同,真值表有区别。
    zhuweiyou
        21
    zhuweiyou  
       2020-06-16 00:50:58 +08:00
    这个一看就是压缩过的代码,再格式化出来的。
    !1 就是 false 的意思,可以省几个字符,如果是人工写的,不可能这样写。
    AFuture
        22
    AFuture  
       2020-06-16 00:54:30 +08:00 via iPhone
    歪楼,询问高亮主题。
    no1xsyzy
        23
    no1xsyzy  
       2020-06-16 02:36:13 +08:00
    @autoxbc #19 有可能是 AST 内做混淆,不一定要做字符串级混淆
    看图中 L1,参数已经是 a, t, e 了。
    ByZHkc3
        24
    ByZHkc3  
       2020-06-16 03:03:53 +08:00
    想知道这是反编译了哪个微信小程序?
    Cbdy
        25
    Cbdy  
       2020-06-16 07:38:34 +08:00 via Android
    这是生成的代码吧
    smilenceX
        26
    smilenceX  
       2020-06-16 08:09:09 +08:00
    @fox0001 @dawn009 谢谢两位指出来。
    hantsy
        27
    hantsy  
       2020-06-16 08:45:06 +08:00
    !!两一起我觉得还是很多用法。一个单独用,少见。
    BreezeInWind
        28
    BreezeInWind  
       2020-06-16 08:58:08 +08:00
    最后那个 playbutton 的逻辑还需要用 if 写成两段吗。。
    ychost
        29
    ychost  
       2020-06-16 09:26:22 +08:00
    ugly 的结果
    guolaopi
        30
    guolaopi  
       2020-06-16 09:34:09 +08:00
    非零即真零即假。
    1 不是零,所以是真,!1 就是假
    takemeaway
        31
    takemeaway  
       2020-06-16 10:28:21 +08:00
    明明是混淆过的,还强行解释。
    s1ro6
        32
    s1ro6  
       2020-06-16 10:45:57 +08:00
    !0 或 !1 保证结果是布尔类型的,比直接写布尔值 true/false 简洁方便一点。
    true 和 !0 几乎在任何时候都是相同的,但 true 和 1 在很多时候是不同的(例如 React 的 JSX 组件)~
    whoami9894
        33
    whoami9894  
       2020-06-16 10:59:14 +08:00
    如果真是混淆过的,那这混淆工具水平不太行
    westoy
        34
    westoy  
       2020-06-16 11:09:39 +08:00
    @smilenceX

    !1 等效于!!0, 不等效于 0

    @zhuweiyou 十几年前提倡过这种写法的.......
    zhuweiyou
        35
    zhuweiyou  
       2020-06-16 12:00:18 +08:00
    @westoy 你看代码里的 a t m p 这些变量名,像是人写的?
    maomaomao001
        36
    maomaomao001  
       2020-06-16 12:27:06 +08:00
    var self = this ;

    明显就不可能是 uglifyjs 出来的
    NasirQ
        37
    NasirQ  
       2020-06-16 13:54:38 +08:00
    1. 这是用来转成布尔型的。(类似的 1+'' 数字转字符串)。
    2. 看参数和变量是混淆后的代码,是系统转的。源代码应该就是 !1 --> false ;!0 --> true
    当然,也可能是写 true 、false 要敲多次键盘 [狗头]~
    galikeoy
        38
    galikeoy  
       2020-06-16 15:02:00 +08:00
    @maomaomao001 #36 这个就有点奇怪
    Tdy95
        39
    Tdy95  
       2020-06-16 16:53:54 +08:00
    写这代码要被锤死的吧,额外增加阅读负担,想少敲几个字母的,vscode 的代码提示不香吗
    murmur
        40
    murmur  
       2020-06-16 16:55:20 +08:00
    用压缩后的代码再格式化当 demo,这是什么公司这么坑人
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2576 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 02:35 · PVG 10:35 · LAX 18:35 · JFK 21:35
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.