百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

在javascript中如何将字符串转成变量或可执行的代码?

xsobi 2024-12-27 17:28 1 浏览

有这样一个需求:当前作用域内有未知的一些变量,其中一个函数中可以拿到某个变量名字符串,怎么能在函数内通过传进来的字符串取到作用域链中的变量值,示例小 demo 如下:

const name = '周小黑'
const age = 18

/**
 * @param {String} e 变量名字符串
 * @returns value 通过变量名字符串在作用域链中取到的变量值
 */
function fn(e) {
  let value
  // ...
  return value
}

const str = fn('name')

要解决上面的问题,主要就是怎么将字符串转变成可执行的代码?主要有三种方式:

eval() 函数

eval() 函数会将传入的字符串当做 JavaScript 代码进行执行,所以下面的字符串可以正确取到变量对应的值,eval 对比 new Function 和 setTimeout 它是可以访问局部作用域的,后两者都只能访问全局作用域。

const name = '周小黑'
const age = 18

function fn(e) {
  let value = eval(e)
  return value
}

const str = fn('name')
console.log(str)

很多地方都能看到这句名言:eval is evil,eval 是魔鬼。所以使用 eval 的时候要注意,性能低而且有安全风险。

new Function()

const name = '周小黑'
const age = 18

function fn(e) {
  let value = new Function('return ' + e)
  return value
}

const str = fn('name')
console.log(str)

对于函数我们平时都是直接用 function 或者箭头函数创建,不会用构造函数来创建函数,一般使用也是为了来动态创建函数,因为 new Function 最后一个参数是函数体字符串,这样我们就可以用来动态生成拼接,具体语法如下:

let func = new Function([arg1, arg2, ...argN], functionBody)

注意函数体中只能访问全局作用域,不能访问局部作用域。

setTimeout

定时器 setTimeout 的第一个参数我们平时都是传一个函数,它其实也是可以传字符串进去的,在浏览器中是可以正常执行的,在node环境中会报错。

实际上浏览器中也是不推荐这么用的,另外需要注意的是字符串中的变量只能访问全局作用域,不能访问局部作用域,如果全局作用域中没有,就是 undefined。

const name = '周小黑'
const age = 18

let value
setTimeout('value = name')
setTimeout(() => {
  console.log(value)
})

相关推荐

一文揭秘领域驱动设计(DDD):领域和子域

★★★建议星标我们★★★2020年Java原创面试题库连载中...

DDD领域驱动设计最全详解(图文全面总结)

DDD领域驱动设计是现在非常火热的设计架构,而且大厂面试也经常考察,下面我就全面来详解DDD领域驱动设计@mikechen本篇已收于mikechen原创超30万字《...

领域驱动设计(Domain-Driven Design)的关键概念

领域驱动设计(Domain-DrivenDesign,DDD)是一种软件开发方法,旨在通过深刻理解业务领域来构建复杂的系统。在DDD中,开发者与领域专家密切合作,共同定义业务逻辑,并通过模型表达领...

终于有人把安卓程序员必学知识点全整理出来了,有如醍醐灌顶

阅读前请点击右上角“关注”,每天免费获取Android知识解析及面试解答。Android架构解析,只做职场干货,完全免费分享!Java相关无论什么级别的Android从业者,Java作为Android...

[Android开发]使用观察者的正确姿势

前言首先先问一个问题,你在做Android开发的时候有没有被传值整的蒙圈?例如Fragment之间的传值,Activity之间的传值(ActivityForResult比较常用),Fragment与A...

大厂永恒敲门砖——Android 系统启动流程详解

...

Android音频开发:如何采集一帧音频

AndroidSDK提供了两套音频采集的API,分别是:MediaRecorder和AudioRecord,前者是一个更加上层一点的API,它可以直接把手机麦克风录入的音频数据进行编码压缩(如...

安卓手机怎么录屏?这三种方法你还不会用么?

手机录屏指的是使用手机的录屏功能,将屏幕上的内容进行录制,保存为视频文件,以供后续观看或分享。使用手机录屏功能,可以方便地将手机屏幕上的任何内容进行录制,无论是游戏操作、软件教程、视频播放等,只需要点...

网易视频云技术分享:Android 消息机制学习

Android消息机制大家都不陌生,想必大家也都看过Handler、Looper的源码(看过可以直接看末尾重点,一款监控APP卡顿情况的控件),下面,网易视频云技术专家就整合一下这方面的资料,加深对这...

2021年四大流行Android手机自动化测试工具,全在这里了

Android自动化测试的工具非常多,但是目前主流使用的就那几个,我会详细说明他们各自的情况,你可以根据自己的需要决定使用哪款工具。...

好程序员Android培训 122天炼成技术达人稳赚高薪

好程序员从课程研发到开班至今,历经一年的时间,专注Android和iOS开发高端人才培养,目前已经毕业的三期学员,从平均薪资的11000到三期的16000,薪资记录在行业内遥遥领先。面对如此“诱人”的...

娃哈哈基课堂第3课。安卓手机的盲人模式深度讲解

上一节课我们说了苹果手机的盲人模式如何设置?今天我们通过长文的方式来讲解安卓手机的盲人设置是如何设置的,所有的安卓手机盲人模式都是通用的,但是有一些手机因为优化系统的问题无法通用,或者有些手机直接把安...

android培训学习的大纲 android软件开发培训

第一阶段android基础:1.基础javaJava概述,进制,数据类型,常量变量,运算符,表达式关系运算符,逻辑运算符,if语句,switch语句while循环,do...while循环,for循环...

Android Jetpack从入门到精通(深度好文,值得收藏)

阅读前请点击右上角“关注”,每天免费获取Android知识解析及面试解答。Android架构解析,只做职场干货,完全免费分享!前言即学即用AndroidJetpack系列Blog的目的是通过学习An...

小技巧:安卓苹果都有!这份玩机的教程,我愿称为最强

从提起适老化这个概念到现在,能真正感受到的,可能只是App上的一个按钮。...