• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

129
Views
Cómo construir una función del diccionario que contiene el nombre de la función y los argumentos mecanografiados

estoy teniendo un diccionario

 { "function_name":"myFunc", "arguments":["a1","a2"] }

Quiero construir una función donde el nombre de la función sea el nombre de la función que está presente en el diccionario anterior (es decir, myFunc) con los argumentos respectivos (es decir, ["a1","a2"]).

La salida final del generador debe ser:

 myFunc(a1,a2){ }

Uso real: quiero agregar esta función a una instancia de clase e invocarla

y extendiendo esto.

Si esta función es asíncrona, debería poder esperarla.

Ejemplo:

para que un contrato inteligente llame a una función que generalmente hacemos (Refiriéndose al contrato inteligente de bienvenida)

 contract.functions.greet().then(k => console.log(k))

El tipo de función del contrato es:

 readonly functions: { [ name: string ]: ContractFunction }; export type ContractFunction<T = any> = (...args: Array<any>) => Promise<T>;

utilizando la biblioteca de éteres.

Quería generar la función de saludo usando el contrato ABI dinámicamente:

 [ { "inputs": [ { "internalType": "string", "name": "_greeting", "type": "string" }, ], "stateMutability": "nonpayable", "type": "constructor" }, { "inputs": [], "name": "greet", "outputs": [ { "internalType": "string", "name": "", "type": "string" } ], "stateMutability": "view", "type": "function" }, { "inputs": [ { "internalType": "string", "name": "_greeting", "type": "string" } ], "name": "setGreeting", "outputs": [], "stateMutability": "nonpayable", "type": "function" } ]

Puedo analizar el JSON anterior y obtener el nombre y los argumentos de la función. Ahora, como paso final, quiero adjuntar esta función construida al contrato y llamarlo.

about 3 years ago · Juan Pablo Isaza
2 answers
Answer question

0

Supongo que estás tratando de hacer algo como lo siguiente:

 class SomeClass { obj = { functionName: "add", args: [10, 20], }; add(a, b) { return a + b; } invokeFunc() { const { functionName, args } = this.obj; return this[functionName](...args); } } const instance = new SomeClass(); console.log(instance.invokeFunc());

Dado que la función a invocar es accesible desde this objeto, puede invocarla y difundir (...) todos los argumentos.

Para las funciones async , no está claro cómo se indica que es una función async . Puede tener un campo de type en el objeto y await condicionalmente la función.

about 3 years ago · Juan Pablo Isaza Report

0

Aquí hay un ejemplo de cómo hacer esto.

lea aquí https://www.c-sharpcorner.com/article/creating-functions-dynamically-in-javascript/ ya que esto podría ayudarlo

 var strFunc = [{ "isAsync":false, "function_name": "myFunc", "arguments": ["a1", "a2"], content: "return a1*a2" }, { "isAsync":true, "function_name": "asyncMyFunc", "arguments": ["a1", "a2"], content: "return a1+a2" }] class Funcs { constructor(f){ const AsyncFunction = Object.getPrototypeOf(async function(){}).constructor; f.forEach(x=> { let func = null; if (x.isAsync) func = new AsyncFunction(...x.arguments, x.content); else func = new Function(...x.arguments, x.content); this[x.function_name] = func; }); } } var mycl = new Funcs(strFunc); mycl.asyncMyFunc(1,2).then(x=> console.log("asyncFunc", x)) console.log("syncFunc", mycl.myFunc(1,2));

about 3 years ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error