陪诊小程序之uniapp(从入门到精通)

1.uniapp如何使用vue3编写页面

复制代码
<template>
	<view class="content">
		<navbar name="navbar组件"></navbar>
		<image class="logo" src="/static/logo.png"></image>
		<view class="text-area">
			<text class="title">{{title}}</text>
		</view>
		<view class="">
			11111
		</view>
		<button @click="handleClick">点我</button>
		<text>总共购买的水果数量{{totalNum}}</text>
		<my-component></my-component>
		<aComponent></aComponent>
		<navbar></navbar>
		<view v-for="item in list" :key="item.name">
			<view>
				1111
			</view>
			<text>{{item.name}}</text>
			<text>{{item.num}}</text>
		</view>
	</view>
</template>

<script setup>
	import  aComponent  from '../../../project/component/component.vue';
	
	import{ref,reactive,computed} from 'vue'
	import{onLoad} from '@dcloudio/uni-app'
	const title=ref('Hello')
	const list=reactive([
		{name:'apple',num:1},
		{name:'orange',num:2},
		{name:'banana',num:3}
	])
	const handleClick=()=>{
		list.forEach(item=>{
			item.num++
		})
	}
	onLoad(()=>{
		console.log('onLode生命周期')
	})
	const totalNum=computed(()=>{
		return list.reduce((total,cur)=>total+cur.num,0)
	})
</script>

<style>
	.content {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}

	.logo {
		height: 200rpx;
		width: 200rpx;
		margin-top: 200rpx;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 50rpx;
	}

	.text-area {
		display: flex;
		justify-content: center;
	}

	.title {
		font-size: 36rpx;
		color: #8f8f94;
	}
</style>

引入组件的三种方式

全局引入

1.引入

import componentVue from './component/component.vue'

2.全局注册

export function createApp() {

const app = createSSRApp(App)
app.component('my-component',componentVue)

return {

app

}

}

3.页面中引入

<my-component></my-component>

局部引入

<script setup>

import aComponent from '../../../project/component/component.vue';

import{ref,reactive,computed} from 'vue'

import{onLoad} from '@dcloudio/uni-app'

const title=ref('Hello')

const list=reactive([

{name:'apple',num:1},

{name:'orange',num:2},

{name:'banana',num:3}

])

const handleClick=()=>{

list.forEach(item=>{

item.num++

})

}

onLoad(()=>{

console.log('onLode生命周期')

})

const totalNum=computed(()=>{

return list.reduce((total,cur)=>total+cur.num,0)

})

</script>

复制代码
<aComponent></aComponent>

自动引入

新建文件夹然后新建组件

组件引入

复制代码
	<navbar></navbar>

2.uniapp组件通信props和$emit和插槽语法

props

组件

复制代码
<template>
	<view>
		navbar组件
	</view>
</template>

<script setup>
import { defineProps } from 'vue';
defineProps(['name','content'])

</script>

<style>

</style>

组件引入数据

复制代码
<navbar name="navbar组件" :content="data"></navbar>

父组件(页面)向子组件传值,如果没传就用默认值

复制代码
<template>
	<view>
		navbar组件
		<view>组件的name属性{{name}}</view>
		<view>组件的content属性{{content}}</view>
		
	</view>
</template>

<script setup>
import { defineProps } from 'vue';
// defineProps(['name','content'])
defineProps({
name:String,	
	content:{
		type:String,
		default:()=>{
			return '默认值';
		}
	}	
})

</script>

<style>

</style>

$emit

navbar.vue

<template>

<view>

navbar组件

<view>组件的name属性{{name}}</view>
<view>组件的content属性{{content}}</view>

<button @click="handleChange">修改content</button>

</view>

</template>

<script setup>

import { defineProps,defineEmits } from 'vue';

// defineProps(['name','content'])

defineProps({

name:String,

content:{

type:String,

default:()=>{

return '默认值';

}

}

})
const emit=defineEmits(['changeData'])
const handleChange=()=>{
emit('changeData','修改后的数据')
}

</script>

<style>

</style>
<navbar :name="navbar组件" :content="data" @changeData="changeData"></navbar>

插槽语法

<navbar :name="navbar组件" :content="data" @changeData="changeData">

<view>我是插槽的内容</view>

</navbar>
<template>

<view>组件</view>

<view>组件的name属性{{name}}</view>

<view>组件的content属性{{content}}</view>

<slot></slot>

<button @click="handleChange">修改content</button>

</template>

<script setup>

import { defineProps,defineEmits } from 'vue';

// defineProps(['name','content'])

defineProps({

name:String,

content:{

type:String,

default:()=>{

return '默认值';

}

}

})

const emit=defineEmits(['changeData'])

const handleChange=()=>{

emit('changeData','修改后的数据')

}

</script>

<style>

</style>

相关推荐
G佳伟14 小时前
‌微信小程序Webview转发页面空白问题解决方案‌
微信小程序·小程序
vx_vxbs6615 小时前
【SSM电动车智能充电服务平台】(免费领源码+演示录像)|可做计算机毕设Java、Python、PHP、小程序APP、C#、爬虫大数据、单片机、文案
java·spring boot·mysql·spring cloud·小程序·php·idea
低代码布道师18 小时前
医疗小程序12出诊列表
低代码·小程序
Coder-coco19 小时前
游戏助手|游戏攻略|基于SprinBoot+vue的游戏攻略系统小程序(源码+数据库+文档)
java·vue.js·spring boot·游戏·小程序·论文·游戏助手
小小王app小程序开发1 天前
盲盒小程序一番赏衍生玩法:魔王赏、非酋赏、狂欢赏差异化分析
小程序
2501_915106321 天前
iOS App 测试工具全景分析,构建从开发调试到线上监控的多阶段工具链体系
android·测试工具·ios·小程序·uni-app·iphone·webview
dchen771 天前
uniapp实现上拉刷新和下拉刷新的两种方式
uni-app
FinelyYang2 天前
uniapp+unipush2.0+WebRTC实现h5一对一视频通话
uni-app·音视频·webrtc
天蓝色的鱼鱼2 天前
mescroll老用户亲测z-paging:这些功能让我果断切换!
前端·uni-app
anyup2 天前
🔥100+ 天,已全面支持鸿蒙!uView Pro 近期更新盘点及未来计划
前端·uni-app·harmonyos