从生成器中获取生成器函数的名称
Get the generator function's name from a generator
在 Javascript 中,给定一个生成器对象,如何让它输出返回该生成器对象的生成器函数的名称?
换句话说:
function* thisIsMyName(i) {
yield i;
}
const gen = thisIsMyName(10);
console.log(gen.name); // How do I get this to output "thisIsMyName" using only the gen object?
调用 gen.name
无效,因为它不是 function but a generator object
来自评论:
You would need to create an intermediate factory that passed a reference to the function as well as the returned generator object
不是很有用,但可能类似于:
const someGenerator = {
*thisIsMyName(i = 1, limit = 10) {
while (i < limit) {
yield i++;
}
},
get name() {return this.thisIsMyName.name},
};
const myGen = { name: someGenerator.name, i: someGenerator.thisIsMyName(15, 20)};
console.log(myGen.i.next().value, myGen.name);
或者...
function createGenerator(name, min = 1, max = 10) {
function* xGen() {
while (min < max) {
yield min++;
}
};
return {gen: xGen(), name,};
};
const myGen = createGenerator(`myName`, 15, 20);
const values = [];
let nxt = {};
while (!nxt.done) {
nxt = myGen.gen.next();
!nxt.done && values.push(nxt.value);
}
console.log(values.join(`, `), `\nmyGen.name = '${myGen.name}'`);
恐怕您不能那样访问它,因为对生成此生成器的函数的引用存储在由符号定义的 属性 中。符号是唯一的,无法重新创建(但一直很疯狂,请参阅 Symbol.for
)。这意味着如果您没有对符号的引用,您将无法获得它的值。
Object.getOwnPropertySymbols()
不是 return 原生的。
检查实例时,您可以在控制台中看到符号道具:
不过,您可以使用包装函数解决此问题,这意味着一个函数将 return 生成器和生成器函数:
function thisIsMyName(value){
const generatorFunction = function* thisIsMyName(i) {
yield i;
}
return {
generator : generatorFunction(value),
generatorFunction: generatorFunction
}
}
const gen = thisIsMyName(10);
console.log(gen.generatorFunction.name) // prints thisIsMyName
console.log(gen.generator.next()) // prints {value: 10, done: false}
在 Javascript 中,给定一个生成器对象,如何让它输出返回该生成器对象的生成器函数的名称?
换句话说:
function* thisIsMyName(i) {
yield i;
}
const gen = thisIsMyName(10);
console.log(gen.name); // How do I get this to output "thisIsMyName" using only the gen object?
调用 gen.name
无效,因为它不是 function but a generator object
来自评论:
You would need to create an intermediate factory that passed a reference to the function as well as the returned generator object
不是很有用,但可能类似于:
const someGenerator = {
*thisIsMyName(i = 1, limit = 10) {
while (i < limit) {
yield i++;
}
},
get name() {return this.thisIsMyName.name},
};
const myGen = { name: someGenerator.name, i: someGenerator.thisIsMyName(15, 20)};
console.log(myGen.i.next().value, myGen.name);
或者...
function createGenerator(name, min = 1, max = 10) {
function* xGen() {
while (min < max) {
yield min++;
}
};
return {gen: xGen(), name,};
};
const myGen = createGenerator(`myName`, 15, 20);
const values = [];
let nxt = {};
while (!nxt.done) {
nxt = myGen.gen.next();
!nxt.done && values.push(nxt.value);
}
console.log(values.join(`, `), `\nmyGen.name = '${myGen.name}'`);
恐怕您不能那样访问它,因为对生成此生成器的函数的引用存储在由符号定义的 属性 中。符号是唯一的,无法重新创建(但一直很疯狂,请参阅 Symbol.for
)。这意味着如果您没有对符号的引用,您将无法获得它的值。
Object.getOwnPropertySymbols()
不是 return 原生的。
检查实例时,您可以在控制台中看到符号道具:
不过,您可以使用包装函数解决此问题,这意味着一个函数将 return 生成器和生成器函数:
function thisIsMyName(value){
const generatorFunction = function* thisIsMyName(i) {
yield i;
}
return {
generator : generatorFunction(value),
generatorFunction: generatorFunction
}
}
const gen = thisIsMyName(10);
console.log(gen.generatorFunction.name) // prints thisIsMyName
console.log(gen.generator.next()) // prints {value: 10, done: false}