uniapp组件的创建和使用

创建组件文件夹

项目根目录下创建components文件夹

创建组件文件

根目录下的组件文件夹如果只是h5和app的话,随便取名就行,例如components文件夹

各大小程序可以参考如下官方给出的目录名

js 复制代码
┌─wxcomponents                  微信小程序自定义组件存放目录
│   └──custom.vue                   微信小程序自定义组件
│
├─mycomponents                  支付宝小程序自定义组件存放目录
│   └──custom.vue                   支付宝小程序自定义组件
│
├─swancomponents                百度小程序自定义组件存放目录
│   └──custom.vue                   百度小程序自定义组件
├─pages
│  └─index
│		└─index.vue
│
├─static
├─main.js
├─App.vue
├─manifest.json
└─pages.json

因为我这个项目要兼容微信小程序和h5以及app的,h5和app任意就行,微信小程序需要为wxcomponents,因此我这里在根目录下创建wxcomponents文件夹

右键wxcomponents文件夹,点击新建组件,我这里起名叫mycomVue点击创建即可,内容如下:

我这里是vue3版本的setUp语言,vue2的换成vue2的语法就好

js 复制代码
<template>
	<button @click="btnClick">点击向父组件发送数据</button>
	<text>父组件传来的数据为:{{num}}</text>
</template>

<script setup>
	import {
		defineEmits,
		defineProps
	} from 'vue';
	const props = defineProps(['num']) // 这里接收的是父组件向子组件发送的数据

	// 子组件享父组件发送事件
	const emit = defineEmits(['customClick']);
	const btnClick = () => {
		emit('customClick', '我是子组件');
	};
</script>

<style>
</style>

页面引入

pages/index/index.vue使用该组件

js 复制代码
<template>
	<div>
		<button @click="hahaha">跳转</button>
		<!-- 给子组件传递数据num为1 -->
		<mycomVue num="1" @customClick="customClick"></mycomVue>
	</div>
</template>

<script setup>
	import mycomVue from '../../wxcomponents/mycom.vue';
	const customClick = (e)=>{
		console.log('父组件接收到数据为:',e);
	}
</script>

<style scoped>

</style>

然后运行到微信小程序和h5和app上面发现都可以兼容了

相关推荐
米粒宝的爸爸1 天前
uniapp在app端,在导航栏设置自定义按钮
uni-app
dssxyz1 天前
uniapp打包微信小程序主包过大问题_uniapp 微信小程序时主包太大和vendor.js过大
javascript·微信小程序·uni-app
xw51 天前
我犯了错,我于是为我的uni-app项目引入环境标志
前端·uni-app
!win !1 天前
被老板怼后,我为uni-app项目引入环境标志
前端·小程序·uni-app
颜渊呐1 天前
uniapp中APPwebview与网页的双向通信
前端·uni-app
白杨木影子被拉长1 天前
多状态映射不同样式(scss语法)
vue.js·uni-app
一念杂记1 天前
免费开源!微信小程序商城源码,快速搭建你的线上商城系统!
微信小程序·uni-app
aklry2 天前
uniapp三步完成生成一维码图片
uni-app
雪芽蓝域zzs2 天前
uniapp 国密sm2加密
uni-app
打不着的大喇叭2 天前
uniapp的光标跟随和打字机效果
前端·javascript·uni-app