吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1011|回复: 7
收起左侧

[讨论] JS 根据字符串条件,访问函数的问题讨论

[复制链接]
cqwcns 发表于 2021-10-14 08:52
本帖最后由 cqwcns 于 2021-10-14 08:54 编辑

根据字符串条件,访问函数,我现在想得到的是eval,不知道是不是标准的方法,欢迎大家指正。
[JavaScript] 纯文本查看 复制代码
<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <title>测试</title>
    <script>

        const data = {
            name: '周星驰',
            action: () => '李小龙'
        }


        // 这里省略若干代码,收到一些传参,字符串类型。

        const paramA = 'name', paramB = 'action'

// 根据传参访问data。
        console.log(data[paramA])
                // 打印了字符串“周星驰”
                
                console.log(data[paramB])
                // 打印了函数() => '李小龙'
                
                // 问题在于,如何通过paramB直接调用action函数,获得返回结果
                // 我想到的是这样:
                console.log(eval(`data.${paramB}()`))
                // 打印了字符串'李小龙'
                
    </script>
</head>

<body>


</body>

</html>

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

zhzhch335 发表于 2021-10-14 09:09
直接加括号调用有啥问题吗
平时写小程序 vue项目 或者ts的时候不都有这种情况吗?
xss5813 发表于 2021-10-14 09:12
kof21411 发表于 2021-10-14 09:33
LTTing 发表于 2021-10-14 09:36
console.log(data.action())
为什么要把action赋给paramB没理解
 楼主| cqwcns 发表于 2021-10-14 10:16

个人认为,此正解。

谢谢各位
 楼主| cqwcns 发表于 2021-10-14 10:17
LTTing 发表于 2021-10-14 09:36
console.log(data.action())
为什么要把action赋给paramB没理解

传过来的参
icysky0605 发表于 2021-10-14 10:21
本帖最后由 icysky0605 于 2021-10-14 10:37 编辑

[HTML] 纯文本查看 复制代码
<!DOCTYPE html>
<html>
 
<head>
    <meta charset="utf-8">
    <title>测试</title>
    <script>
 
        const data = {
            name: '周星驰',
            action: (myname,age) => myname + age
        }
        Function.prototype.getName = function(){

            return this.name || this.toString().match(/function\s*([^(]*)\(/)[1]

        }
 
        const paramA = 'name', paramB = 'action'
 
        if(typeof data[paramB] === 'function'){
            document.write("函数名称:"+data[paramB].getName()+"<br/>")
            document.write("参数数量:"+data[paramB].length+"<br/>")
            document.write("参数列表:"+getParameterName(data[paramB]).join(",")+"<br/>")
            document.write("执行结果:"+data[paramB]("张三",18)+"<br/>")
        }
        function getParameterName(fn) {
            if(typeof fn !== 'object' && typeof fn !== 'function' ) return;
            const COMMENTS = /((\/\/.*$)|(\/\*[\s\S]*?\*\/))/mg;
            const DEFAULT_PARAMS = /=[^,)]+/mg;
            const FAT_ARROWS = /=>.*$/mg;
            let code = fn.prototype ? fn.prototype.constructor.toString() : fn.toString();
            code = code
                .replace(COMMENTS, '')
                .replace(FAT_ARROWS, '')
                .replace(DEFAULT_PARAMS, '');
            let result = code.slice(code.indexOf('(') + 1, code.indexOf(')')).match(/([^\s,]+)/g);
            return result === null ? [] :result;
        }
    </script>
</head>
 
<body>
 
 
</body>
 
</html>
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-25 20:51

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表