码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • uniapp的组件封装与组件间的参数传递


    目录

      • 前言
      • 开发环境
      • 封装组件
        • 组件注册
        • 定义子组件中的属性
        • 父组件要调用子组件里的方法
        • 子组件要向父组件传递参数
      • 注意的点

    前言

    uniapp是一款一端开发多端打包的便捷应用开发框架,他不仅提供了类似于小程序的开发组件,更是基于vue的语法进行开发,方便入手。有极其完善的文档与社区,也有不少第三方ui框架的支持。

    开发环境

    HBuilderX3.6.4.20220922, Vue2

    封装组件

    在vue项目开发中甚至是前后端不分离的项目封装组件也是一件非常常见的事,比如像侧边栏、页脚,这种每页都要但又不想每页都写的页面,就会单独抽离成组件,在用的地方直接引用即可。uniapp自然也是支持这种做法的,具体做法与vue几乎一致。

    组件注册

    在项目根路径下创建componetns文件夹,右击新建组件,创建SCSS模板组件,创建同名目录,这样在父组件引用时不需要注册和import,封装过vue组件的朋友懂得。
    在这里插入图片描述

    定义子组件中的属性

    子组件使用 props,用这个属性定义参数名称

    <view>
    	{{name}}
    	{{age}}
    view>
    
    • 1
    • 2
    • 3
    • 4
    props: {
    	name: {
    		type: String,
    		default: '小明'
    	},
    	age: {
    		type: Number,
    		default: 20
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    父组件使用子组件

    <myTest :name="name" :age="age">myTest>
    
    • 1

    data定义传递给子组件的数据

    data() {
    	return {
    		title: '登陆',//与本文无关
    		name: '小明',
    		age: 20
    	}
    },
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    效果:
    在这里插入图片描述
    子组件拿到的数据是父组件的data里定义的数据

    父组件要调用子组件里的方法

    父组件在引用的子组件上定义refs

    <myTest ref="myTest" :name="name" :age="age">myTest>
    
    • 1

    如何调用:
    首先我们要确定调用的子组件的方法名,我在myTest.vue里定义了个tap事件

    <view @tap="tap" style="border-color: black;">组件位置view>
    
    • 1
    methods: {
    	tap() {
    		console.log('tap');
    	}
    },
    
    • 1
    • 2
    • 3
    • 4
    • 5

    调用:
    myTest就是组件名,tap是事件或者方法

    this.$refs.myTest.tap(); // 调用子组件的方法
    
    • 1

    效果:
    在这里插入图片描述
    注意:
    由于生命周期的关系,一些周期较早的属性里如果调用子组件的话可能会导致出错比如onLoad函数,因为那个时候子组件还未加载!

    子组件要向父组件传递参数

    使用emit关键字
    比如我在父组件引用子组件的位置上定义了一个确认方法

    <myTest ref="myTest" :name="name" :age="age" @confirm="confirm">myTest>
    
    • 1

    对应的方法

    confirm(data) {
    	console.log('接受到了', data);
    },
    
    • 1
    • 2
    • 3

    在子组件中调用,并让父组件接收到
    emit两个属性,第一个对应的是父组件里定义的名字,第二个是让他接收的参数

    tap() {
    	console.log('tap')
    	this.$emit('confirm', 'con'); 
    }
    
    • 1
    • 2
    • 3
    • 4

    在这里插入图片描述

    注意的点

    一、关于上面已经提过的生命周期加载的问题,如果父组件要在初始化的时候调用子组件,可以使用onReady函数

    onReady() {
    	// onReady的生命周期在load后面,$nextTick是等页面刷新完才回调
    	this.$nextTick(() => {
    		this.$refs.myTest.tap(); // 调用子组件的方法
    		console.log(this.$refs.myTest.name); // 调用子组件的属性
    	})
    },
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    二、关于子组件的生命周期,它是不能用onLoad、onLoad这种小程序生命属性,而要用vue的created、mounted

  • 相关阅读:
    【时空融合:改进MRA】
    Linux修改ssh端口
    北京已收录2023开学了《乡村振兴战略下传统村落文化旅游设计》中国建筑出版传媒许少辉八一新书
    用尾指针标识的单循环链表实现队列r
    DXF笔记:根据法向量,求出位置矩阵或坐标系
    虚幻4学习笔记(12)操控导入的角色、动画蓝图、播放蒙太奇和打包、角色重定向
    在使用yum -y install python-openstackclient下载openstack云计算平台管理客户端时
    公司新来了个一年测试经验拿15K的,发现是个00后卷王····
    关于序列化协议,你需要知道的一些内容(3)
    [枚举]Stormwind 2022杭电多校第8场 1011
  • 原文地址:https://blog.csdn.net/Curtisjia/article/details/127828947
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号