- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试为模块声明和初始化一个具有全局范围的 const 变量,它需要从异步/等待的结果中获取值。这是我试过的代码,变量仍然未定义。我怎样才能重写这个,这样我仍然可以使用一个常量并且它包含所需的值:
const puppet = require('puppeteer')
const browser = (async () => { await puppet.launch() })();
const page = (async () => { await browser.newPage() })();
console.log( "browser holds: " + util.inspect(page) );
// prints out undefined
我需要设置两个单独的页面,这两个页面将在整个应用程序中用于加载不同的页面并根据需要进行处理。
现在,我可以通过将变量声明为“var”然后在 .then() 中赋值来实现这一点。但我更愿意为这些使用“const”作为最佳实践。
下面是允许我将此作为 var 执行并在整个应用程序中使用它的代码:
const puppet = require('puppeteer')
async function setupNewPuppetWithKeys(puppetBrowser, puppetPage ){
let browser = await puppet.launch();
let page = await browser.newPage();
page.setViewport({ width: 1280, height: 800 });
logger.infoLog("initialized values for - " + puppetBrowser + ", " + puppetPage )
return { [puppetBrowser] : browser , [puppetPage] : page };
}
var browserDev, pageDev;
setupNewPuppetWithKeys("browserDev", "pageDeV").then( (jsonResult) => {
logger.infoLog("In Then received : " + util.inspect(jsonResult) );
browserDev = jsonResult.browserDev;
pageDev = jsonResult.pageDev;
} );
// I declare more browser and page variables here .. but you get the idea with the one I've done above.
最佳答案
我在 node.js 上遇到了同样的问题,找不到答案,但后来尝试了这种技术,如果您使用的是 node.js,这可能会有所帮助。
诀窍是在异步函数内的global
对象上定义只读变量。该函数完成后,其他代码可以在整个应用程序中直接访问具有全局范围的变量。
这是一个说明该方法的测试脚本。如果有人有更简单的解决方案,我很想知道。
"use strict";
// Utility function to set a constant value on the global object
function setGlobalConst(constName, constValue){
console.log(` >> setGlobalConst ${constName} `);
if( typeof global[constName] !== "undefined" )
throw new Error(`Attempt to redefine global const ${constName}`);
Object.defineProperty(global, constName, { value: constValue, writable: false });
};
// This is the setter function for the global const ABC
// Note this does not need to be async, it returns a promise
// synchronously
function setABC () {
// Check for the global promise to set the value of ABC
if(typeof global.prmABC === "undefined" ){
console.log(" >> setABC called for the first time")
// Create the promise that will set the value of ABC some
// time in the future;
let setterPromise =
(
async function(){
await delay(2000);
setGlobalConst("ABC", "[VALUE OF ABC]");
console.log(" >> setter: global const ABC has now been set")
return ABC;
}
)()
// Save this promise in the global setter promise const prmABC
setGlobalConst("prmABC", setterPromise );
// Return the promise, which will resolve when ABC has been set
return setterPromise;
};
// As this has previously been called, we just
// need to return the promise that was previously
// saved in the global const prmABC.
console.log(" >> setABC has already been called")
return prmABC;
};
// Application code - this is async to ensure that
// it waits for the ABC setter to resolve before accessing
// the global const ABC.
async function run( ){
console.log(` 1. Before setting, global ABC=${global.ABC}`);
console.log(" 2. Calling setABC without waiting");
setABC();
console.log(` 3. Before setter has resolved, global ABC still =${global.ABC}`)
try{
console.log(" 4. Waiting on the original global setter promise.. delay here...:");
let myABC1 = await prmABC;
// The value returned by the resolved prmABC is the value of global const ABC
console.log(` 4a. >> Resolved value of global prmABC=${myABC1}`);
// Also, now that the setter promise is fulfilled, the global const ABC is set
console.log(` 4b. >> Global const ABC=${ABC}`);
console.log(" 5. We can also get the value of ABC by waiting on a call to setABC()");
let myABC2 = await setABC();
console.log(` 5a. >> Value returned from resolved setABC() is ${myABC2}`);
console.log(` 7. Accessing value of ABC directly: ABC=${ABC}`);
} catch(e) {
console.log(` ERROR: ${e.message}`)
};
console.log(" 8. Calling setABC() again, after it has finished, without waiting");
setABC();
console.log(` 9. Accessing value of global const ABC again: ABC=${ABC}`);
try{
console.log(" 10. Attempting to change value of ABC directly")
ABC = "New value of ABC";
} catch(e) {
console.log(` ERROR: ${e.message}`)
};
console.log(" Run finished---------------------------------");
};
run();
// Small utility function to provide async promise
function delay(ms) {
return new Promise(resolve => setTimeout(resolve, ms));
}
这段代码的控制台输出是:
test> node testConstWithAsync
1. Before setting, global ABC=undefined
2. Calling setABC without waiting
>> setABC called for the first time
>> setGlobalConst prmABC
3. Before setter has resolved, global ABC still =undefined
4. Waiting on the original global setter promise.. delay here...:
>> setGlobalConst ABC
>> setter: global const ABC has now been set
4a. >> Resolved value of global prmABC=[VALUE OF ABC]
4b. >> Global const ABC=[VALUE OF ABC]
5. We can also get the value of ABC by waiting on a call to setABC()
>> setABC has already been called
5a. >> Value returned from resolved setABC() is [VALUE OF ABC]
7. Accessing value of ABC directly: ABC=[VALUE OF ABC]
8. Calling setABC() again, after it has finished, without waiting
>> setABC has already been called
9. Accessing value of global const ABC again: ABC=[VALUE OF ABC]
10. Attempting to change value of ABC directly
ERROR: Cannot assign to read only property 'ABC' of object '#<Object>'
Run finished---------------------------------
关于node.js - 在为全局 const 变量赋值时使用 Async/await,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60863519/
你能解释一下这个作业是如何完成的吗, var fe, f = document.forms[0], h; 哪个等于哪个。 最佳答案 以上等同于 var fe; var f = document.for
据我测试,这两种方法都有效,但我不知道哪一种最好,也不知道它们之间的区别,这就是我想知道的。 以下是两种方法: window.location = 'http://www.google.com'; w
我正在处理用字符串填充的 numpy 数组。我的目标是分配给第一个数组 a 的切片,值包含在较小尺寸的第二个数组 b 中。 我想到的实现如下: import numpy as np a = np.em
在我使用过的其他语言(如 Erlang 和 Python)中,如果我正在拆分字符串并且不关心其中一个字段,我可以使用下划线占位符。我在 Perl 中试过这个: (_,$id) = split('
我认为这似乎很简单,但我对调用、应用、绑定(bind)感到困惑。等等 我有一个事件监听器 red.addEventListener("click", function() { j = 0;
这个问题在这里已经有了答案: What is the python "with" statement designed for? (11 个答案) 关闭 7 年前。 使用有什么区别: iFile =
这个问题在这里已经有了答案: What is the python "with" statement designed for? (11 个答案) 关闭 7 年前。 使用有什么区别: iFile =
几周前我们开始写一篇关于 Haskell 的论文,刚刚接到我们的第一个任务。我知道 SO 不喜欢家庭作业问题,所以我不会问怎么做。相反,如果有人能将我推向正确的方向,我将不胜感激。鉴于它可能不是一个特
我正在尝试为我的函数的变量根分配一个值,但似乎不起作用。我不明白这个问题。 hw7.c:155:7:警告:赋值使指针来自整数而不进行强制转换[默认启用] root = 负载(&fp, 大小); 此代码
我昨天花了大约 5 个小时来完成这个工作,并使用这个网站的帮助让代码可以工作,但我认为我这样做的方式是一种作弊方式,我使用了 scanf 命令。无论如何,我想以正确的方式解决这个问题。多谢你们!哦,代
我需要一些帮助来解决问题。 我有这个文本文件: 我将文本内容输入到字符串二维数组中,并将其转换为整数二维数组。当我转换为 int 数组时,nan 被替换为零。现在,我继续查找二维数组中每行的最大值和最
假设我有一个只能移动的类型。我们停止现有的默认提供的构造函数,但 Rvalue 引用引入了一种新的“ flavor ”,我们可以将其用于签名的移动版本: class CantCopyMe { priv
假设我有两个简单的对象,我想创建第三个对象来连接它们的属性。这非常有效: (()=>{ const a1 = {a: 2, b: 3} const b1 = {a: 100, c: 5}
我想知道我是否可以稍后在这样的代码中为 VAR 赋值 var myView: UIView func createView() { myView = UIView() { let _view =
我遇到了一些 Javascript/HTML/CSS 代码的问题。我对创建网站还很陌生,所以请多多包涵。 我最终想做的是从 javascript 中提取一个动态值并使用它对一些 div(在容器中)进行
#include class Box{ public: int x; Box(){ x=0; std::cout No move construction thanks to RV
我发现在javascript中&=运算符是按位赋值: var test=true; test&=true; //here test is an int variable javascript中是否存在
请帮助完成赋值重载函数的执行。 这是指令: 赋值运算符 (=),它将源字符串复制到目标字符串中。请注意,目标的大小需要调整为与源相同。 加法 (+) 和赋值 (=) 运算符都需要能够进行级联运算。这意
我有一个名为 SortedArrayList 的自定义结构它根据比较器对其元素进行排序,我想防止使用 operator[] 进行分配. 示例: 数组列表.h template class Array
我是 python 的新手,我看到了这种为列表赋值的形式 color= ['red' if v == 0 else 'green' for v in y] 但是如果我尝试用 3 个数字来做,例如 co
我是一名优秀的程序员,十分优秀!