当前位置:首页 > AI技术 > 正文内容

JavaScript进阶:中使递归嵌套括号并现区间逻辑判断的整方案案例 |Duuu笔记

admin1个月前 (04-22)AI技术119

在生产环境中优化JavaScript,本文分析

本文介绍一种将自定义区间表达式(如 0...100 & [70...80, 0...100] & 30...50)安全、可扩展地转换为可执行 javascript 逻辑的方法,支持任意深度嵌套方括号 [...],无需手动递归解析,兼顾简洁性与健壮性。

本文介绍一种将自定义区间表达式(如 0...100 & [70...80, 0...100] & 30...50)安全、可扩展地转换为可执行

javascript

逻辑的方法,支持任意深度嵌套方括号 [...],无需手动递归解析,兼顾简洁性与健壮性。

在实际业务中,我们常需用简洁字符串描述复杂的数值范围条件(例如权限阈值、配置校验规则等),如 "0...100 & [70...80, 0...100] & 30...50"——它语义为:“数值必须同时满足:在 0–100 内,且(在 70–80 或 0–100 中),且在 30–50 内”。这类表达式天然具备嵌套结构,若强行用正则+循环逐层提取括号内容(如原问题中尝试的 depthPerIndex 手动栈管理),极易因边界错位、转义遗漏或优先级混乱而失败。

更优解是

语义转换法

:不直接“解析括号”,而是将整个字符串按预定义规则

重写为合法 JavaScript 表达式

,再通过受控方式求值。该方案规避了手工递归的复杂性,同时天然支持任意嵌套层级(因为 JS 引擎自身负责括号匹配与运算符优先级)。

以下是核心实现:

刺鸟创客

一款专业高效稳定的AI内容创作平台

下载

const inRange = (num, str) => {

// 定义安全的语法映射规则(顺序敏感!)

const subs = [

['&', ' && '], // 逻辑与 → JS &&

[/(?<=(?:\D|^))\.\.\.(\d+)/g, 'num <= $1'], // "...100" → "num <= 100"

[/(\d+)\.\.\.(?=(?:\D|$))/g, 'num >= $1'], // "0..." → "num >= 0"

[/(\d+)\.\.\.(\d+)/g, '$1 <= num && num <= $2'], // "0...100" → "0 <= num && num <= 100"

[',', ' || '], // 逻辑或 → JS ||

['[', ' ( '], // 左括号 → 左圆括号(提升分组优先级)

[']', ' ) '] // 右括号 → 右圆括号

];

// 逐条应用替换规则

for (const [from, to] of subs) {

str = typeof from === 'string'

? str.replaceAll(from, to)

: str.replaceAll(from, to);

}

// 调试时可取消注释以查看生成的表达式

// console.log('Generated expression:', str);

try {

// 使用 Function 构造器动态编译(比 eval 更安全:无闭包污染、作用域隔离)

const fn = new Function('num', 'return ' + str);

return fn(num);

} catch (e) {

throw new Error(`Invalid range expression: "${str}" → ${e.message}`);

}

};

✅ 关键设计说明

替换顺序至关重要

:先处理 & 和 , 避免干扰 ... 的正则匹配;... 的三种变体需按「边界锚定」顺序(...N、N...、N...M)排列,防止误匹配;

括号处理极简有效

:[/] 直接映射为 ( ),利用 JS 原生运算符优先级实现逻辑分组,无需任何递归或栈操作;

安全性保障

:使用 new Function() 而非 eval(),确保执行环境纯净(无外部变量访问),且输入字符串仅参与表达式构建,不执行任意代码;

错误防御

:包裹 try/catch,对非法表达式(如括号不匹配、数字格式错误)提供清晰报错。

? 使用示例

console.log(inRange(75, "0...100 & [70...80, 0...100] & 30...50")); // false

console.log(inRange(75, "0...100 & [70...80, 0...100] & 60...90")); // true

console.log(inRange(5, "...10 & [2...8, 15...20]")); // true

⚠️ 注意事项

输入字符串中禁止出现未转义的单引号、反引号或换行符(否则破坏 Function 构造);

数值部分必须为纯数字(不支持科学计数法或负数前缀,如需扩展可增强正则);

若需支持更多运算符(如 ! 取反),应在 subs 中添加对应规则,并确保其优先级合理;

生产环境若对动态代码执行有严格限制,可改用

Acorn

等解析器做 AST 校验,但会显著增加复杂度。

此方案以“字符串即代码”的思维降维解决问题,将嵌套解析的算法难题转化为声明式语法映射,兼具可读性、可维护性与工程鲁棒性。

Java免费学习笔记(深入)

”;

标签: PHP编程技术

相关文章

LLM介绍

。LLM 被证明在使用指令形式化描述的未见过的任务上表现良好。这意味着 LLM 能够根据任务指令执行任务,而无需事先见过具体示例,展示了其强大的泛化能力。 :小型语言模型通常难以解决涉...

神经网络中的单层神经网络

神经网络是一种模拟人脑的神经网络以期能够实现类人工智能的机器学习技术。人脑中的神经网络是一个非常复杂的组织。成人的大脑中估计有1000亿个神经元之多。 看一个经典的神经网络。这是一个包...

AI高级应用:Perplexity 怎么写用户手册 Perplexity 产品帮助文档生成【技术】实战案例|Duuu笔记

Perplexity AI用户手册需基于API元数据、真实UI截图、典型场景示例、响应字段解析及动态调试指令五步构建:一调用API获取参数与错误码;二标注网页端搜索框、引用图标等组件;三设计信息检索、...

什么是AI+?什么是人工智能+?

一、人工智能(AI)的基本概念 要理解“AI+”,首先要明白人工智能的核心内涵。人工智能是一门让计算机系统具备人类智能能力的学科与技术体系,主要包含: :如图像识别、语音识别;...

AI核心技巧:WorkBuddy 怎么用沙盒隔离 WorkBuddy 沙盒安全隔离教程【进阶】深度解析|Duuu笔记

必须启用沙盒隔离机制以确保安全,WorkBuddy提供容器级、进程级与目录级三重隔离,具体包括:一、启用Claw Craft模式并强化日志与写入限制;二、显式授权多级目录并降权为只读;三、通过Open...

什么是人工智能?15分钟了解人工智能

理性行为:理性智能体方法 这4种方法有其必然的差异: 追求类人智能必须在某种程度上是与心理学相关的经验科学,包括对真实人类行为和思维过程的观察和假设; 而理性主义方法涉...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。