Angular - 将字符串解析为{{ dataObject + 变量 }},其中变量 = 'object?.key.something | pipe'
创始人
2024-10-14 18:30:12
0

要将字符串解析为表达式,可以使用Angular的内置解析器Parser。以下是一个示例代码,演示如何使用Parser解析字符串并将其转换为Angular表达式:

import { Component, OnInit } from '@angular/core';
import { Parser } from '@angular/compiler';

@Component({
  selector: 'app-example',
  template: `
    
解析结果: {{ parsedExpression }}
`, }) export class ExampleComponent implements OnInit { dataObject = 10; expression = '{{ dataObject + variable }}'; variable = 'object?.key.something | pipe'; parsedExpression: any; constructor(private parser: Parser) {} ngOnInit() { const context = { dataObject: this.dataObject, variable: this.variable }; const ast = this.parser.parseBinding(this.expression, null); const transformedAst = this.parser.visitAll(ast, new ExpressionTransformer(), context); const expression = this.parser.print(transformedAst); this.parsedExpression = expression; } } class ExpressionTransformer { visitPipe(pipe: any, context: any) { const name = pipe.name; const args = this.visitAll(pipe.args, context); return { name, args }; } visitLiteralPrimitive(literal: any, context: any) { return literal.value; } visitPropertyRead(prop: any, context: any) { const contextValue = context[prop.receiver.value]; const propertyName = prop.name; return contextValue[propertyName]; } visitMethodCall(method: any, context: any) { const args = this.visitAll(method.args, context); return context[method.name](...args); } visitAll(nodes: any[], context: any) { return nodes.map(node => this.visit(node, context)); } visit(node: any, context: any) { if (typeof this[node.type] === 'function') { return this[node.type](node, context); } return node; } }

在上面的示例中,我们使用Parser解析字符串expression并将其转换为AST(抽象语法树)。然后,我们使用自定义的ExpressionTransformer访问器类来遍历AST并根据上下文计算表达式的值。最后,我们将转换后的表达式打印出来并将其显示在模板中。

请注意,上述示例中使用了Parser,它是Angular的内部类,因此需要将其导入到组件中。另外,还需要引入@angular/compiler模块。

希望这可以帮助到您!

相关内容

热门资讯

必备透视!wpk透视插件,wp... 必备透视!wpk透视插件,wpk软件是正规的吗,真是一直都是有辅助插件(哔哩哔哩)1、免费辅助多个强...
教你透视!wpk控制牌是真的吗... 教你透视!wpk控制牌是真的吗,wpk透视是真的吗,确实是有辅助软件(哔哩哔哩);1、游戏颠覆性的策...
揭露透视!wepoker私人局... 揭露透视!wepoker私人局开挂视频,wepoker私局代打,一贯真的有辅助方法(哔哩哔哩)1、脚...
科普透视!wpk有那种辅助吗,... 科普透视!wpk有那种辅助吗,wpk透视是真的假的,确实是真的有辅助攻略(哔哩哔哩)1、透视辅助软件...
有挂透视!德普之星透视辅助软件... 有挂透视!德普之星透视辅助软件,德普软件,都是一直都是有辅助app(哔哩哔哩)1、每一步都需要思考,...
科普透视!wpk俱乐部有没有辅... 科普透视!wpk俱乐部有没有辅助,如何判断wpk辅助软件的真假,本来是真的有辅助攻略(哔哩哔哩)1、...
解迷透视!htx矩阵wepok... 解迷透视!htx矩阵wepoker辅助,wepoker有没有挂,其实一直都是有辅助脚本(哔哩哔哩)1...
专业透视!wpk插件,wpk俱... 专业透视!wpk插件,wpk俱乐部辅助器,一贯有辅助攻略(哔哩哔哩)1. 选牌创建新账号,点击进入游...
有挂透视!wpk软件是正规的吗... 有挂透视!wpk软件是正规的吗,有哪些免费的wpk作比弊码,原来存在有辅助软件(哔哩哔哩)小薇(辅助...
普及透视!德普之星有辅助软件吗... 普及透视!德普之星有辅助软件吗,德普之星透视辅助软件是真的吗,竟然存在有辅助工具(哔哩哔哩)1、首先...