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上面发现都可以兼容了

相关推荐
自然 醒12 小时前
uni-app开发微信小程序,如何使用towxml去渲染md格式和html标签格式的内容?
微信小程序·uni-app·html
CHB14 小时前
uni-agent,你的数字员工来了
人工智能·uni-app·vibecoding
h_jQuery14 小时前
uniapp使用canvas实现逐字书写任意文字内容,后合成一张图片提交
前端·javascript·uni-app
困困的果果头14 小时前
【uniapp】解决H5嵌套在web-view中时打包页面与状态栏重叠
前端·uni-app
前端 贾公子14 小时前
Uniapp 使用 UQRCode 创建二维码
uni-app
Rattenking14 小时前
uni-app组件开发----自定义数字键盘组件
前端·javascript·uni-app
笨笨狗吞噬者15 小时前
代理的妙用:uni-app 小程序是怎样用 `Proxy` 和 `wrapper` 抹平平台差异的
前端·微信小程序·uni-app
软希网分享源码2 天前
中英双语言量化交易投资源码/跟单搬砖区块链交易所源码/前端uniapp纯源码+后端
前端·uni-app·区块链·中英双语言量化交易投资源码
小成Coder2 天前
UniApp 如何调用鸿蒙预加载
uni-app·harmonyos·鸿蒙