uni-app中使用RenderJs 使用原生js

RenderJs运行的层叫【视图层】,Uniapp原生Script叫【逻辑层】,逻辑层要调用视图层需要使用一个叫【watcher】,具体怎么调用呢

为了实现这两层之间的通信,uniapp提供了一些特定的机制。以下是对这些通信机制的详细解释,以及一个具体的示例,说明逻辑层如何调用视图层的watcher。

通信机制

‌通过this.$ownerInstance获取当前组件的ComponentDescriptor实例‌:

在RenderJs中,你可以通过this.$ownerInstance访问到当前组件的ComponentDescriptor实例。这个实例提供了与逻辑层通信的接口。

‌通过事件和callMethod方法进行通信‌:

逻辑层可以触发事件,并在RenderJs中监听这些事件。

RenderJs也可以通过this.$ownerInstance.callMethod方法调用逻辑层中的方法,并传递数据。

举例:

javascript 复制代码
<template>
  <view>
    <!-- 视图层组件,绑定:prop和:change:prop -->
    <view :prop="someData" :change:prop="renderScript.onDataChange"></view>
    <button @click="changeData">改变数据并触发watcher</button>
  </view>
</template>

<script>
export default {
  data() {
    return {
      someData: '初始数据', // 逻辑层数据
    };
  },
  methods: {
    changeData() {
      this.someData = '新数据'; // 改变数据,这将触发视图层的watcher
    },
    // 逻辑层接收来自视图层的数据(可选)
    receiveDataFromRenderJs(data) {
      console.log('从视图层接收到的数据:', data);
    },
  },
};
</script>

<script module="renderScript" lang="renderjs">
export default {
  data() {
    return {
      receivedData: '', // 用于存储从逻辑层接收到的数据
    };
  },
  methods: {
    onDataChange(newValue, oldValue, ownerVm, vm) {
      console.log('数据变化了,新值:', newValue, '旧值:', oldValue);
      
      // 可以在这里调用逻辑层的方法,并传递数据
      // ownerVm.callMethod('receiveDataFromRenderJs', { someKey: newValue });
    },
    // 视图层向逻辑层发送数据(示例)
    sendDataToLogicLayer() {
      // 假设这里有一些逻辑需要向逻辑层发送数据
      const dataToSend = { fromRenderJs: '这是视图层的数据' };
      this.$ownerInstance.callMethod('receiveDataFromRenderJs', dataToSend);
    },
  },
};
</script>

解释

‌模板部分‌:

我们定义了一个视图层组件,并使用:prop和:change:prop绑定了逻辑层的数据和视图层的watcher方法。

当someData在逻辑层发生变化时,将触发renderScript.onDataChange方法。

‌逻辑层部分‌:

我们定义了一个someData数据和一个changeData方法,用于改变someData的值。

当someData的值改变时,将触发视图层的onDataChangewatcher方法。

我们还定义了一个receiveDataFromRenderJs方法,用于接收来自视图层的数据(虽然在这个示例中并没有直接调用它,但展示了如何接收数据)。

‌视图层(RenderJs)部分‌:

我们定义了一个onDataChange方法,当逻辑层的数据变化时,这个方法将被调用。

在onDataChange方法中,我们可以访问新旧值,并可以在这里调用逻辑层的方法,传递数据。

我们还定义了一个sendDataToLogicLayer方法,用于演示如何从视图层向逻辑层发送数据。

通过这种方式,你可以在uniapp中实现逻辑层和视图层之间的有效通信

相关推荐
昔人'18 分钟前
`list-style-type: decimal-leading-zero;`在有序列表`<ol></ol>` 中将零添加到一位数前面
前端·javascript·html
岁月宁静6 小时前
深度定制:在 Vue 3.5 应用中集成流式 AI 写作助手的实践
前端·vue.js·人工智能
2501_915909066 小时前
“绑定 HTTPS” 的工程全流程 从证书配置到真机验证与故障排查
网络协议·http·ios·小程序·https·uni-app·iphone
心易行者6 小时前
10天!前端用coze,后端用Trae IDE+Claude Code从0开始构建到平台上线
前端
saadiya~7 小时前
ECharts 实时数据平滑更新实践(含 WebSocket 模拟)
前端·javascript·echarts
fruge7 小时前
前端三驾马车(HTML/CSS/JS)核心概念深度解析
前端·css·html
百锦再7 小时前
Vue Scoped样式混淆问题详解与解决方案
java·前端·javascript·数据库·vue.js·学习·.net
烛阴7 小时前
Lua 模块的完整入门指南
前端·lua
2501_915918417 小时前
iOS 混淆实战 多工具组合完成 IPA 混淆、加固与工程化落地(iOS混淆|IPA加固|无源码混淆|Ipa Guard|Swift Shield)
android·ios·小程序·https·uni-app·iphone·webview
浪里行舟8 小时前
国产OCR双雄对决?PaddleOCR-VL与DeepSeek-OCR全面解析
前端·后端