uniapp项目下拉框uni-data-select多选

前言:uniapp项目官方uni-data-select下拉框没有多选功能,需要的话就得自己封装一个,下面是封装的方法

1.在components文件下创建一个vue文件my-selectCheckbox(叫什么名无所谓了!)

2.下面是封装的代码(my-selectCheckbox文件下的代码)

<template>
    <view class="uni-stat__select">
        <span v-if="label" class="uni-label-text">{{label + ':'}}</span>
        <view class="uni-stat-box" :class="{'uni-stat__actived': current}">
            <view class="uni-select" :style="{height:multiple?'100%':' 35px;'}"
                :class="{'uni-select--disabled':disabled}">
                <view class="uni-select__input-box" :style="{height:multiple?'100%':'35px;'}" @click="toggleSelector">
                    <view class="" style="display: flex;flex-wrap: wrap;width: 100%;" v-if="multiple&&current.length>0">
                        <view class="tag-calss"
                            v-for="(item,index) in collapseTags?current.slice(0,collapseTagsNum):current"
                            :key="item[dataValue]">
                            <span class="text">{{item[dataKey]}}</span>
                            <view class="" @click.stop="delItem(item)">
                                <uni-icons type="clear" style="margin-left: 4px;" color="#c0c4cc" />
                            </view>
                        </view>
                        <view v-if="current.length>collapseTagsNum&&collapseTags" class="tag-calss">
                            <span class="text">+{{current.length-collapseTagsNum}}</span>
                        </view>
                    </view>
                    <view v-else-if="current&&current.length>0&&!filterable" class="uni-select__input-text">{{current}}
                    </view>
                    <input v-else-if="filterable" class="uni-select__input-text" type="text" style="font-size: 12px;"
                        :placeholder="placeholderOld" v-model="current">
                    <view v-else class="uni-select__input-text uni-select__input-placeholder">{{typePlaceholder}}</view>
                    <uni-icons v-if="current && clear" type="clear" color="#c0c4cc" size="24" @click="clearVal" />
                    <uni-icons v-else :type="showSelector? 'top' : 'bottom'" size="14" color="#999" />
                </view>
                <view class="uni-select--mask" v-if="showSelector" @click="toggleSelector" />
                <view class="uni-select__selector" v-if="showSelector">
                    <view class="uni-popper__arrow"></view>
                    <scroll-view scroll-y="true" class="uni-select__selector-scroll">
                        <view class="uni-select__selector-empty" v-if="filterMixinDatacomResData.length === 0">
                            <span>{{emptyTips}}</span>
                        </view>
                        <view v-else class="uni-select__selector-item"
                            style="display: flex;justify-content: space-between;align-items: center;"
                            v-for="(item,index) in filterMixinDatacomResData" :key="index" @click="change(item)">
                            <span
                                :class="{'uni-select__selector__disabled': item.disable}">{{formatItemName(item)}}</span>
                            <uni-icons v-if="multiple&&currentArr.includes(item[dataValue])" type="checkmarkempty"
                                color="#007aff" />
                        </view>
                    </scroll-view>
                </view>
            </view>
        </view>
    </view>
</template>
 
<script>
    /**
     * DataChecklist 数据选择器
     * @description 通过数据渲染的下拉框组件
     * @tutorial https://uniapp.dcloud.io/component/uniui/uni-data-select
     * @property {String} value 默认值
     * @property {Array} localdata 本地数据 ,格式 [{text:'',value:''}]
     * @property {Boolean} clear 是否可以清空已选项
     * @property {Boolean} emptyText 没有数据时显示的文字 ,本地数据无效
     * @property {String} label 左侧标题
     * @property {String} placeholder 输入框的提示文字
     * @property {Boolean} disabled 是否禁用
     * @event {Function} change  选中发生变化触发
     */
 
    export default {
        name: "my-selectCheckbox",
        mixins: [uniCloud.mixinDatacom || {}],
        props: {
            collapseTagsNum: {
                type: Number,
                default: 1
            },
            collapseTags: {
                type: Boolean,
                default: false
            },
            dataKey: {
                type: [String],
                default: 'text'
            },
            dataValue: {
                type: [String],
                default: 'value'
            },
            multiple: {
                type: Boolean,
                default: false
            },
            filterable: {
                type: Boolean,
                default: false
            },
            localdata: {
                type: Array,
                default () {
                    return []
                }
            },
            // #ifndef VUE3
            value: {
                type: [String, Number, Array],
                default: ''
            },
            // #endif
            // #ifdef VUE3
            modelValue: {
                type: [String, Number, Array],
                default: ''
            },
            // #endif
            label: {
                type: String,
                default: ''
            },
            placeholder: {
                type: String,
                default: '请选择'
            },
            emptyTips: {
                type: String,
                default: '无选项'
            },
            clear: {
                type: Boolean,
                default: true
            },
            defItem: {
                type: Number,
                default: 0
            },
            disabled: {
                type: Boolean,
                default: false
            },
            // 格式化输出 用法 field="_id as value, version as text, uni_platform as label" format="{label} - {text}"
            format: {
                type: String,
                default: ''
            },
        },
        data() {
            return {
                showSelector: false,
                current: [],
                mixinDatacomResData: [],
                apps: [],
                channels: [],
                cacheKey: "uni-data-select-lastSelectedValue",
                placeholderOld: "",
                currentArr: []
            };
        },
        created() {
            if (this.multiple) {
                // #ifndef VUE3
                this.currentArr = this.value || []
                // #endif
                // #ifdef VUE3
                this.currentArr = this.modelValue || []
                // #endif
                if (!this.current) {
                    this.current = []
                }
                // #ifndef VUE3
                if (this.value && this.value.length > 0 && this.filterMixinDatacomResData.length > 0) {
                    this.value.forEach(item => {
                        let current = this.filterMixinDatacomResData.find(e =>
                            e[this.dataValue] == item
                        )
                        this.current.push(current)
                    })
                }
                // #endif
                // #ifdef VUE3
                if (this.modelValue && this.modelValue.length > 0 && this.filterMixinDatacomResData.length > 0) {
                    this.modelValue.forEach(item => {
                        let current = this.filterMixinDatacomResData.find(e =>
                            e[this.dataValue] == item
                        )
                        this.current.push(current)
                    })
                }
                // #endif
 
            } else {
 
                // #ifndef VUE3
                if (this.value) {
                    this.current = this.formatItemName(this.filterMixinDatacomResData.find(e =>
                        e[this.dataValue] == this.value
                    ))
                }
                // #endif
                // #ifdef VUE3
                if (this.modelValue) {
                    this.current = this.formatItemName(this.filterMixinDatacomResData.find(e =>
                        e[this.dataValue] == this.modelValue
                    ))
                }
                // #endif
            }
            this.placeholderOld = this.placeholder
            this.debounceGet = this.debounce(() => {
                this.query();
            }, 300);
            if (this.collection && !this.localdata.length) {
                this.debounceGet();
            }
        },
        computed: {
            filterMixinDatacomResData() {
                if (this.filterable && this.current) {
                    return this.mixinDatacomResData.filter(e => e[this.dataKey].includes(this.current))
                } else {
                    return this.mixinDatacomResData
                }
            },
            typePlaceholder() {
                const text = {
                    'opendb-stat-app-versions': '版本',
                    'opendb-app-channels': '渠道',
                    'opendb-app-list': '应用'
                }
                const common = this.placeholder
                const placeholder = text[this.collection]
                return placeholder ?
                    common + placeholder :
                    common
            },
            valueCom() {
                // #ifdef VUE3
                return this.modelValue;
                // #endif
                // #ifndef VUE3
                return this.value;
                // #endif
            }
        },
        watch: {
            localdata: {
                immediate: true,
                handler(val, old) {
                    if (Array.isArray(val) && old !== val) {
                        this.mixinDatacomResData = val
                    }
 
                }
            },
            valueCom(val, old) {
                this.initDefVal()
            },
            mixinDatacomResData: {
                immediate: true,
                handler(val) {
                    if (val.length) {
                        this.initDefVal()
                    }
                }
            },
            // modelValue(val) {
            //     if (this.multiple && val && val.length > 0) {
            //         this.currentArr = val
            //         if (!this.current) {
            //             this.current = []
            //         }
            //         val.forEach(item => {
            //             let current = this.filterMixinDatacomResData.find(e =>
            //                 e[this.dataValue] == item
            //             )
            //             this.current.push(current)
            //         })
            //     } else {
            //         if (val) {
            //             this.current = this.formatItemName(this.filterMixinDatacomResData.find(e =>
            //                 e[this.dataValue] == val
            //             ))
            //         }
            //     }
 
            // },
            // value(val) {
            //     if (this.multiple && val && val.length > 0) {
            //         this.currentArr = val
            //         if (!this.current) {
            //             this.current = []
            //         }
            //         val.forEach(item => {
            //             let current = this.filterMixinDatacomResData.find(e =>
            //                 e[this.dataValue] == item
            //             )
            //             this.current.push(current)
            //         })
            //     } else {
            //         if (val) {
            //             this.current = this.formatItemName(this.filterMixinDatacomResData.find(e =>
            //                 e[this.dataValue] == val
            //             ))
            //         }
            //     }
 
            // }
        },
        methods: {
            debounce(fn, time = 100) {
                let timer = null
                return function(...args) {
                    if (timer) clearTimeout(timer)
                    timer = setTimeout(() => {
                        fn.apply(this, args)
                    }, time)
                }
            },
            // 执行数据库查询
            query() {
                this.mixinDatacomEasyGet();
            },
            // 监听查询条件变更事件
            onMixinDatacomPropsChange() {
                if (this.collection) {
                    this.debounceGet();
                }
            },
            initDefVal() {
                let defValue = ''
                if ((this.valueCom || this.valueCom === 0) && !this.isDisabled(this.valueCom)) {
                    defValue = this.valueCom
                } else {
                    let strogeValue
                    if (this.collection) {
                        strogeValue = this.getCache()
                    }
                    if (strogeValue || strogeValue === 0) {
                        defValue = strogeValue
                    } else {
                        let defItem = ''
                        if (this.defItem > 0 && this.defItem <= this.mixinDatacomResData.length) {
                            defItem = this.mixinDatacomResData[this.defItem - 1][this.dataValue]
                        }
                        defValue = defItem
                    }
                    if (defValue || defValue === 0) {
                        this.emit(defValue)
                    }
                }
                if (this.multiple) {
                    this.current = []
                    defValue.forEach(item => {
                        let current = this.filterMixinDatacomResData.find(e =>
                            e[this.dataValue] == item
                        )
                        this.current.push(current)
                    })
                } else {
                    const def = this.mixinDatacomResData.find(item => item[this.dataValue] === defValue)
                    this.current = def ? this.formatItemName(def) : ''
                }
            },
 
            /**
             * @param {[String, Number]} value
             * 判断用户给的 value 是否同时为禁用状态
             */
            isDisabled(value) {
                let isDisabled = false;
 
                this.mixinDatacomResData.forEach(item => {
                    if (item[this.dataValue] === value) {
                        isDisabled = item.disable
                    }
                })
 
                return isDisabled;
            },
 
            clearVal() {
                if (this.multiple) {
                    this.current = []
                    this.currentArr = []
                    this.emit([])
                } else {
                    this.current = ""
                    this.currentArr = []
                    this.emit('')
                }
                if (this.collection) {
                    this.removeCache()
                }
                this.placeholderOld = this.placeholder
            },
            change(item) {
                if (!item.disable) {
                    this.showSelector = false
                    if (this.multiple) {
                        if (!this.current) {
                            this.current = []
                        }
                        if (!this.currentArr) {
                            this.currentArr = []
                        }
                        if (this.currentArr.includes(item[this.dataValue])) {
                            let index = this.current.findIndex(e => {
                                return e[this.dataValue] == item[this.dataValue]
                            })
                            this.current.splice(index, 1)
                            this.currentArr.splice(index, 1)
                            this.emit(this.current)
                        } else {
                            this.current.push(item)
                            this.currentArr.push(item[this.dataValue])
                            this.emit(this.current)
                        }
                    } else {
                        this.current = this.formatItemName(item)
                        this.emit(item[this.dataValue])
                    }
                }
            },
            delItem(item) {
                if (this.currentArr.includes(item[this.dataValue])) {
                    let index = this.current.findIndex(e => {
                        return e[this.dataValue] == item[this.dataValue]
                    })
                    this.current.splice(index, 1)
                    this.currentArr.splice(index, 1)
                    this.emit(this.current)
                }
            },
            emit(val) {
                this.$emit('change', val)
                if (this.multiple) {
                    this.$emit('input', this.currentArr)
                    this.$emit('update:modelValue', this.currentArr)
                } else {
                    this.$emit('input', val)
                    this.$emit('update:modelValue', val)
                }
                if (this.collection) {
                    this.setCache(val);
                }
            },
            toggleSelector() {
                if (this.disabled) {
                    return
                }
                if (this.filterable && this.current && this.mixinDatacomResData.findIndex(e => {
                        return e[this.dataKey] == this
                            .current
                    }) < 0) {
                    this.current = ""
                }
                this.showSelector = !this.showSelector
                if (this.filterable && this.current && this.showSelector) {
                    this.placeholderOld = this.current
                    this.current = ""
                } else if (this.filterable && !this.current && !this.showSelector) {
                    if (this.placeholderOld != this.placeholder) {
                        this.current = this.placeholderOld
                    }
                }
 
            },
            formatItemName(item) {
                if (!item) {
                    return ""
                }
                let text = item[this.dataKey]
                let value = item[this.dataValue]
                let {
                    channel_code
                } = item
                channel_code = channel_code ? `(${channel_code})` : ''
                if (this.format) {
                    // 格式化输出
                    let str = "";
                    str = this.format;
                    for (let key in item) {
                        str = str.replace(new RegExp(`{${key}}`, "g"), item[key]);
                    }
                    return str;
                } else {
                    return this.collection.indexOf('app-list') > 0 ?
                        `${text}(${value})` :
                        (
                            text ?
                            text :
                            `未命名${channel_code}`
                        )
                }
            },
            // 获取当前加载的数据
            getLoadData() {
                return this.mixinDatacomResData;
            },
            // 获取当前缓存key
            getCurrentCacheKey() {
                return this.collection;
            },
            // 获取缓存
            getCache(name = this.getCurrentCacheKey()) {
                let cacheData = uni.getStorageSync(this.cacheKey) || {};
                return cacheData[name];
            },
            // 设置缓存
            setCache(value, name = this.getCurrentCacheKey()) {
                let cacheData = uni.getStorageSync(this.cacheKey) || {};
                cacheData[name] = value;
                uni.setStorageSync(this.cacheKey, cacheData);
            },
            // 删除缓存
            removeCache(name = this.getCurrentCacheKey()) {
                let cacheData = uni.getStorageSync(this.cacheKey) || {};
                delete cacheData[name];
                uni.setStorageSync(this.cacheKey, cacheData);
            },
        }
    }
</script>
 
<style lang="scss">
    $uni-base-color: #6a6a6a !default;
    $uni-main-color: #333 !default;
    $uni-secondary-color: #909399 !default;
    $uni-border-3: #e5e5e5;
 
 
    /* #ifndef APP-NVUE */
    @media screen and (max-width: 500px) {
        .hide-on-phone {
            display: none;
        }
    }
 
    /* #endif */
    .uni-stat__select {
        display: flex;
        align-items: center;
        // padding: 15px;
        cursor: pointer;
        width: 100%;
        flex: 1;
        box-sizing: border-box;
    }
 
    .uni-stat-box {
        width: 100%;
        flex: 1;
    }
 
    .uni-stat__actived {
        width: 100%;
        flex: 1;
        // outline: 1px solid #2979ff;
    }
 
    .uni-label-text {
        font-size: 14px;
        font-weight: bold;
        color: $uni-base-color;
        margin: auto 0;
        margin-right: 5px;
    }
 
    .uni-select {
        font-size: 14px;
        border: 1px solid $uni-border-3;
        box-sizing: border-box;
        border-radius: 4px;
        padding: 0 5px;
        padding-left: 10px;
        position: relative;
        /* #ifndef APP-NVUE */
        display: flex;
        user-select: none;
        /* #endif */
        flex-direction: row;
        align-items: center;
        border-bottom: solid 1px $uni-border-3;
        width: 100%;
        flex: 1;
        height: 35px;
        min-height: 35px;
 
        &--disabled {
            background-color: #f5f7fa;
            cursor: not-allowed;
        }
    }
 
    .uni-select__label {
        font-size: 16px;
        // line-height: 22px;
        min-height: 35px;
        height: 35px;
        padding-right: 10px;
        color: $uni-secondary-color;
    }
 
    .uni-select__input-box {
        height: 35px;
        position: relative;
        /* #ifndef APP-NVUE */
        display: flex;
        /* #endif */
        flex: 1;
        flex-direction: row;
        align-items: center;
 
        .tag-calss {
            font-family: Helvetica Neue, Helvetica, PingFang SC, Hiragino Sans GB, Microsoft YaHei, SimSun, sans-serif;
            font-weight: 400;
            -webkit-font-smoothing: antialiased;
            -webkit-tap-highlight-color: transparent;
            font-size: 12px;
            border: 1px solid #d9ecff;
            border-radius: 4px;
            white-space: nowrap;
            height: 24px;
            padding: 0 4px 0px 8px;
            line-height: 22px;
            box-sizing: border-box;
            margin: 2px 0 2px 6px;
            display: flex;
            max-width: 100%;
            align-items: center;
            background-color: #f4f4f5;
            border-color: #e9e9eb;
            color: #909399;
 
            .text {
                font-family: Helvetica Neue, Helvetica, PingFang SC, Hiragino Sans GB, Microsoft YaHei, SimSun, sans-serif;
                font-weight: 400;
                -webkit-font-smoothing: antialiased;
                -webkit-tap-highlight-color: transparent;
                font-size: 12px;
                white-space: nowrap;
                line-height: 22px;
                color: #909399;
                overflow: hidden;
                text-overflow: ellipsis;
            }
        }
    }
 
    .uni-select__input {
        flex: 1;
        font-size: 14px;
        height: 22px;
        line-height: 22px;
    }
 
    .uni-select__input-plac {
        font-size: 14px;
        color: $uni-secondary-color;
    }
 
    .uni-select__selector {
        /* #ifndef APP-NVUE */
        box-sizing: border-box;
        /* #endif */
        position: absolute;
        top: calc(100% + 12px);
        left: 0;
        width: 100%;
        background-color: #FFFFFF;
        border: 1px solid #EBEEF5;
        border-radius: 6px;
        box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
        z-index: 3;
        padding: 4px 0;
    }
 
    .uni-select__selector-scroll {
        /* #ifndef APP-NVUE */
        max-height: 200px;
        box-sizing: border-box;
        /* #endif */
    }
 
    .uni-select__selector-empty,
    .uni-select__selector-item {
        /* #ifndef APP-NVUE */
        display: flex;
        cursor: pointer;
        /* #endif */
        line-height: 35px;
        font-size: 14px;
        text-align: center;
        /* border-bottom: solid 1px $uni-border-3; */
        padding: 0px 10px;
    }
 
    .uni-select__selector-item:hover {
        background-color: #f9f9f9;
    }
 
    .uni-select__selector-empty:last-child,
    .uni-select__selector-item:last-child {
        /* #ifndef APP-NVUE */
        border-bottom: none;
        /* #endif */
    }
 
    .uni-select__selector__disabled {
        opacity: 0.4;
        cursor: default;
    }
 
    /* picker 弹出层通用的指示小三角 */
    .uni-popper__arrow,
    .uni-popper__arrow::after {
        position: absolute;
        display: block;
        width: 0;
        height: 0;
        border-color: transparent;
        border-style: solid;
        border-width: 6px;
    }
 
    .uni-popper__arrow {
        filter: drop-shadow(0 2px 12px rgba(0, 0, 0, 0.03));
        top: -6px;
        left: 10%;
        margin-right: 3px;
        border-top-width: 0;
        border-bottom-color: #EBEEF5;
    }
 
    .uni-popper__arrow::after {
        content: " ";
        top: 1px;
        margin-left: -6px;
        border-top-width: 0;
        border-bottom-color: #fff;
    }
 
    .uni-select__input-text {
        // width: 280px;
        width: 100%;
        color: $uni-main-color;
        white-space: nowrap;
        text-overflow: ellipsis;
        -o-text-overflow: ellipsis;
        overflow: hidden;
    }
 
    .uni-select__input-placeholder {
        color: $uni-base-color;
        font-size: 12px;
    }
 
    .uni-select--mask {
        position: fixed;
        top: 0;
        bottom: 0;
        right: 0;
        left: 0;
    }
</style>

3. 哪个页面需要就import引入就行

别忘了components声明!

4.哪里需要直接用就行(localdata这是下拉的数据,collapse-tags-num这是超过几个隐藏)

  • 7
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用以下方法来改变 uni-data-select 组件的样式: 1. 在样式文件中直接对组件进行修改。例如,你可以在样式文件中加入以下代码来改变组件的字体颜色: ```css .uni-data-select { color: red; } ``` 2. 在组件的标签上添加自定义属性,然后在样式文件中使用自定义属性来进行样式修改。例如,你可以在组件的标签上添加 `custom-class` 属性,然后在样式文件中使用该自定义属性来修改组件的样式: ```html <uni-data-select custom-class="my-class"></uni-data-select> ``` ```css .my-class { color: red; } ``` 3. 使用 JavaScript 代码动态修改组件的样式。例如,你可以使用 DOM 操作或者通过修改组件的属性来改变组件的样式。 以上是几种常用的修改 uni-data-select 组件样式的方法,你可以根据自己的需要选择适合的方法进行修改。 ### 回答2: uni-app是一款基于Vue.js的跨平台框架,可以同时开发多个平台的应用。对于uni-data-select这个扩展组件来说,我们可以通过修改样式来改变它的外观。 首先,在使用uni-data-select组件的页面中,可以使用`class`或者`style`属性来修改组件的样式。比如,添加一个`class`属性定义一个自定义样式类,然后在对应的样式文件中添加对应的样式规则。 举个例子,如果我们想改变uni-data-select的字体颜色,可以在页面组件中添加`class`属性: ``` <uni-data-select class="my-custom-class"></uni-data-select> ``` 然后在对应的样式文件(比如App.vue文件下的style标签中或者组件内部的style标签中)中定义my-custom-class的样式规则: ```css .my-custom-class { color: red; } ``` 上述代码表示将uni-data-select组件中选项的文字颜色设置为红色。 除了修改文字颜色,我们还可以通过修改其他样式属性来改变uni-data-select组件的样式。例如,可以通过调整组件的边框颜色、背景色、文字大小等属性来改变其外观。 总的来说,通过添加class属性和对应的样式规则,我们可以在uni-app中改变uni-data-select组件的样式。当然,具体的修改还需要根据实际需求来确定。 ### 回答3: uni-data-selectuniapp框架的扩展组件之一,用于创建下拉框。要改变uni-data-select的样式,可以通过修改其相关的CSS来实现。 首先,需要在uni-data-select所在的vue文件或者全局的App.vue文件中,找到对应的样式类名或者id名。可以通过查看uni-data-select组件的文档或者查看组件的源代码来确定样式类名或id名。 接下来,可以在样式表文件(通常是在页面的style标签中或者是在全局的App.vue文件的style标签中)中添加对应的样式来修改uni-data-select的样式。可以使用常用的样式属性,如font-size、color、background-color等来修改文本的大小、颜色和背景色。可以使用width和height来修改下拉框的宽度和高度。 样式的修改示例: ```css /* 修改下拉框的文本颜色和背景色 */ .uni-data-select { color: red; background-color: yellow; } /* 修改下拉框的宽度和高度 */ .uni-data-select .uni-data-select-value { width: 200px; height: 30px; } ``` 修改完样式后,重新编译运行uniapp项目,就可以看到uni-data-select组件的样式已经被修改了。 需要注意的是,uniapp框架中的组件样式作用域是组件封装内部的,所以需要确定uni-data-select组件的样式类名或者id名,并在对应的作用域内添加样式。如果想要修改全局的样式,可以在App.vue文件中添加相应的全局样式,或者通过封装一个uni-data-select的子组件,来自定义uni-data-select的样式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值