有没有办法将 JavaScript 字符串作为某些函数执行?我正在使用 eval 但它不起作用
Is there a way to execute a JavaScript string as some functions? I'm using eval but it is not working
有没有办法将 JavaScript 字符串作为某些函数来执行?我正在使用 eval
但它不起作用。
我正在尝试这个,因为我需要从 YML 文件中读取值以进行 serenity js 测试。
这就是我想要做的
this.data = "element1.element2"
this.test1 = "safeLoad(readFileSync(`config/${this.fileName}.yml`, 'utf8'))";
console.log(this.test1)
console.log(`${this.test1}.${this.data}`);
这就是我尝试执行字符串的方式
eval(`${this.testabc}.${this.data}`)
但是,当我执行此操作时,出现以下错误:
ReferenceError: safeLoad is not defined
P.S.: 如果我正常执行代码(没有评估)它工作正常!
safeLoad(readFileSync(`config/${this.fileName}.yml`, 'utf8')).element1.element2
有谁知道如何将这样的代码作为字符串执行?
我猜你 import safeLoad
使用 es6 语法。
如果是,当你使用babel
转译代码时,safeLoad
将被省略。因为通过 safeLoad 的转译器不会在您的代码中使用。
了解请看下面图片,或this babel example.
要解决这个问题,您应该使用 require
而不是 import(es6)
:
// instead of
import safeLoad from 'safeLoad'
// use this:
const safeLoad = require('safeLoad').default
// instead of
import { safeLoad } from 'safeLoad'
// use this:
const { safeLoad } = require('safeLoad')
有没有办法将 JavaScript 字符串作为某些函数来执行?我正在使用 eval
但它不起作用。
我正在尝试这个,因为我需要从 YML 文件中读取值以进行 serenity js 测试。
这就是我想要做的
this.data = "element1.element2"
this.test1 = "safeLoad(readFileSync(`config/${this.fileName}.yml`, 'utf8'))";
console.log(this.test1)
console.log(`${this.test1}.${this.data}`);
这就是我尝试执行字符串的方式
eval(`${this.testabc}.${this.data}`)
但是,当我执行此操作时,出现以下错误:
ReferenceError: safeLoad is not defined
P.S.: 如果我正常执行代码(没有评估)它工作正常!
safeLoad(readFileSync(`config/${this.fileName}.yml`, 'utf8')).element1.element2
有谁知道如何将这样的代码作为字符串执行?
我猜你 import safeLoad
使用 es6 语法。
如果是,当你使用babel
转译代码时,safeLoad
将被省略。因为通过 safeLoad 的转译器不会在您的代码中使用。
了解请看下面图片,或this babel example.
要解决这个问题,您应该使用 require
而不是 import(es6)
:
// instead of
import safeLoad from 'safeLoad'
// use this:
const safeLoad = require('safeLoad').default
// instead of
import { safeLoad } from 'safeLoad'
// use this:
const { safeLoad } = require('safeLoad')