当前位置:   article > 正文

JavaScript 实现通过字符串调用函数、方法_js字符串函数如何执行

js字符串函数如何执行

1. 简单函数形式

  1. function fun() {
  2. console.log("函数 fun 被调用");
  3. }
  4. /**
  5. * 简单函数形式,该方法传入函数名即可
  6. */
  7. function callModelFun(functionName) {
  8. //根据函数名得到函数类型
  9. let func = eval(functionName);
  10. //创建函数对象,并调用
  11. new func();
  12. }
  13. callModelFun("fun");

2. 构造函数形式

  1. function User () {
  2. this.sayHello = function () {
  3. console.log("User 对象的 sayHello 方法被调用");
  4. }
  5. }
  6. /**
  7. * 构造函数的形式 通过构造函数名和方法名实现方法调用
  8. * @param objName
  9. * @param methodName
  10. */
  11. function callObjectMethod(objName, methodName) {
  12. const func = eval(objName);
  13. const f = new func();
  14. f[methodName]();
  15. }
  16. callObjectMethod("User", "sayHello");

 3. 对象字面量的形式

  1. let Person = {
  2. speak: function () {
  3. console.log("speak方法调用");
  4. // return "hello hello";
  5. }
  6. }
  7. // callObjectMethod("Person", "speak"); // 不可行
  8. /**
  9. * 对象字面量的形式 通过对象名和方法名实现方法调用
  10. * @param objName
  11. * @param methodName
  12. */
  13. function callObjectMethod2(objName, methodName) {
  14. // 实现动态调用objName 对象的 methodName 方法
  15. const func = eval(objName);
  16. func[methodName]();
  17. }
  18. callObjectMethod2("Person", "speak");

以上是三种情况的处理方式。核心用到了 js 的eval 函数。

eval()函数是一种接受字符串作为参数,并且可以将接受的字符串转换成js表达式并且立即执行该表达式。将字符串转成js指令执行。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/78698
推荐阅读
相关标签
  

闽ICP备14008679号