Node-RED UI 模板中脚本内动态数据传递与管理


node-red ui 模板中脚本内动态数据传递与管理

本文旨在解决Node-RED UI模板中,无法直接使用Mustache语法在`<script>`标签内动态注入J*aScript代码的问题。我们将阐述其根本原因,并提供两种安全有效的解决方案:一是通过`$scope.msg`直接访问传递的数据,二是通过Mustache结合`| <a style="color:#f60; text-decoration:underline;" title= "js"href="https://www.php.cn/zt/15802.html" target="_blank">json`过滤器将数据渲染为J*aScript变量。此外,文章还将探讨将UI模板封装为子流(Subflow)的实践,以实现模板的复用与集中管理。</script>

理解Node-RED UI模板中的Mustache渲染机制

在Node-RED的UI模板(ui_template)节点中,Mustache语法(例如 {{msg.payload}})是在Node-RED服务器端进行渲染的。这意味着当Node-RED处理该节点时,它会用当前msg对象中的值替换所有的Mustache占位符,然后将生成的HTML内容(包括其中的<script>标签)发送到用户的<a style="color:#f60; text-decoration:underline;" title= "浏览器"href="https://www.php.cn/zt/16180.html" target="_blank">浏览器。浏览器接收到这些内容后,才会解析并执行其中的J*aScript代码。</script>

因此,尝试在<script>标签内部直接使用 {{msg.payload.ranges1}} 来注入一段J*aScript代码(如 high = 88; mid = 65; low = 60; size= "0.9em";)是行不通的。Mustache引擎会将其视为字符串进行替换,如果替换后的内容不符合J*aScript语法结构,或者期望它直接执行,就会导致错误或行为不符预期。Mustache主要用于数据绑定和内容替换,而非代码注入。</script>

正确地将动态数据传递到J*aScript脚本

要将msg.payload中的动态数据传递到UI模板内的J*aScript脚本中,应遵循将数据作为变量传递,而非代码片段传递的原则。以下是两种推荐的方法:

方法一:通过 $scope.msg 直接访问数据

Node-RED UI模板的J*aScript上下文会自动将当前的msg对象绑定到 $scope.msg。因此,如果您的动态数据作为对象或特定属性存在于msg.payload中,可以直接在脚本中访问它。

示例: 假设您的 msg.payload.ranges1 是一个包含范围值的J*aScript对象,例如: msg.payload.ranges1 = { high: 88, mid: 65, low: 60, size: "0.9em" };

您可以在UI模板的脚本中这样访问:

<script>
    (function($scope) {
        // 监听Node-RED发送的msg变化
        $scope.$watch('msg', function() {
            if ($scope.msg && $scope.msg.topic === "temperature_*g") {
                // 直接从$scope.msg.payload中获取数据
                var ranges = $scope.msg.payload.ranges1;

                if (ranges) { // 确保ranges存在
                    var high = ranges.high;
                    var mid = ranges.mid;
                    var low = ranges.low;
                    var size = ranges.size;

                    // 在这里使用 high, mid, low, size 变量
                    console.log("Temperature Ranges:", { high, mid, low, size });
                    // 例如,更新UI元素
                    // document.getElementById('tempHigh').innerText = high;
                }
            }
        });
    })(scope);
</script>

这种方法是最直接和推荐的,因为它利用了Node-RED UI模板的内置数据绑定机制。

方法二:使用 Mustache 渲染为 J*aScript 变量(带 | json 过滤器)

如果需要将数据渲染到一个客户端J*aScript变量中,并且该数据是复杂的对象或数组,使用 | json Mustache过滤器可以确保数据被正确地序列化为JSON字符串,并在客户端J*aScript中解析。

AI at Meta AI at Meta

Facebook 旗下的AI研究平台

AI at Meta 72 查看详情 AI at Meta

示例: 假设 msg.payload.ranges1 仍然是: msg.payload.ranges1 = { high: 88, mid: 65, low: 60, size: "0.9em" };

您可以在UI模板中这样设置:

<script>
    (function($scope) {
        // 在此处声明一个全局或局部变量,并使用Mustache渲染数据
        // {{msg.payload.ranges1 | json}} 会被替换成 {"high":88,"mid":65,"low":60,"size":"0.9em"}
        var dynamicRanges = {{msg.payload.ranges1 | json}};

        // 监听Node-RED发送的msg变化
        $scope.$watch('msg', function() {
            if ($scope.msg && $scope.msg.topic === "temperature_*g") {
                // 如果需要每次msg更新都获取最新值,可以再次从$scope.msg获取
                // 否则,dynamicRanges变量在页面加载时就已经初始化
                var currentRanges = $scope.msg.payload.ranges1 || dynamicRanges; // 优先使用最新msg,否则使用初始值

                if (currentRanges) {
                    var high = currentRanges.high;
                    var mid = currentRanges.mid;
                    var low = currentRanges.low;
                    var size = currentRanges.size;

                    console.log("Temperature Ranges (from rendered variable):", { high, mid, low, size });
                    // ... 在这里使用变量
                }
            }
        });
    })(scope);
</script>

注意事项:

  • | json 过滤器至关重要,它将J*aScript对象转换为有效的JSON字符串,防止语法错误。
  • dynamicRanges 变量在页面加载时初始化一次。如果msg频繁更新且您需要反映最新的数据,仍然建议在$scope.$watch('msg', ...)回调中访问$scope.msg.payload。

利用子流(Subflow)实现UI模板的复用与管理

虽然上述方法解决了动态数据传递的问题,但如果您的流程中包含多个相似的UI模板,并且希望集中管理它们的结构或默认值,将UI模板封装成子流(Subflow)是一个非常有效的架构实践。

子流的优势:

  1. 复用性: 创建一个包含ui_template节点的子流后,您可以在多个不同的流程中多次实例化这个子流。
  2. 集中管理: 对子流内部的任何修改(包括UI模板的HTML、CSS或J*aScript代码),都会自动应用到所有使用了该子流的实例中。这极大地简化了维护工作。
  3. 参数化: 子流可以配置输入和输出端口,甚至可以定义环境变量,允许每个子流实例接收不同的配置或数据,从而增强灵活性。

如何操作:

  1. 创建子流: 在Node-RED编辑器中,选择您希望封装的ui_template节点(及其可能相关的function或change节点),右键点击并选择 "创建子流"。
  2. 配置子流:
    • 为子流命名并添加描述。
    • 在子流属性中,您可以定义输入端口(例如,接收msg.payload.ranges1)。
    • 可以在子流的ui_template节点内部继续使用上述方法一或方法二来处理传入的动态数据。
  3. 使用子流: 创建子流后,它会出现在节点面板的 "子流" 分类下,您可以像使用普通节点一样将其拖放到任何流程中。每个子流实例都可以接收独立的msg,从而实现动态配置。

子流与数据传递的关系: 将UI模板放入子流并不能直接解决Mustache在脚本中注入代码的问题。它解决的是模板本身的复用和管理问题。每个子流实例仍然需要通过其输入端口接收msg,然后子流内部的ui_template节点再按照上述方法正确地从$scope.msg中提取动态数据。

总结

在Node-RED UI模板中,Mustache语法是用于服务器端渲染的,主要用于数据绑定和内容替换。直接在<script>标签内使用Mustache注入J*aScript代码片段是不可行的。正确的做法是将动态数据作为变量传递,并通过$scope.msg在客户端J*aScript中访问,或者使用| json过滤器将数据安全地渲染为J*aScript变量。此外,通过将UI模板封装为子流,可以有效提升模板的复用性和可维护性,实现对多个相似UI组件的集中管理。理解这些机制和实践,将有助于您构建更健壮、更易于维护的Node-RED UI应用。</script>

以上就是Node-RED UI 模板中脚本内动态数据传递与管理的详细内容,更多请关注其它相关文章!


# 绑定  # 二七区推广网站搭建收费  # 棉花糖营销推广策略分析  # 东台seo优化欢迎咨询  # 关键词排名 公式怎么做  # 营销推广赠送赠品  # 北屯网络推广营销  # 新网站上线推广文案  # 四川seo经理  # 安龙县网站建设推广  # 律师网站建设大全推荐  # 将其  # 客户端  # 两种  # 正确地  # 在这里  # css  # 多个  # 复用  # 您的  # 您可以  # red  # 环境变量  # 端口  # 浏览器  # node  # json  # js  # html  # java  # javascript 


相关栏目: 【 Google疑问12 】 【 Facebook疑问10 】 【 优化推广96088 】 【 技术知识133117 】 【 IDC资讯59369 】 【 网络运营7196 】 【 IT资讯61894


相关推荐: 汽车之家网页版免费登录_汽车之家官网首页直接进入  Windows自带的便笺数据如何备份_防止数据丢失的便利贴迁移教程【干货】  FotoBalloon图片左右镜像教程  原子笔记app误删找回教程  Go语言中方法接收器的选择:值类型还是指针类型?  uc浏览器官网网页版使用 uc浏览器官网免费在线首页  解决CSS background 属性中 cover 关键字的常见误用  Three.js中动态更换3D模型纹理的教程  Go Template中优雅处理循环最后一项:自定义函数实践  c++如何掌握指针的核心用法_c++指针入门到精通指南  《浙里办》电子发票开具方法  Pydantic 中“schema”字段命名冲突的解决方案  2025考研成绩查询时间入口分享  AI图层蒙版怎么用_AI图层蒙版应用技巧与设计实例  《下一站江湖2》武器获取方法  如何查询国外邮政编码_国外邮政编码查询的多种有效途径  不吃碳水化合物是健康减肥的好办法吗  雨课堂官网在线登录 网页版雨课堂登录链接  电脑从睡眠中被自动唤醒怎么办_Windows唤醒源事件查看与禁用【解决】  奥克斯空调不制热啥毛病_奥克斯空调不制热原因分析及解决技巧  《雷电模拟器》截图方法介绍  小米手机截图后如何查看历史_小米手机截图历史记录查看方法  Win10共享文件夹设置方法 Win10局域网文件共享全攻略【教程】  QQ网站入口直接登录 QQ官方正版登录页面  抖音团长模式怎么做?团长模式是什么意思?  PHP页面重载时变量值不重置的实现方法  圆通快递包裹轨迹查询 圆通速递快件实时位置跟踪  智学网成绩单查询系统网_智学网学生平台登录  b站网页版入口 哔哩哔哩官方网站直接进入  三星M34录音变声问题_Samsung M34麦克风调整  邮编号码查询app有哪些_邮编号码查询推荐app及使用体验  荣耀magicv5怎么上手测评  苹果SE如何开启单手模式_苹果SE单手操作功能  我居然低估了 DeepSeek,这次更新它做到了这些!  Win11怎么开启HDR_Windows 11显示器画质增强设置  苹果电脑如何快速截图并编辑 苹果电脑截屏标注快捷操作  《环球网校》设置报考省市方法  解决PHP MySQL数据库更新无响应:SQL查询语法错误解析  基于键值条件高效映射 Pandas DataFrame 多列数据  如何在 WordPress 前端实现内容提交:古腾堡编辑器的替代方案与实践  Win10通知横幅停留时间修改 Win10自定义通知显示时长【技巧】  抖音怎么解除第三方绑定_抖音解除第三方平台绑定方法介绍  空腹吃苹果好吗 苹果空腹摄入指南  路由器DNS怎么设置最快 优化DNS提升上网速度教程  怎样让Windows 11的开始菜单恢复经典样式_Open-Shell工具使用指南【怀旧】  AO3永久镜像入口开放_AO3最新网址兼容所有浏览器  4399小游戏下装链接 4399小游戏下载链接入口  《健康大兴》注册方法介绍  AO3中文入口稳定分享_AO3官网HTTPS看文详解  LINUX怎么查看显卡信息_LINUX查看GPU状态 

 2025-11-20

了解您产品搜索量及市场趋势,制定营销计划

同行竞争及网站分析保障您的广告效果

点击免费数据支持

提交您的需求,1小时内享受我们的专业解答。

运城市盐湖区信雨科技有限公司


运城市盐湖区信雨科技有限公司

运城市盐湖区信雨科技有限公司是一家深耕海外推广领域十年的专业服务商,作为谷歌推广与Facebook广告全球合作伙伴,聚焦外贸企业出海痛点,以数字化营销为核心,提供一站式海外营销解决方案。公司凭借十年行业沉淀与平台官方资源加持,打破传统外贸获客壁垒,助力企业高效开拓全球市场,成为中小企业出海的可靠合作伙伴。

 8156699

 13765294890

 8156699@qq.com

Notice

We and selected third parties use cookies or similar technologies for technical purposes and, with your consent, for other purposes as specified in the cookie policy.
You can consent to the use of such technologies by closing this notice, by interacting with any link or button outside of this notice or by continuing to browse otherwise.