uniapp 购物弹窗组件 (微信小程序)

news2025/1/11 6:10:29

 效果图,暂时只适应单规格,居中弹出和下方弹出,如需求不满足,请自行修改代码

(更新于24/11/15)

居中显示效果

下方弹出效果

html 

<template>
	<view class="" v-if="show"
		:class="mode=='center'?(style_show?'specifications_show_center openAnimation':'specifications_show_center closeAnimation'):mode=='bottom'?(style_show?'specifications_show_bottom  openAnimation':'specifications_show_bottom  closeAnimation'):''"
		@tap.stop="()=>{}">


		<view class="specifications"
			:class="mode=='bottom'?(style_show?'specifications_bottom_open  ':'specifications_bottom_close  '):''"
			@tap.stop="()=>{}">
			<view class="specification">
				<view class="specification_title">请选择规格</view>
				<image class="colseIcon"
					:src="$publicfun.locaAndHttp()?'../../static/all/del.png':$publicfun.httpUrlImg('colse.png')"
					mode="aspectFit" @tap.stop="colosePopue"></image>
				<!-- 商品信息 -->
				<view class="modal-header flex ">
					<view class="header-left ss-m-r-30">
						<image class="sku-image" :src="component_goodsDetail.image" mode="aspectFill"
							@tap.stop="previewImages1(component_goodsDetail.image,1)">
						</image>
					</view>
					<view class="header-right   ">
						<view class="goods-title ss-line-2">{{component_goodsDetail.title||'商品名称' }}</view>
						<view class="header-right-bottom ss-flex ss-col-center ss-row-between">
							<view class="price-text">
								{{is_kongobj=='{}'? Number(component_goodsDetail.price*1).toFixed(2) :Number(chooseSpecificationObject.price*1).toFixed(2)}}
							</view>
							<view class="stock-text ss-m-l-20" v-if="is_kongobj!='{}'">
								库存{{ is_kongobj=='{}'?component_goodsDetail.goods_stock:chooseSpecificationObject.inventory}}件
							</view>
						</view>
					</view>
				</view>
				<view class="specification_title2">
					规格
				</view>
				<view class="specification_title_1">
					<scroll-view scroll-y="true" style="height: 100%;">
						<view>
							<height :hg='30'></height>
							<view class="flex flexwrap">
								<view v-for="(itemall,indexall) in component_goodsDetail.multiplejson" :key="indexall"
									@click.stop="setguigeindex(indexall,itemall)">
									<view
										:class="guigeindex==indexall?'specification_title_1_title specification_title_1_titlec':'specification_title_1_title'"
										v-if='itemall.title'>
										{{itemall.title}}
									</view>
								</view>
							</view>
							<!-- 单规格 -->
							<view class="mt30" v-if="false">
								<view class="specification_title_1_content">
									<view class="specification_title_1_content_flex flex jc ac"
										:class="guigeindex2==index?'specification_title_1_content_flex_activate':''"
										v-for="(item,index) in specification_list[guigeindex].item" :key="index"
										@tap.stop="selective_specification(item.guigechildren,item)">
										<!-- 可用于显示商品图片 -->
										<!-- <image class="image" :src="sheep.$url.cdn(type_return_img(item.id).url)"
											mode="aspectFill" v-if="type_return_img(item.id).url!=''">
										</image> -->
										<view>{{item.name}}</view>
									</view>
									<view class="nogoods" v-if="item.guigechildren.length==0" style="margin: auto;">
										<u-empty text='没有规格~' icon="">
										</u-empty>
									</view>
								</view>
							</view>
						</view>
					</scroll-view>
				</view>
				<view class="" v-if="mode=='center'">
					<view class="selected">
						<text>已选规格:</text>
						{{is_kongobj=='{}'?'未选择':chooseSpecificationObject.title}}
					</view>
				</view>
				<view class="buy-num-box flex jsb ac">
					<view class="label-text">购买数量</view>
					<view class="ShopCar flex jc ac">
						<image class="ShopCaricon"
							:src="$publicfun.locaAndHttp()?'../../static/all/del.png':$publicfun.httpUrlImg('del.png')"
							mode="aspectFit" @tap.stop="delnum(item)"></image>
						<input type="number" v-model="goodsNum" class="ShopCarInp" @blur="inpnum(item)" />
						<image class="ShopCaricon"
							:src="$publicfun.locaAndHttp()?'../../static/all/add.png':$publicfun.httpUrlImg('add.png')"
							mode="aspectFit" @tap.stop="addnum(item)"></image>
					</view>
				</view>
				<view class="sublist" v-if="mode=='center'">
					<view class="sublist_left">
						<view class="">
							<text>总计 </text>
							<text class="TotalPrices">
								<text>¥</text>
								{{is_kongobj=='{}'?'0.00':Number(chooseSpecificationObject.price*goodsNum).toFixed(2) }}
							</text>
						</view>
					</view>
					<view class="sublist_right" @tap.stop="goodsAddCar()">
						<text>+</text> <text>加入购物车</text>
					</view>
				</view>


				<view class="specification_bottombuts" v-if="mode=='bottom'">
					<view class="specification_bottombuts_but specification_bottombuts_ShoppingCart"
						@tap.stop="goodsAddCar()">
						加入购物车
					</view>
					<view class="specification_bottombuts_but specification_bottombuts_PayNow" @tap.stop="newPay()">
						立即购买
					</view>
				</view>
				<view class="" style="width: 100%;height: 30px;" v-if="mode=='bottom'">

				</view>
			</view>
		</view>
	</view>
</template>

js


	export default {
		name: "specification",
		//style_show  主要控制动画效果
		//mode   设置方向弹出
		//show   控制显示不显示
		//goodsDetail  传入的商品信息
		props: ['show', 'style_show', 'goodsDetail', 'mode'],
		data() {
			return {
				orderprive: '',
				style: [], //规格动态样式
				// goodsDetail: { //模拟商品信息
				// 	goods_name: '番茄鸡蛋面',
				// 	goods_price: '9.90',
				// 	goods_stock: 999,
				// 	specification: [{
				// 		goods_name: '规格1',
				// 		goods_price: '9.90',
				// 		goods_stock: 999,
				// 		children: [{
				// 			goods_name: '11',
				// 			goods_price: '6.60',
				// 			goods_stock: 999,
				// 		}]
				// 	}]
				// },
				chooseSpecificationObject: {}, //选中的规格
				guigeindex: 0, //一级规格
				guigeindex2: 0, //二级规格
				component_goodsDetail: {}, //请求接口的商品数据
				goodsNum: 1,


			
			};
		},
		onLoad() {
			
		},
		watch: {
//监听是否有商品id传入进来
			goodsDetail: {
				handler(newName, oldName) {
                    //获取商品信息的接口
					GoodsDetail({
						id: newName.id
					}).then(res => {
						this.component_goodsDetail = res.data;
						this.chooseSpecificationObject = res.data ? res.data.multiplejson[0] : {};
						this.guigeindex = 0;
						console.log(res, '商品详情');
					})
					this.goodsNum = 1;
				},
				immediate: true,
				deep: true
			}
		},
		onShow() {
		
		},
		computed: {
			//判断是否选中规格
			is_kongobj() {
				console.log(this.chooseSpecificationObject);
				return JSON.stringify(this.chooseSpecificationObject); 
			}
		},

		methods: {
			newPay() {
				if (!this.style_show) {
					return
				}
				let that = this;
				//可用于显示弹窗不默认选中规格的判断
				// if (JSON.stringify(this.choose_specification) == '{}') {
				// 	uni.showToast({
				// 		title: "请选择规格",
				// 		icon: "none"
				// 	})
				// 	return
				// }
				// console.log(that.goodsNum);
				// return
                // 直接购买将需要的信息提交到vuex缓存中,用于渲染页面
				this.$store.commit('set_is_immediately', {
					type: 'goodsDetail',
					id: that.component_goodsDetail.id, //id
					item: that.chooseSpecificationObject, //规格名称
					count: that.goodsNum,
					goodsDetail: [that.component_goodsDetail] //商品列表数组
				})
                //跳转到提交订单页面
				this.$publicfun.navigateTo('/pagesA/SubmitOrder/SubmitOrder')
				this.colosePopue()
			},
			//选中规格
			setguigeindex(index, item) {
				if (!this.style_show) {
					return
				}
				this.chooseSpecificationObject = item;
				this.guigeindex = index;
				if (this.goodsNum > this.chooseSpecificationObject.inventory) {
					this.goodsNum = this.chooseSpecificationObject.inventory;
				}

			},
			//删除购物车数量
			delnum() {
				if (!this.style_show) {
					return
				}
				if (this.goodsNum > 1) {
					this.goodsNum--;
				} else {
					//数量少于1 关闭弹窗
					this.colosePopue()
				}
			},
			//添加购物车数量
			addnum() {
				if (!this.style_show) {
					return
				}
				if (this.goodsNum < this.chooseSpecificationObject.inventory) {
					this.goodsNum++;
				} else {
					uni.showToast({
						title: '超出购买数量~',
						icon: "none"
					})
				}
			},
			//手动输入购买数量
			inpnum() {
				if (!this.style_show) {
					return
				}
				if (this.goodsNum > this.chooseSpecificationObject.inventory) {
					this.goodsNum = this.chooseSpecificationObject.inventory;
				}
				if (this.goodsNum == '') {
					// this.colosePopue()
					this.goodsNum = 1;
					this.$publicfun.showToast('购买数量不得少于1~')
				}
				if (this.goodsNum <= 0) {
					// this.colosePopue()
					this.goodsNum = 1;
					this.$publicfun.showToast('购买数量不得少于1~')
				}
			},
			//预览商品图片
			previewImages1(url, index) {
//因为动画效果是 用透明度为0,再消失,透明度改变的时候还可以点击,加这个判断是很必要的
				if (!this.style_show) {
					return
				}
                //预览图片
				this.$publicfun.previewImage({
					url: url,
					index: index
				})
			},
			//关闭弹窗
			colosePopue() {
				if (!this.style_show) {
					return
				}
				this.$emit('closeCar')
				// this.component_goodsDetail={};
			},
			//添加购物车
			goodsAddCar() {
				if (!this.style_show) {
					return
				}
				let that = this;
                //这是添加到购物车
				carAddAndDel({
					id: this.goodsDetail.id,
					count: this.goodsNum,
					item_name: this.chooseSpecificationObject.title,
					type: 'add'
				}).then(res => {
					if (res.code == 1) {
                        //通过vuex更新数据
						this.$store.dispatch('fun_set_shopCar');
						// console.log(res);
						that.colosePopue();
						uni.showToast({
							title: '已添加到购物车~',
							icon: "none"
						})
					} else {
						uni.showToast({
							title: res.msg,
							icon: "none"
						})
					}
				})
			},
			
		}
	}

css部分

//居中显示
	.specifications_show_center {
		width: 100vw;
		height: 100vh;
		position: fixed;
		top: 0;
		left: 0;
		z-index: 999999999;
		background: rgba(0, 0, 0, 0.6);
		display: flex;
		justify-content: center;
		align-items: center;
		opacity: 1;
		border-radius: 18rpx;
	}

	.openAnimation {
		animation: slow_show 0.3s linear;
	}

	.closeAnimation {
		opacity: 0 !important;
		animation: close_slow_show 0.3s linear;
	}

	@keyframes slow_show {
		0% {
			opacity: 0;
		}

		100% {
			opacity: 1;
		}
	}

	@keyframes close_slow_show {
		0% {
			opacity: 1;
		}

		100% {
			opacity: 0;
		}
	}

	//从下方弹出显示
	.specifications_show_bottom {
		width: 100vw;
		height: 100vh;
		position: fixed;
		bottom: 0;
		left: 0;
		z-index: 999999999;
		background: rgba(0, 0, 0, 0.6);
		display: flex;
		justify-content: center;
		align-items: flex-end;
		opacity: 1;
		border-radius: 18rpx;

		.specifications {
			width: 100% !important;
			position: absolute;
			bottom: 0;
			left: 0;
			padding: 30rpx 50rpx !important;
		}

		.specifications_bottom_open {
			animation: From_bottom_to_top 0.22s linear;
		}

		.specifications_bottom_close {
			animation: From_top_to_bottom 0.3s linear;
		}
	}


	@keyframes From_bottom_to_top {
		0% {
			bottom: -100%;
		}

		100% {
			bottom: 0;
		}
	}

	@keyframes From_top_to_bottom {
		0% {
			bottom: 0;
		}

		100% {
			bottom: -100%;
		}
	}

//以上是动画效果


	.specifications {
		width: 690rpx;
		padding: 30rpx;
		box-sizing: border-box;
		background: #fff;
		border-radius: 18rpx;




		.buy-num-box {
			height: 100rpx;
			// padding-left: 20rpx;
			// box-sizing: border-box;

			.ShopCar {
				.ShopCaricon {
					width: 46rpx;
					height: 46rpx;
				}

				.ShopCarInp {
					width: 100rpx;
					height: 46rpx;
					text-align: center;
				}
			}
		}

		.modal-header {
			// position: relative;
			padding: 20rpx 0;
			margin-top: 20rpx;

			.sku-image {
				width: 160rpx;
				height: 160rpx;
				border-radius: 10rpx;
				background: darkslategray;
			}

			.header-right {
				width: calc(100% - 160rpx - 20rpx);
				height: 160rpx;
				display: flex;
				flex-direction: column;
				justify-content: space-between;
				margin-left: 20rpx;
			}

			.close-icon {
				position: absolute;
				top: 10rpx;
				right: 20rpx;
				font-size: 46rpx;
				opacity: 0.2;
			}

			.goods-title {
				font-size: 28rpx;
				font-weight: bold;
				line-height: 42rpx;
				position: relative;
				overflow: hidden;
				text-overflow: ellipsis;
				display: -webkit-box;
				-webkit-box-orient: vertical;
				-webkit-line-clamp: 2;


				.tig {
					border: 2rpx solid #ff6000;
					border-radius: 4rpx;
					width: 126rpx;
					height: 38rpx;
					position: absolute;
					left: 0;
					top: 0;

					.tig-icon {
						width: 40rpx;
						height: 40rpx;
						background: #ff6000;
						margin-left: -2rpx;
						border-radius: 4rpx 0 0 4rpx;

						.groupon-tag {
							width: 32rpx;
							height: 32rpx;
						}
					}

					.tig-title {
						font-size: 24rpx;
						font-weight: 500;
						line-height: normal;
						color: #ff6000;
						width: 86rpx;
						display: flex;
						justify-content: center;
						align-items: center;
					}
				}

				.info-title {
					text-indent: 132rpx;
				}
			}

			.header-right-bottom {
				display: flex;
				justify-content: space-between;
				align-items: center;
			}

			.price-text {
				font-size: 30rpx;
				font-weight: 500;
				color: red;
				font-family: OPPOSANS;

				&::before {
					content: '¥';
					font-size: 24rpx;
				}
			}

			.stock-text {
				font-size: 26rpx;
				color: #999999;
			}
		}

		.d_box {
			.d_box_item {
				font-size: 34rpx;
				color: #3d3d3d;
				width: 45%;
				margin-bottom: 20rpx;
			}
		}

		.specification {

			background: #FFFFFF;
			border-radius: 12rpx;
			position: relative;
			z-index: 10074;

			.specification_title {
				text-align: center;
				font-size: 38rpx;
				font-weight: 600;
				color: #353535;
				margin: 0 auto;
			}

			.colseIcon {
				width: 40rpx;
				height: 40rpx;
				position: absolute;
				right: 0rpx;
				top: 0rpx;
			}

			.specification_title2 {
				font-size: 38rpx;
				font-weight: 600;
				color: #353535;
				margin: 0 auto;
				margin-bottom: 30rpx;
			}

			.specification_goods_title {
				font-size: 38rpx;
				font-weight: 600;
			}

			.specification_title_1 {
				width: 100%;
				max-height: 400rpx !important;
				margin: 0 auto;

				.specification_title_1_title {
					font-size: 32rpx;
					font-weight: 600;
					color: #676767;
					// color: $AccentColor;
					display: inline-block;
					padding: 10rpx 20rpx;
					text-align: center;
					background: #fff;
					border-radius: 18rpx;
					white-space: nowrap;
					// border: 1rpx solid $AccentColor !important;
					border: 1rpx solid #676767 !important;
					margin-right: 10rpx;
					margin-bottom: 10rpx;
				}



				.specification_title_1_titlec {
					color: $AccentColor !important;
					// background: $AccentColor !important;
					border: 1rpx solid $AccentColor !important;
				}




				.specification_title_1_content {
					display: flex;
					flex-wrap: wrap;
					// overflow-x: auto;
					display: -webkit-box;
					-webkit-overflow-scrolling: touch;

					.specification_title_1_content_flex_activate {
						background: $AccentColor !important;
						border: 1rpx solid $AccentColor !important;
						color: #fff !important;
					}

					.font_sizi_1 {
						color: $AccentColor;
					}

					.font_sizi_2 {
						border-left: 1rpx solid $AccentColor;
					}

					.specification_title_1_content_flex {
						// height: 63rpx;
						background: #FFFFFF;
						border-radius: 14rpx;
						border: 1rpx solid #999;
						margin-right: 20rpx;
						text-align: center;
						// line-height: 63rpx;
						font-size: 28rpx;
						font-weight: 400;
						color: #343434;
						padding: 10rpx 20rpx;
						margin-bottom: 20rpx;

						.image {
							width: 60rpx;
							height: 60rpx;
							margin-right: 20rpx;
							border-radius: 12rpx;
						}
					}
				}
			}

			.close {
				position: absolute;
				bottom: -150rpx;
				left: 50%;
				transform: translateX(-50%);
			}
		}

		.selected {
			width: 100%;
			padding: 20rpx 0;
			background: #F5F5F5;
			margin-top: 60rpx;

			text {
				font-size: 24rpx;
				font-weight: 400;
				color: #363636;
			}

			text:nth-child(1) {
				font-size: 24rpx;
				font-weight: 400;
				color: #676767;
				padding: 0 20rpx;
				margin-left: 10rpx;
			}
		}

		.sublist {
			display: flex;
			align-items: center;
			justify-content: space-between;
			margin-top: 30rpx;
			// padding: 30rpx 40rpx;

			.sublist_left {
				.TotalPrices {
					margin-left: 10rpx;
				}

				text:nth-child(1) {
					font-size: 28rpx;
					font-weight: 600;
					color: #363636;
				}

				text:nth-child(2) {
					font-size: 28rpx;
					font-weight: 600;
					color: #FF0000;

					text:nth-child(1) {
						font-size: 28rpx;
						font-weight: 600;
						color: #FF0000;
						font-size: 24rpx;
					}
				}
			}

			.sublist_right {
				width: 234rpx;
				height: 62rpx;
				background: $AccentColor;
				border-radius: 12rpx;
				font-size: 32rpx;
				font-weight: 500;
				color: #F3FCFF;
				line-height: 62rpx;
				text-align: center;
			}
		}


		//从下方弹出的弹窗按钮
		.specification_bottombuts {
			width: 100%;
			margin: auto;
			display: flex;
			justify-content: space-between;
			align-items: center;
			margin-top: 20rpx;

			.specification_bottombuts_but {
				width: 50%;
				padding: 25rpx 20rpx;
				font-size: 28rpx;
				font-weight: bold;
				color: #fff;
				text-align: center;
			}

			.specification_bottombuts_ShoppingCart {
				background: #9dceff;
				border-radius: 99px 0 0 99px;
			}

			.specification_bottombuts_PayNow {
				background: #0a84ff;
				border-radius: 0px 99px 99px 0px;
			}
		}


		.minus {
			width: 25px;
			height: 25px;
			border-width: 1px;
			border-color: #E6E6E6;
			border-style: solid;
			border-top-left-radius: 100px;
			border-top-right-radius: 100px;
			border-bottom-left-radius: 100px;
			border-bottom-right-radius: 100px;
			@include flex;
			justify-content: center;
			align-items: center;
		}

		.input {
			padding: 0 10px;
		}

		.plus {
			width: 25px;
			height: 25px;
			border-width: 1px;
			background-color: #00B8FB;
			border-color: #00B8FB;
			border-style: solid;
			border-top-left-radius: 100px;
			border-top-right-radius: 100px;
			border-bottom-left-radius: 100px;
			border-bottom-right-radius: 100px;
			@include flex;
			justify-content: center;
			align-items: center;
		}
	}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2245110.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

(Linux)搭建静态网站——基于http/https协议的静态网站

简单了解nginx配置文件 1.下载并开启nginx服务 下载 [rootlocalhost ~]# dnf install nginx -y开启 [rootlocalhost ~]# systemctl restart nginx 1.(1)搭建静态网站——基于http协议的静态网站 实验1&#xff1a;搭建一个web服务器&#xff0c;访问该服务器时显示“hello w…

爬取网易云音乐热歌榜:从入门到实战

爬取网易云音乐热歌榜&#xff1a;从入门到实战 前提声明 爬虫应遵守目标网站的robots.txt协议&#xff0c;尊重版权和用户隐私。本代码仅供学习和研究使用&#xff0c;不得用于商业用途。请确保在合法合规的前提下使用本代码。本代码所爬音乐为公开可选择的音乐 目录 引言…

Quality minus junk论文阅读

Quality minus junk论文阅读 文章目录 Quality minus junk论文阅读 AbstractTheoretical FrameworkEmpirical AnalysisDataQuality scorePortfoliosEx ante quality forecasts fundamentals Results and DiscussionThe price of qualityUnderstanding the price of quality: th…

利用RAGflow和LM Studio建立食品法规问答系统

前言 食品企业在管理标准、法规&#xff0c;特别是食品原料、特殊食品法规时&#xff0c;难以通过速查法规得到准确的结果。随着AI技术的发展&#xff0c;互联网上出现很多AI知识库的解决方案。 经过一轮测试&#xff0c;找到问题抓手、打通业务底层逻辑、对齐行业颗粒度、沉…

类和对象——拷贝构造函数,赋值运算符重载(C++)

1.拷⻉构造函数 如果⼀个构造函数的第⼀个参数是自身类类型的引用&#xff0c;且任何额外的参数都有默认值&#xff0c;则此构造函数也叫做拷贝构造函数&#xff0c;也就是说拷贝构造是⼀个特殊的构造函数。 // 拷贝构造函数//d2(d1) Date(const Date& d) {_year d._yea…

浅谈软件开发中的yield关键字:从餐厅服务理解异步编程之美

在现代软件开发中&#xff0c;处理大量数据流时经常会遇到性能和内存消耗的问题。传统的编程方式往往是一次性获取所有数据&#xff0c;这就像餐厅厨师要把所有菜品做完才上菜一样&#xff0c;既不高效也不够灵活。而yield关键字的出现&#xff0c;为我们提供了一种优雅的解决方…

散户持股增厚工具:智能T0算法交易

最近市场很多都说牛市&#xff0c;但是大多数朋友怎么来的又怎么吐出去了。这会儿我们用T0的智能算法交易又可以增厚我们的持仓收益。简单来说&#xff0c;就是基于用户原有的股票持仓&#xff0c;针对同一标的&#xff0c;配合智能T0算法&#xff0c;每天全自动操作&#xff0…

[ 网络安全介绍 1 ] 什么是网络安全?

&#x1f36c; 博主介绍 &#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 _PowerShell &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 &#x1f389;点赞➕评论➕收藏 养成习…

R语言4.3.0安装教程【附安装包】

R for Windows是一个免费的用于统计计算和统计制图的优秀工具&#xff0c;是R语言开发工具。它拥有数据存储和处理系统、数组运算工具&#xff08;其向量、矩阵运算方面功能尤其强大&#xff09;、完整连贯的统计分析工具、优秀的统计制图等功能。提供的图形界面&#xff0c;可…

【网络】Socket编程TCP/UDP序列化和反序列化理解应用层(C++实现)Json::Value

主页&#xff1a;醋溜马桶圈-CSDN博客 专栏&#xff1a;计算机网络原理_醋溜马桶圈的博客-CSDN博客 gitee&#xff1a;mnxcc (mnxcc) - Gitee.com 目录 1.基于Socket的UDP和TCP编程介绍 1.1 基本TCP客户—服务器程序设计基本框架 ​编辑1.2 基本UDP客户—服务器程序设计基本框…

小熊派Nano接入华为云

一、华为云IoTDA创建产品 创建如下服务&#xff0c;并添加对应的属性和命令。 二、小熊派接入 根据小熊派官方示例代码D6完成了小熊派接入华为云并实现属性上传命令下发。源码&#xff1a;小熊派开源社区/BearPi-HM_Nano 1. MQTT连接代码分析 这部分代码在oc_mqtt.c和oc_mq…

如何在 Ubuntu 上安装 Jellyfin 媒体服务器

Jellyfin 是一个开源的媒体服务器软件&#xff0c;让你可以整理、管理和流式传输你的个人媒体收藏&#xff0c;比如电影、音乐、电视节目和照片&#xff0c;而且完全免费&#xff0c;没有订阅费用或数据收集的担忧。 简介 媒体管理&#xff1a;Jellyfin 整理媒体库&#xff0…

Android集成FCM(Firebace Cloud Messaging )

集成FCM官方文档 Firebace主页面 将 Firebase 添加到您的 Android 应用 1、进入Firebace页面&#xff0c;创建自己的项目 2、点击自己创建好的项目&#xff0c;在右侧选择Cloud Messaging 3、点击Android去创建 google-services.json 4、将下载的 google-services.json 文件…

实时直播平台如何实现美颜功能?第三方美颜API与美颜SDK的技术

通过实时美颜技术&#xff0c;主播可以轻松实现肤色优化、五官调整以及滤镜效果&#xff0c;极大提升观众的观看体验。本篇文章&#xff0c;小编将深入讲解实时直播平台如何通过第三方美颜API与美颜SDK实现美颜功能&#xff0c;以及其中的技术实现与关键要点。 一、实时美颜的…

使用GDB或Delve对已经运行起来的Go程序进行远程调试

同步发布在我的博客&#xff0c;欢迎来点赞。 使用 GDB 或 Delve 对已经运行起来的 Go 程序进行远程调试 使用 GDB 或 Delve 对已经运行起来的 Go 程序进行远程调试 背景 Java 程序可以很方便地通过 jdwp 参数指定一个对外端口进行远程调试&#xff0c;如 java \ -agentlib…

Ubuntu问题 -- 设置ubuntu的IP为静态IP (图形化界面设置) 小白友好

目的 为了将ubuntu服务器IP固定, 方便ssh连接人在服务器前使用图形化界面设置 设置 找到自己的网卡名称, 我的是 eno1, 并进入设置界面 查看当前的IP, 网关, 掩码和DNS (注意对应eno1) nmcli dev show掩码可以通过以下命令查看完整的 (注意对应eno1) , 我这里是255.255.255.…

实现一个string的indexof方法,给出时空复杂度估计

文心快码(BaiduComate)是基于百度文心大模型&#xff0c;在研发全流程全场景下为开发者提供辅助建议的智能代码助手。结合百度积累多年的编程现场大数据、外部优秀开源数据&#xff0c;可为开发者生成更符合实际研发场景的优秀代码&#xff0c;提升编码效率&#xff0c;释放“十…

ESP8266 STA模式TCP客户端 电脑手机网络调试助手

1.STA模式TCP客户端和电脑网络调试助手 2.STA模式TCP客户端和手机网络调试助手

【lamafactory BLEU ROUGLE L评测】

1、BLEU/ROUGLE评测界面 2、这个是用BLEU 和ROUGL来评测 目录&#xff1a;saves/Qwen2-7B-Chat/lora/eval_2024-11-14-16-28-19/ 在saves文件夹 生成的文件如下 all_results.json文件 说明模型在这个测试集上是不好的 3、可以查看预测结果的文件 predict_result.json

Ros Noetic 20.04 跑通mpc_ros包保姆级教程

前言: 本文将简述mpc_ros包在noetic20.04中的安装,mpc是 一种跟踪、MPC_ROS 是一个基于ROS(Robot Operating System)的模型预测控制(Model Predictive Control,MPC)库。该项目旨在为机器人控制提供一个灵活且高效的MPC实现,使得开发者能够在ROS环境中轻松集成和使用MPC…