EP37 分享给好友与分享到朋友圈

文件路径: E:/homework/uniappv3tswallpaper/pages/index/index.vue

这两个分享的api引入方法类似声明周期。

<template>
	<view class="homeLayout pageBg">
		<custom-nav-bar title="推荐"></custom-nav-bar>
		<view class="banner">
			<swiper :indicator-dots="true" :autoplay="true" :interval="3000" :duration="1000" circular="true"
				indicator-color="rgba(255,255,255,0.5)" indicator-active-color="rgba(255,255,255,1)">
				<swiper-item v-for="item in bannerList" :key="item._id">
					<image :src="item.picurl" mode="scaleToFill"></image>
				</swiper-item>
			</swiper>
		</view>
		<view class="notice">
			<view class="left">
				<uni-icons type="sound-filled" size="20"></uni-icons>
				<text class="text">公告</text>
			</view>
			<view class="center">
				<swiper :autoplay="true" :interval="3000" :duration="1000" circular vertical>
					<swiper-item v-for="item in noticeList" :key="item._id">
						<navigator url="/pages/notice/detail">
							{{item.title}}
						</navigator>
					</swiper-item>
				</swiper>
			</view>
			<view class="right">
				<uni-icons type="forward" size="16" color="#333"></uni-icons>
			</view>
		</view>
		<view class="select">
			<common-title>
				<template #name>
					每日推荐
				</template>
				<template #custom>
					<view class="date">
						<uni-icons type="calendar"></uni-icons>
						<view class="text">
							<uni-dateformat :date="Date.now()" format="dd号" />
						</view>
					</view>
				</template>
			</common-title>
			<view class="content">
				<scroll-view scroll-x="true">
					<view class="box" v-for="item in randomList" :key="item._id" @click="goPreview">
						<image :src="item.smallPicurl" mode="aspectFill"></image>
					</view>
				</scroll-view>
			</view>
		</view>
		<view class="theme">
			<common-title>
				<template #name>
					专题精选
				</template>
				<template #custom>
					<navigator url="">More+</navigator>
				</template>
			</common-title>
			<view class="content">
				<theme-item v-for="item in classifyList" :key="item._id" :items="item"></theme-item>
				<theme-item :isMore="true"></theme-item>
			</view>
		</view>
	</view>
</template>

<script setup>
	import {
		ref
	} from 'vue';
	import {
		apiGetBanner,
		apiGetDayRandom,
		apiGetRequest,
		apiGetClassify
	} from "@/api/apis.js"
	import {
		onShareAppMessage,
		onShareTimeline
	} from "@dcloudio/uni-app"

	const bannerList = ref([]);
	const randomList = ref([])
	const noticeList = ref([])
	const classifyList = ref([])

	const getBanner = async () => {
		let res = await apiGetBanner()
		bannerList.value = res.data
	};
	const getDayRandom = async () => {
		let res = await apiGetDayRandom()
		randomList.value = res.data
	};
	const getNotice = async () => {
		let res = await apiGetRequest({
			select: true
		})
		noticeList.value = res.data
	}
	const getClassify = async () => {
		let res = await apiGetClassify({
			select: true
		})
		classifyList.value = res.data
	}

	// 点击跳转到壁纸预览页面
	const goPreview = () => {
		uni.navigateTo({
			url: '/pages/preview/preview'
		});
	};

	// 分享给好友
	onShareAppMessage((e) => {
		return {
			title: "壁纸小程序好友",
			path: "/pages/classify/classify"
		}
	})
	// 分享到朋友圈
	onShareTimeline(() => {
		return {
			title: "壁纸小程序朋友圈"
		}
	})

	getBanner()
	getDayRandom()
	getNotice()
	getClassify()
</script>

<style lang="scss">
	.homeLayout {
		.banner {
			width: 750rpx;
			padding: 30rpx 0;

			swiper {
				width: 100%;
				height: 340rpx;

				&-item {
					width: 100%;
					height: 100%;
					padding: 0 30rpx;

					image {
						width: 100%;
						height: 100%;
						border-radius: 10rpx;
					}
				}
			}
		}

		.notice {
			margin: 0 30rpx;
			display: flex;
			flex-direction: row;
			flex-wrap: nowrap;
			align-content: center;
			justify-content: center;
			align-items: center;
			background: gray;
			border-radius: 80rpx;
			height: 80rpx;
			line-height: 80rpx;


			.left {
				width: 140rpx;
				display: flex;
				flex-direction: row;
				flex-wrap: nowrap;
				align-content: center;
				justify-content: center;
				align-items: center;

				:deep() {
					.uni-icons {
						color: $brand-theme-color !important;
					}
				}

				.text {
					color: $brand-theme-color;
					font-weight: 600;
					font-size: 28rpx;
				}
			}

			.center {
				flex: 1;
				height: 100%;

				swiper {
					height: 100%;

					&-item {
						// 以下三条是实现 文字长度超过显示宽度时展示省略号 的关键操作
						overflow: hidden;
						white-space: nowrap;
						text-overflow: ellipsis;
						// 以上三条

						height: 100%;
						color: $text-font-color-3;
						font-size: 30rpx;

						// flex布局与 text-overflow: ellipsis;属性 冲突
						// display: flex;
						// flex-direction: row;
						// flex-wrap: nowrap;
						// align-content: center;
						// align-items: center;
						// justify-content: flex-start;

						align-content: end;
						align-items: end;
					}
				}
			}

			.right {
				width: 70rpx;
				display: flex;
				flex-direction: row;
				flex-wrap: nowrap;
				align-content: center;
				align-items: center;
				justify-content: center;
			}
		}

		.select {
			padding: 50rpx 30rpx 0 30rpx;

			scroll-view {
				white-space: nowrap;

				.box {
					display: inline-block;
					width: 200rpx;
					height: 430rpx;
					margin-right: 15rpx;

					image {
						height: 100%;
						width: 100%;
					}
				}

				:last-child {
					margin-right: 0;
					border-radius: 10rpx;
				}
			}

			.date {
				display: flex;
				flex-direction: row;
				flex-wrap: nowrap;
				align-content: center;
				justify-content: center;
				align-items: center;
				color: $brand-theme-color;

				:deep() {
					.uni-icons {
						color: $brand-theme-color !important;
					}
				}
			}
		}

		.theme {
			padding: 50rpx 30rpx;

			.content {
				display: grid;
				gap: 15rpx;
				grid-template-columns: repeat(3, 1fr);
			}

		}
	}
</style>

文件路径: E:/homework/uniappv3tswallpaper/pages/classify/classify.vue

同时给两个页面做了分享的操作,index和classify。

<template>
	<view class="classLayout pageBg">
		<custom-nav-bar title="分类"></custom-nav-bar>
		<view class="classify">
			<theme-item v-for="item in classifyList" :key="item._id" :items="item"></theme-item>
		</view>
	</view>
</template>

<script setup>
	import {
		ref
	} from 'vue'
	import {
		apiGetClassify
	} from "@/api/apis.js"
	import {
		onShareAppMessage,
		onShareTimeline
	} from "@dcloudio/uni-app"


	const classifyList = ref([])

	const getClassify = async () => {
		let res = await apiGetClassify({
			pageSize: 15
		})
		classifyList.value = res.data
	}

	// 分享给好友
	onShareAppMessage((e) => {
		return {
			title: "壁纸小程序好友",
			path: "/pages/classify/classify"
		}
	})
	// 分享到朋友圈
	onShareTimeline(() => {
		return {
			title: "壁纸小程序朋友圈"
		}
	})

	getClassify()
</script>

<style lang="scss" scoped>
	.classify {
		padding: 30rpx;
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		gap: 15rpx;
	}
</style>

注意:
这里用到各个页面的功能,抽离出来放在 utils 文件夹会比较好,我犯懒了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值