关于面板小程序自定义进度条拖动性能问题

面板小程序开发相关产品技术讨论,包括面板小程序、智能小程序、React Native、Ray跨端框架、Panel SDK、微信小程序、小程序开发工具(IDE)及其他开发技术相关等话题


Post Reply
MwM-Mai
Posts: 65

在IDE调试拖动进度时不会进度条变化不会出现延迟,在真机调试的时候拖动进度条时出现延迟

muhai
Posts: 32

Re: 关于面板小程序自定义进度条拖动性能问题

提供一下示例代码。物料广场上的 Slider 组件 有 2 个版本,推荐使用 Sjs 版本,会少一层 React 转小程序的通信成本。

MwM-Mai
Posts: 65

Re: 关于面板小程序自定义进度条拖动性能问题

muhai 2023年 Oct 31日 17:45

提供一下示例代码。物料广场上的 Slider 组件 有 2 个版本,推荐使用 Sjs 版本,会少一层 React 转小程序的通信成本。

您好,提供的链接500报错进不去

Attachments
59640bd6bcf36d0d99b5c93c6fb7010.png
muhai
Posts: 32

Re: 关于面板小程序自定义进度条拖动性能问题

MwM-Mai 2023年 Oct 31日 17:52
muhai 2023年 Oct 31日 17:45

提供一下示例代码。物料广场上的 Slider 组件 有 2 个版本,推荐使用 Sjs 版本,会少一层 React 转小程序的通信成本。

您好,提供的链接500报错进不去

目前用 React setState 更新方法确实存在 IDE 流畅、真机卡顿的情况,我们还在进一步优化。当前解决的办法是直接操作 dom 来实现动画效果而不是走 React 调度更新,需要利用 Sjs 语法 来操作 dom 节点。

上面链接 500 的话,你可以按下面命令安装尝试:

Code: Select all

yarn add --registry=https://registry.npmjs.org/ @ray-js/components-ty-slider@^0.2.34

示例:

Code: Select all

import SjsSlider from '@ray-js/components-ty-slider/lib/slider';

<SjsSlider
  reverse
  direction="vertical"
  barPad={-4}
  step={1}
  end={value}
  bind:onChange={event => {
    setValue(event.detail.end);
    console.log('onChange', event.detail);
  }}
  bind:onEnd={event => {
    setValue(event.detail.end);
    console.log('onEnd', event.detail);
  }}
  bind:onStart={event => {
    setValue(event.detail.end);
    console.log('onStart', event.detail);
  }}
/>
MwM-Mai
Posts: 65

Re: 关于面板小程序自定义进度条拖动性能问题

muhai 2023年 Nov 1日 11:14
MwM-Mai 2023年 Oct 31日 17:52
muhai 2023年 Oct 31日 17:45

提供一下示例代码。物料广场上的 Slider 组件 有 2 个版本,推荐使用 Sjs 版本,会少一层 React 转小程序的通信成本。

您好,提供的链接500报错进不去

目前用 React setState 更新方法确实存在 IDE 流畅、真机卡顿的情况,我们还在进一步优化。当前解决的办法是直接操作 dom 来实现动画效果而不是走 React 调度更新,需要利用 Sjs 语法 来操作 dom 节点。

上面链接 500 的话,你可以按下面命令安装尝试:

Code: Select all

yarn add --registry=https://registry.npmjs.org/ @ray-js/components-ty-slider@^0.2.34

示例:

Code: Select all

import SjsSlider from '@ray-js/components-ty-slider/lib/slider';

<SjsSlider
  reverse
  direction="vertical"
  barPad={-4}
  step={1}
  end={value}
  bind:onChange={event => {
    setValue(event.detail.end);
    console.log('onChange', event.detail);
  }}
  bind:onEnd={event => {
    setValue(event.detail.end);
    console.log('onEnd', event.detail);
  }}
  bind:onStart={event => {
    setValue(event.detail.end);
    console.log('onStart', event.detail);
  }}
/>

我这边使用你提供链接的物料广场组件在真机调试中还是会出现卡顿的情况

muhai
Posts: 32

Re: 关于面板小程序自定义进度条拖动性能问题

MwM-Mai 2023年 Nov 1日 14:04
muhai 2023年 Nov 1日 11:14
MwM-Mai 2023年 Oct 31日 17:52

您好,提供的链接500报错进不去

目前用 React setState 更新方法确实存在 IDE 流畅、真机卡顿的情况,我们还在进一步优化。当前解决的办法是直接操作 dom 来实现动画效果而不是走 React 调度更新,需要利用 Sjs 语法 来操作 dom 节点。

上面链接 500 的话,你可以按下面命令安装尝试:

Code: Select all

yarn add --registry=https://registry.npmjs.org/ @ray-js/components-ty-slider@^0.2.34

示例:

Code: Select all

import SjsSlider from '@ray-js/components-ty-slider/lib/slider';

<SjsSlider
  reverse
  direction="vertical"
  barPad={-4}
  step={1}
  end={value}
  bind:onChange={event => {
    setValue(event.detail.end);
    console.log('onChange', event.detail);
  }}
  bind:onEnd={event => {
    setValue(event.detail.end);
    console.log('onEnd', event.detail);
  }}
  bind:onStart={event => {
    setValue(event.detail.end);
    console.log('onStart', event.detail);
  }}
/>

我这边使用你提供链接的物料广场组件在真机调试中还是会出现卡顿的情况

注意看 import 那一行,是导入的/lib/slider,看看是不是导入错误?

MwM-Mai
Posts: 65

Re: 关于面板小程序自定义进度条拖动性能问题

muhai 2023年 Nov 1日 14:27
MwM-Mai 2023年 Nov 1日 14:04
muhai 2023年 Nov 1日 11:14

目前用 React setState 更新方法确实存在 IDE 流畅、真机卡顿的情况,我们还在进一步优化。当前解决的办法是直接操作 dom 来实现动画效果而不是走 React 调度更新,需要利用 Sjs 语法 来操作 dom 节点。

上面链接 500 的话,你可以按下面命令安装尝试:

Code: Select all

yarn add --registry=https://registry.npmjs.org/ @ray-js/components-ty-slider@^0.2.34

示例:

Code: Select all

import SjsSlider from '@ray-js/components-ty-slider/lib/slider';

<SjsSlider
  reverse
  direction="vertical"
  barPad={-4}
  step={1}
  end={value}
  bind:onChange={event => {
    setValue(event.detail.end);
    console.log('onChange', event.detail);
  }}
  bind:onEnd={event => {
    setValue(event.detail.end);
    console.log('onEnd', event.detail);
  }}
  bind:onStart={event => {
    setValue(event.detail.end);
    console.log('onStart', event.detail);
  }}
/>

我这边使用你提供链接的物料广场组件在真机调试中还是会出现卡顿的情况

注意看 import 那一行,是导入的/lib/slider,看看是不是导入错误?

好的,感谢

Post Reply