PHP前端开发

uniapp怎么使用组件

百变鹏仔 2个月前 (11-21) #uniapp
文章标签 组件
uniapp使用组件的方法:1、使用props用于父组件给子组件传递参数;2、使用【$emit】用于向父组件传递事件,可携带子组件的参数;3、使用ref获取某个dom节点或子组件的注册引用信息。

本教程操作环境:windows7系统、uni-app2.5.1版本,该方法适用于所有品牌电脑。

推荐(免费):uni-app开发教程

uniapp使用组件的方法:

1、props(props用于父组件给子组件传递参数,参数可以限制类型,可以设置默认值)

2、$emit(事件名,参数1,参数n):用于向父组件传递事件,可携带子组件的参数

3、ref用于获取某个dom节点或子组件的注册引用信息,在父组件的$refs对象里,分别指向dom元素或子组件的实例

4、如需在基本组件的内置事件传递新的参数,可使用$event占位默认参数,如 @change($event,新的参数)

5、插槽,里面可填充任何模板

如下代码为一个弹窗组件:

<template>    <view>                 <!-- 弹窗 -->        <view>            <view>                <!-- 关闭 -->                <view>                    <image></image>                </view>                <!-- 标题 -->                <view>{{title}}</view>                <textarea></textarea>                                 <view>                    {{item.name}}<switch></switch>                </view>                                 <!-- 确定按钮 -->                <view>确定</view>            </view>        </view>             </view></template> <script>    export default {        name:"popWindow",        props:{            title:{                type:String,                default:"标题"            },            max:{                type:[Number,String],                default:200            },            showPop:{                type:Boolean,                default:false            },            hasAni:{                type:Boolean,                default:true            },            holder:{                type:String,                default:"请输入..."            },            swArr:{                type:Array,                default:function(){                    return [{name:"开关",value:false}];                }            }        },        data(){            return {                textArea:""            }        },methods:{            closePop(){                this.$emit("close");            },            changeSw(e,i){                //console.log(e);                //console.log(i);                this.$emit("change",e.detail.value,i);            },            confirmSet(){                let _self = this;                _self.$emit("click",_self.textArea);            }        }    }</script> <style>         .popup_box{        width: 100%;        height: 100%;        background: rgba(0,0,0,0.5);        position: fixed;        top:0;        left: 0;        z-index: 2000;        padding:0;        .pop_panel{            width: 520upx;            height: auto;            background: #fff;            border-radius: 8upx;            position: absolute;            top:50%;            left: 50%;            transform: translate(-50%,-50%);            .pop_tit{                width: 100%;                padding:30upx 0 10upx 0;                font-size: 30upx;                text-align: center;                font-weight: bold;                box-sizing: border-box;            }            .pop_switch{                width: 100%;                box-sizing: border-box;                padding:0 30upx;                font-size: 28upx;                switch{                    transform: scale(0.6);                }            }            .pop_confirm{                margin-top:20upx;                width: 100%;                text-align: center;                font-size: 28upx;                color: #fff;                background: #009714;                height: 60upx;                line-height: 60upx;                border-bottom-left-radius: 8upx;                border-bottom-right-radius: 8upx;            }            .pop_area{                width: 460upx;                height: 200upx;                min-height: 200upx;                padding:20upx 20upx;                font-size: 26upx;                text-align: justify;                box-sizing: border-box;                border:2upx solid #e6e6e6;                margin:10upx auto;            }            .pop_close{                width:26upx;                height:26upx;                position: absolute;                right: 2upx;                top:-40upx;                image{                    width: 100%;                    height: 100%;                    display: block;                }            }        }        .pop_panel.ani{            animation: fadeIn 0.6s ease 0s 1 alternate;            animation-fill-mode: backwards;        }    } </style>

用法:

main.js中注册全局组件使用:

import popWindow from 'components/uni-part/pop-window.vue'Vue.component('popWindow',popWindow);

页面中调用:

<popwindow></popwindow>
        data() {            return {                showPop:false,                arr:[{name:"资质证书",value:true}]            }        } methods: {            changeSw(e,i){                console.log(e,i);                var newArr = _self.arr;                newArr[i].value = e;                _self.arr = newArr;            },            confirmFun(e){                //文本输入框和开关值都在这里了                console.log(e);                console.log(_self.arr);                _self.changePop();            },            changePop(){                _self.showPop = !_self.showPop;            }        }

效果如下:

相关免费学习推荐:编程视频