Node.js 中的 assert.strictEqual() 函数
assert模块提供了一系列用于函数断言的不同功能。assert.strictEqual用于检查两个对象或参数之间的相等性。如果两个对象不相等,它将抛出断言错误。
语法
assert.strictEqual(actual, expected[, message])
参数
上述参数描述如下-
实际 -这是将根据预期参数评估的实际值。
预期 -这是与实际值匹配的预期参数值。
message –如果实际参数和预期参数不匹配,则此参数保存要打印的字符串消息值。它是一个可选字段。
安装断言模块
npm install assert
assert模块是一个内置Node.js模块,因此您也可以跳过此步骤。您可以使用以下命令检查断言版本以获取最新的断言模块。
npm version assert
在您的函数中导入模块
const assert = require("assert");
示例
创建一个具有名称的文件-assertStrictEqual.js并复制以下代码片段。创建文件后,使用以下命令运行此代码。
node assertStrictEqual.js
assertStrictEqual.js
//导入模块 const assert = require('assert').strict; var a = "nhooo"; var b = "nhooo"; try { //调用equal函数检查相等性 assert.strictEqual(a, b); console.log("Actual and expected parameters are equal") } catch(error) { console.log("Error: ", error) }输出结果
C:\home\node>> node assertStrictEqual.js Actual and expected parameters are equal
我们可以在上面的例子中看到两个值严格相等。
示例
让我们再看一个例子。
//导入模块 const assert = require('assert').strict; var a = "Welcome to nhooo"; var b = "nhooo"; try { //调用equal函数检查相等性 assert.strictEqual(a, b); console.log("Actual and expected parameters are equal") } catch(error) { console.log("Error: ", error) }输出结果
C:\home\node>> node assertStrictEqual.js Error: { AssertionError [ERR_ASSERTION]: Input A expected to strictly equal input B: + expected - actual - 'Welcome to nhooo' + 'nhooo' at Object. (/home/node/test/assert.js:9:9) atModule._compile(internal/modules/cjs/loader.js:778:30) at Object.Module._extensions..js (internal/modules/cjs/loader.js:789:10) atModule.load(internal/modules/cjs/loader.js:653:32) at tryModuleLoad (internal/modules/cjs/loader.js:593:12) at Function.Module._load (internal/modules/cjs/loader.js:585:3) at Function.Module.runMain (internal/modules/cjs/loader.js:831:12) at startup (internal/bootstrap/node.js:283:19) at bootstrapNodeJSCore (internal/bootstrap/node.js:623:3) generatedMessage: true, name: 'AssertionError [ERR_ASSERTION]', code: 'ERR_ASSERTION', actual: 'Welcome to nhooo', expected: 'nhooo', operator: 'strictEqual' }
在上面的例子中,我们可以看到两个值不相等。因此,断言strictEqual()方法抛出了断言错误。