评论

WeUI官方组件库:助力小程序高效设计与开发

咳咳,今天推荐的是 weui 组件库~

提起 WeUI,相信大家都不陌生,WeUI 是一套同微信原生视觉体验一致的基础样式库,由微信官方设计团队为微信内网页和微信小程序量身设计,令用户的使用感知更加统一。

不过,对于 WeUI 样式库,开发者就有疑问了。

我们来看看 WeUI 组件库到底有什么可用的 UI 组件呢?WeUI 样式库有的各个元素,WeUI 组件库是基于 WeUI 样式库做了组件化处理,开发者可以便捷的使用,无需考虑组件层面的逻辑问题。

有了心动的组件之后,大家肯定想知道 WeUI 组件库是怎么使用的。

要使用 WeUI,首先要把 WeUI 引入我们的小程序项目,引入 WeUI 的方式有以下两种,使用其中一种即可~

方法一:通过 useExtendedLib 扩展库 的方式引入,这种方式引入的组件将不会计入代码包大小。(推荐👍)

方法二:可以通过 npm方式下载构建,npm 包名为 weui-miniprogram。

与方法一不同,npm 引入的方式需要多操作一步,在 app.wxss 中引用 weui.wxss。

// app.wxss
@import '/miniprogram_npm/weui-miniprogram/weui-wxss/dist/style/weui.wxss';


引入之后,我们就要开始来使用了,WeUI 组件库是基于小程序自定义组件构建的,所以使用是以自定义组件的形式来使用。

下面通过几个例子来感受下 WeUI 组件库的使用。

由于是自定义组件的形式,所以使用组件都需要在页面配置中引入,像这样:

// page.json
{
  "usingComponents": {
    "mp-half-screen-dialog": "weui-miniprogram/half-screen-dialog/half-screen-dialog",
    "mp-searchbar": "weui-miniprogram/searchbar/searchbar"
  }
}

引入组件之后,就可以直接在 wxml 中使用了,当然,为了让开发者接入更加简便,我们也加入了做了一些常见的实用性功能。

半屏弹窗

小程序提供了 wx.showModal、wx.showToast 供开发者进行页面交互,在开发过程中,可能需要自定义按钮相关的内容,所以 WeUI 提供了半屏弹窗让开发者可以有更多的自定义空间。

我们来看下代码,使用很简单,直接使用 mp-half-screen-dialog,配置相关属性即可。

// page.wxml
<mp-half-screen-dialog         
    bindbuttontap="buttontap"
    show="{{show}}"
    mask-closable="{{false}}" 
    title="测试标题B" 
    sub-title="测试标题B的副标题" 
    desc="辅助描述内容,可根据实际需要安排" 
    tips="辅助提示内容,可根据实际需要安排" 
    buttons="{{buttons}}">
</mp-half-screen-dialog>

// page.js data配置
buttons: [
  {
    type: 'default',
    className: '',
    text: '辅助操作',
    value: 0
},
{
    type: 'primary',
    className: '',
    text: '主操作',
    value: 1
  }
]

来看下半屏弹窗的效果~

u1s1,这交互体验真的爱了😍


Form 表单校验

Form 表单这里,除了基础的的功能之外,WeUI 组件库还提供了表单校验的能力,通过 rules 规则的配置(支持长度、手机号码、电子邮件、url 链接地址等),轻松解决表单校验问题。


左滑删除

相比 Web 端,手机端的操作按钮更多的是通过⬅️左滑等来实现,考虑到左滑删除的普遍性,WeUI 组件库也是支持的。

在 mp-slideview 组件中设置 buttons属性即可。

搜索组件

同样是基本功能的搜索,WeUI 组件库也封装了搜索组件,开发者只需配置搜索结果即可拥有搜索功能~

除了这些组件之外,WeUI 组件库还提供了很多实用的组件,包括基础的 icon、loading,表单的 uploader、cell 等等。

伴随客户端、小程序对 DarkMode 的支持,WeUI 组件库也同步适配 DarkMode 的模式,让 WeUI 组件库的使用同学可以快速适配 DarkMode。

在根结点(或组件的外层结点)增加属性 data-weui-theme="dark" ,即可把 WeUI 组件切换到 DarkMode 的表现,如:

<view data-weui-theme="dark">
    ...
</view>


最后,如果想体验 WeUI 组件库的效果,欢迎点击下方小程序示例体验👏及接入使用,使用过程中如有建议或者疑问,欢迎到微信开放社区与我们交流。

             

最后一次编辑于  2020-05-21  
点赞 7
收藏
评论

10 个评论

  • YONG
    YONG
    2020-06-17

    使用 weui 做了一个网站 cx.yzyo.com

    2020-06-17
    赞同 3
    回复 1
    • 钟爱
      钟爱
      2022-07-15
      有源码地址吗
      2022-07-15
      回复
  • 时光人 ‍微信超級會員
    时光人 ‍微信超級會員
    2020-10-09

    怎么更新插件版本啊啊啊


    2020-10-09
    赞同 1
    回复
  • ghost
    ghost
    2020-12-18

    useExtendedLib 扩展库引用后,导致以前的页面出现样式问题,如何解决?

    2020-12-18
    赞同
    回复
  • 沐歌
    沐歌
    2020-10-09

    啥时候更新下sketch文件。已经2020年了。

    2020-10-09
    赞同
    回复 1
    • 蘇
      2021-03-17
      可能之前搞sketch那个人离职了
      2021-03-17
      1
      回复
  • 胡占红
    胡占红
    发表于移动端
    2020-07-28
    议迷糊妻
    2020-07-28
    赞同
    回复
  • 胡占红
    胡占红
    发表于移动端
    2020-07-28
    '0
    2020-07-28
    赞同
    回复
  • 赵昀伟
    赵昀伟
    2020-07-18

    您好,请问有音频播放组件么?

    2020-07-18
    赞同
    回复
  • 天使ηò哭💬
    天使ηò哭💬
    2020-06-10

    使用了方案一并不奏效呢,mac 下小程序开发者工具,提示Component is not found in path "miniprogram_npm/weui-miniprogram/components/**"

    2020-06-10
    赞同
    回复 2
  • 小肥羊🍊
    小肥羊🍊
    2020-05-27

    关于半屏弹窗不能自定义内容,这种UI组件比CSS的半屏弹窗差距太大了,后续有继续完善吗?

    半屏弹窗

    2020-05-27
    赞同
    回复
  • 拾忆
    拾忆
    2020-05-21

    羡慕互动的那位同学~

    2020-05-21
    赞同
    回复 5
登录 后发表内容