Skip to content

Latest commit

 

History

History
117 lines (107 loc) · 8.89 KB

button.md

File metadata and controls

117 lines (107 loc) · 8.89 KB

button(id, options)

浮动按钮

参数 类型 描述
id string 唯一标识
options object 配置项
options.className string 自定义类名
options.position string 按钮的位置,可选值 topLeft、topRight、bottomLeft、bottomRight
options.backdrop boolean 是否显示透明蒙层
options.buttons array 按钮
options.buttons[].className string 按钮的类名
options.buttons[].label string 按钮的文字
options.buttons[].icon string 按钮的图标
options.buttonClicked function 按钮点击事件
options.callback function 监听状态变化的回调函数

Example

<import src="../../components/button/button.wxml"/>

<template is="button" data="{{ ...$wux.button.br }}"/>

<view class="page">
    <view class="page__hd">
        <view class="page__title">Button</view>
        <view class="page__desc">浮动按钮</view>
    </view>
    <view class="page__bd">
        <view class="weui-cells weui-cells_after-title">
            <view class="weui-cell weui-cell_select">
                <view class="weui-cell__hd weui-cell__hd_in-select-after">
                    <view class="weui-label">切换位置</view>
                </view>
                <view class="weui-cell__bd">
                    <picker bindchange="pickerChange" value="{{ index }}" range="{{ types }}">
                        <view class="weui-select weui-select_in-select-after">{{ types[index] }}</view>
                    </picker>
                </view>
            </view>
            <view class="weui-cell weui-cell_switch">
                <view class="weui-cell__bd">切换状态</view>
                <view class="weui-cell__ft">
                    <switch bindchange="switchChange" checked="{{ opened }}" />
                </view>
            </view>
        </view>
    </view>
</view>
import { $wuxButton } from '../../components/wux'

Page({
    data: {
        types: ['topLeft', 'topRight', 'bottomLeft', 'bottomRight'], 
        index: 3, 
        opened: !1, 
    },
    onLoad() {
        this.initButton()
    },
    initButton(position = 'bottomRight') {
        this.setData({
            opened: !1, 
        })

        this.button = $wuxButton.init('br', {
            position: position, 
            buttons: [
                {
                    label: 'View on Github', 
                    icon: "", 
                },
                {
                    label: 'View on About', 
                    icon: "", 
                },
                {
                    label: 'View on Demo', 
                    icon: "", 
                }
            ],
            buttonClicked(index, item) {
                index === 0 && wx.showModal({
                    title: 'Thank you for your support!', 
                    showCancel: !1, 
                })

                index === 1 && wx.switchTab({
                    url: '/pages/about/index'
                })

                index === 2 && wx.switchTab({
                    url: '/pages/index/index'
                })

                return true
            },
            callback(vm, opened) {
                vm.setData({
                    opened, 
                })
            },
        })
    },
    switchChange(e) {
        e.detail.value ? this.button.open() : this.button.close()
    },
    pickerChange(e) {
        const index = e.detail.value
        const position = this.data.types[index]
        this.initButton(position)
    },
})