Skip to content

常见问题 FAQ

本节介绍在开发过程当中遇到的部分 常见问题 以及 解决办法

目前支持哪些平台?

目前支持 微信小程序、支付宝小程序、钉钉小程序、H5、APP 等平台。

组件库有没有提供可以单独引入的组件?

目前是没有的,首先在插件市场缺少CI/CD工具,无法实现自动化发布,维护一套单独引入的组件费时费力,其次组件库提供的安装方式均可以实现按需引入,所以是无需提供单独引入的组件的。

如何开启暗黑模式?

Wot Design Uni支持深色模式、主题定制等能力,详见ConfigProvider 全局配置组件。

有没有技术交流群?

有! 可以加入Wot UI 互助群,分享心得、交流体会。

Sass抛出大量错误和警告?

Dart Sass 3.0.0 废弃了一批API,而组件库目前还未兼容,因此请确保你的sass版本为1.78.0及之前的版本。可以通过以下命令安装指定版本:

bash
npm i sass@1.78.0 -D
bash
yarn add sass@1.78.0 -D
bash
pnpm add sass@1.78.0 -D

小程序样式隔离

在页面中使用 Wot Design Uni 组件时,可直接在页面的样式文件中覆盖样式

vue
<wd-button type="primary">主要按钮</wd-button>
scss
/* 页面样式 */
:deep(.wd-button) {
  color: red !important;
}

为什么在组件中无法覆盖组件库样式?

在自定义组件中使用 Wot Design Uni 组件时,需开启styleIsolation: 'shared'选项

vue
<wd-button type="primary">主要按钮</wd-button>

Vue 3.2 及以下版本可以使用如下配置开启styleIsolation: 'shared'选项:

ts
// vue
<script lang="ts">
export default {
  options: {
    styleIsolation: 'shared'
  }
}
</script>
<script lang="ts" setup>
</script>
scss
/* 组件样式 */
:deep(.wd-button) {
  color: red !important;
}

Vue 3.3+ 可以通过defineOptions开启styleIsolation: 'shared'选项:

ts
<script lang="ts" setup>
defineOptions({
  options: {
    styleIsolation: 'shared'
  }
})
</script>

小程序使用外部样式类

Wot Design Uni 开放了大量的自定义样式类供开发者使用,具体的样式类名称可查阅对应组件的“外部样式类”部分。需要注意的是普通样式类和自定义样式类的优先级是未定义的,因此使用时请添加!important以保证外部样式类的优先级。

请注意

Wot Design Uni 的组件均设置了scoped,所以它的 CSS 只会影响当前组件的元素,和 Shadow DOM 中的样式封装类似,处于 scoped 样式中的选择器如果想要做更“深度”的选择,也即:影响到子组件,可以使用 :deep() 这个伪类:

css
<style scoped>
.a :deep(.b) {
  /* ... */
}
</style>

上面的代码会被编译成:

css
.a[data-v-f3f3eg9] .b {
  /* ... */
}

详细可见单文件组件 CSS 功能

vue
<wd-button custom-class="custom-button" type="primary">主要按钮</wd-button>
scss
/* 组件样式 */
:deep(.custom-button) {
  color: red !important;
}

小程序自定义组件渲染问题

微信/QQ/百度/抖音这四家小程序,自定义组件在渲染时会比 App/H5 端多一级节点,下面以divider组件举例:

vue
<!-- 使用 -->
<wd-divider></wd-divider>

<!-- h5渲染 -->
<view class="wd-divider"></view>

<!-- 微信小程序渲染 -->
<wd-divider>
  <view class="wd-divider"></view>
</wd-divider>

解决办法

在微信端可以使用virtualHost解决,virtualHost设为true之后会将自定义节点设置成虚拟的,更加接近 Vue 组件的表现,可以去掉微信小程序自定义组件多出的最外层标签,启用后还可以通过 mergeVirtualHostAttributes 合并合并组件虚拟节点外层属性。

js
// vue2使用virtualHost
export default {
  data() {
    return {}
  },
  options: {
    virtualHost: true
  }
}
ts
// vue3 script setup 使用virtualHost
<script lang="ts">
export default {
  // 将自定义节点设置成虚拟的,更加接近Vue组件的表现,可以去掉微信小程序自定义组件多出的最外层标签
  options: {
    virtualHost: true
  }
}
</script>
<script lang="ts" setup>
</script>

启用 virtualHost 效果

这里我们还是以divider组件举例:

vue
<!-- 使用 -->
<wd-divider></wd-divider>

<!-- h5渲染 -->
<view class="wd-divider"></view>

<!-- 微信小程序渲染 -->
<view class="wd-divider"></view>

如何定制主题?

我们为每个组件提供了css 变量,可以参考config-provider组件的使用介绍来定制主题。

Toast 和 MessageBox 组件调用无效果?

首先要检查一下用法是否正确,uni-app平台不支持全局挂载组件,所以MessageToast等组件仍需在 SFC 中显式使用,例如:

html
<wd-toast></wd-toast>

MessageToast的函数式调用是基于provide/inject实现的,所以你的调用要确保在setup中。

编译到支付宝小程序 Popup 组件的遮罩无法显示?

uni-app 3.99.2023122704 将支付宝小程序的styleIsolation默认值设置为了apply-shared,而支付宝小程序默认的styleIsolationshared,所以导致更新到3.99.2023122704版本后,支付宝小程序自定义组件样式穿透无法生效,参见issue。 解决办法:在mainfest.json中设置styleIsolationshared

json
{
  // ...
  "mp-alipay": {
    // ...
    "styleIsolation": "shared"
    // ...
  }
  // ...
}

为什么组件库文档中都是从@/uni_modules/wot-design-uni导入方法和工具类?

当前组件库本身的开发方式是将组件库代码放到@/uni_modules/wot-design-uni这个目录的,所以文档中都是从@/uni_modules/wot-design-uni导入方法和工具类,使用npm方式安装组件库的时候可以这样调整:

ts
// useToast、useNotify等同理
import { useMessage } from '@/uni_modules/wot-design-uni'

替换为

ts
import { useMessage } from 'wot-design-uni'

uni-app 如何自定义编译平台,例如钉钉小程序?

可以参考uni-app文档中package.json章节。

钉钉小程序示例:

JSON
{
    "uni-app": {
    "scripts": {
      "mp-dingtalk": {
        "title": "钉钉小程序",
        "env": {
          "UNI_PLATFORM": "mp-alipay"
        },
        "define": {
          "MP-DINGTALK": true
        }
      }
    }
  },
}

当前组件库提供的用于控制组件显示隐藏 hooks 不生效怎么办?

注意

多次执行use后,useToastuseMessageuseNotifyuseQueue等 hooks 不生效的问题已在1.3.14版本修复,请升级到最新版本。

可以按照以下步骤进行排查

  1. uni-app平台不支持全局挂载组件,所以MessageToastNotify等组件需在 SFC 中显式使用,例如:
html
<wd-toast></wd-toast>
  1. useToastuseMessageuseNotifyuseQueue等 hooks 不生效,请检查是否在setup中调用,如果setup中调用,请检查当前页面是否存在多次执行use的场景,例如在多个组件中执行,这样会导致上一次use的失效。针对此场景,组件的函数式调用都支持传入selector参数,可以通过selector参数来指定组件,例如:
html
<wd-toast></wd-toast>
<wd-toast selector="my-toast"></wd-toast>
ts
const toast = useToast()
const myToast = useToast('my-toast')

为什么在微信小程序上使用PopupActionSheetDropDownItem等弹出框组件包裹SliderTabs等组件时,SliderTabs表现异常?

目前uni-app使用v-if控制插槽是否显示编译到微信小程序端存在问题,具体可以参考issue:47554847。而PopupActionSheetDropDownItem恰好正是使用v-if控制插槽是否显示,所以会导致SliderTabs在未渲染时执行了相关生命周期。SliderTabs等组件的一些数据如Slider的宽度,Tabs的滑块位置等会在onMounted等生命周期进行获取,此时这些数据将会存在异常。

解决办法:

  1. SliderTabs等组件外部使用v-if控制弹框打开前不展示,例如:
html
<wd-slider v-if="showSlider"></wd-slider>
  1. PopupActionSheetDropDownItem等组件完全打开时的钩子中重新初始化SliderTabs组件,例如:
html
<wd-popup v-model="show" position="bottom" closable custom-style="height: 200px;" @after-enter="handleOpened">
<wd-slider v-model="value" ref="slider"></wd-slider>
</wd-popup>
ts
const slider = ref()

function handleOpened() {
  slider.value!.initSlider()
}

为何messageBox弹出了多个?

检查一下弹出多个messageBox的页面是否存在多个相同selector或无selector<wd-message-box></wd-message-box>标签(当前页面包括页面中使用的组件)。toast亦是同理,在子组件中使用messageBox等组件需要指定selector并确保selector唯一。

如何快速解决你的问题?

提问的智慧,可以帮助你快速提出正确的问题,获得更快的解答。

关于我们

如果您的问题不在上述列表中或您有更好的建议,请联系我们 Moonofweisheng

Released under the MIT License.

Released under the MIT License.