下划线命名对象值直呼恶心心

就是在一次逛知乎看了一段全是下划线命名变量的代码 于是自己用js尝试着写了一下

效果如下图 也实现了反编译的
在这里插入图片描述
就图一乐 代码很简单 嘿嘿

     // 使用
        let key = 'queryyy';
        let testdata = {};
        let Keydata = { name: "shou", age: 12, set: "男" };
        let keyValue = new rulercode();
        testdata[keyValue.compiler('name')] = 'shou';
        testdata[keyValue.compiler('age')] = '12';
        testdata[keyValue.compiler('set')] = '男';

方法代码 接受一个布尔值 是否需要反编译

class rulercode {
    searching = [];
    codecharacter = 'qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM1234567890-=_/.|';
    constructor(data = false) {
        this.iscode = data;
        this.searchinginit();
    }
    searchinginit() {
        for (let i = 0; i < this.codecharacter.length; i++) {
            this.searching.push({
                index: i + 1,
                keyValue: this.codecharacter.charAt(i)
            })
        }
    }
    compiler(edata) {
        let data = [];
        this.searching.map(item => {
            for (let i = 0; i < edata.length; i++) {
                let _length = 0;
                let _string = new String();
                if (item.keyValue == edata[i]) {
                    for (let t = 0; t < item.index; t++) {
                        _string += '_'
                    }
                    data.push({
                        value: _string,
                        index: i
                    });
                }
            }
        })
        data = data.sort(this.cpmpare('index'));
        let rundata = [];
        data.map(item => {
            rundata.push(item.value)
        })
        if (this.iscode) {
            return rundata.join('-');
        } else {
            return rundata.join('');
        }
    }
    cpmpare(property) {
        return function (a, b) {
            var value1 = a[property];
            var value2 = b[property];
            return value1 - value2;
        }
    }
    reverse(data) {
        let _stringdata = data.split('-');
        let _codedata = new String();
        _stringdata.map(item => {
            let _stringketlength = 0;
            for (let i = 0; i < item.length; i++) {
                _stringketlength++;
            }
            this.searching.map(itemall => {
                if (itemall.index == _stringketlength) {
                    _codedata += itemall.keyValue;
                }
            })
        });
        return _codedata;
    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值