外卖点餐系统小程序

news2025/1/11 14:32:18
目录
        • 开发前准备
          • 项目展示
          • 项目分析
          • 项目初始化
          • 封装网络请求
        • 任务1 商家首页
          • 任务分析
          • 焦点图切换
          • 中间区域单击跳转到菜单列表
          • 底部商品展示
        • 任务2 菜单列表
          • 任务分析
          • 折扣信息区
          • 设计菜单列表布局
          • 请求数据
          • 实现菜单栏联动单品列表功能
        • 任务3 购物车
          • 任务分析
          • 设计底部购物车区域
          • 添加商品到购物车
          • 购物车界面
          • 添加商品数量
          • 减少商品数量
          • 清空购物车
          • 满减优惠
          • 跳转到订单确认页面
        • 任务4 订单确认
          • 任务分析
          • 订单信息
          • 备注功能实现
          • 支付功能
          • 支付成功返回订单列表
        • 任务5 订单详情
          • 任务分析
          • 取餐部分信息展示
          • 订单详情部分
          • 订单信息部分
        • 任务6 订单列表
          • 任务分析
          • 订单列表设计
          • 封装数据请求
          • 初始化页面
          • 下拉刷新功能
          • 上拉触底功能
        • 任务7 消费记录
          • 任务分析
          • 设计消费记录列表
        • 成果展示

划重点哦👉👉👉点击有惊喜哦文章地址

随着微信小程序的迅速发展与普及,外卖、点餐小程序越来越多地被使用,它不像APP那样全面,有非常复杂的功能,而是提供了快速购物的通道,无需下载使用,不用安装APP,简化了APP的很多功能,之加入核心功能呢。

点餐系统小程序主要完成底部标签导航的设计、幻灯片轮播效果设计、菜单列表的效果显示、购物车功能实现、订单详情页面设计、订单列表设计、消费记录页面的设计。

开发前准备
项目展示

desc
desc

项目分析

订餐系统任务需求:

  • 底部标签导航切换。
  • 在“首页” 单击“开启点餐之旅”,跳转到菜单列表界面。
  • 在菜单列表页面中,单击“+”把所选商品加入购物车。
  • 如果购物车中商品数量为0时,单击购物车图标不会展开购物车列表,如果不为0时,单击购物车,可以操作购物车。
  • 在“订单列表”界面,查看订单状态,显示是否取餐。
  • “消费记录”界面显示历史订单消费记录信息。
项目初始化
路径作用
images存放图片
pages/index首页
pages/list菜单列表页面
pages/order/list订单列表页面
pages/order/detail订单详情页面
pages/order/balance订单确认页面
pages/record消费记录页面
utils/fetch.js网络请求封装页面
utils/common.wxss页面公有样式库
app.js定义全局变量
app.json配置pages、window、tabBar
app.wxss公共样式页面
封装网络请求

为什么要封装网络请求?

  • 本项目采用的 网络请求 的方式来获取数据。
  • 小程序官方文档提供了网络请求API,传递参数,对不同请求做不同处理。
  • 请求接口中有部分请求参数以及响应结果处理都很类似。
module.exports = function(path, data, method) {
  return new Promise((resolve, reject) => {
    wx.request({
      url: '',   // 接口地址
      method: method,  data: data,  header: {'Content-Type': 'json' }, 
      success: resolve,
      fail: function() {// 请求失败执行fail操作
        reject()
        wx.showModal({ showCancel: false, title: '失败' }) }
    })
  }) }

// 引入fetch.js文件
const fetch = require('../../utils/fetch.js')
// 接口请求
fetch(path).then((res) => {
  // 请求成功的操作
 },() => {
  // 请求失败操作
});

任务1 商家首页
任务分析

首页内容任务分析:

  • 顶部商品的滑块容器区域。
  • 中间部分新品推送区域。
  • 底部商品列表展示区域。
  • 当进入到首页时开始请求接口,此时会出现弹窗,提示努力加载中;请求成功后,关闭弹窗,获取数据渲染首页。
焦点图切换

desc
在首页顶部区域,设置了焦点图切换的效果,图片资源通过请求接口获取数据。焦点图区域的布局:

index.wxml

<block wx:for="{{listData}}">
  <swiper>
      <swiper-item>
        <image></image>
      </swiper-item>
  </swiper>
</block>

焦点图切换:

index.js

//onLoad()函数
onLoad: function(options) {
	//请求首页接口
    wx.showLoading({ title: '努力加载中' })
     fetch(‘food/index’).then(res => { // 请求成功,关闭提示框
      //请求成功
	  wx.hideLoading();
      // 把接口返回数据给listData
      this.setData({ listData: res.data })
    }, () => {   // 请求失败,关闭提示框,执行fetch.js文件中的fail方法
        wx.hideLoading()
    })
  }

 onLoad: function(options) {
    wx.showLoading({ title: '努力加载中' })
     fetch(‘food/index’).then(res => { // 请求成功,关闭提示框
      wx.hideLoading();
      // 把接口返回数据给listData
      this.setData({ listData: res.data })
    }, () => {   // 请求失败,关闭提示框,执行fetch.js文件中的fail方法
        wx.hideLoading()
    })
  }
中间区域单击跳转到菜单列表

desc
首页中间部分展示了手机点餐的推广banner图,单击“开启订餐之旅”跳转到菜单列表,引导顾客进行点餐,中间区域的布局:

index.wxml


<block wx:for="{{listData}}">  
<!-- listData 为后台返回的数据 -->
<view bindtap="gostart">
<image></image>
</block>	

index.js

gostart: function(){
//wx.navigateTo()实现跳转
  wx.navigateTo({ url: '../list/list' })
}
底部商品展示

desc
底部区域的布局:

index.wxml

<block wx:for="{{listData}}">  
<view  wx:for="{{item.image_bottom}}" 
    wx:for-item="bottomItem" >
      <image></image>
    </view>
</block>	
任务2 菜单列表
任务分析

菜单列表任务分析:

  • 顶部折扣信息区域。
  • 左侧菜单栏区域。
  • 右侧单品列表区域。
  • 菜单栏和单品间实现单击联动效果。
折扣信息区

desc
展示商家的折扣活动信息或店铺优惠信息,折扣信息区页面结构布局:

list.wxml


<!-- 折扣信息区 -->
<view class="discount">
  <text class="discount-txt"></text>50元减10元(在线支付专享)
</view>
设计菜单列表布局

pages/list/list.wxml文件,左侧菜单列表页面结构布局:
desc
list.wxml

<scroll-view class="left-menu" scroll-y="true">
    <view wx:for="{{listData}}" wx:key="{{index}}" data-index="{{index}}" bindtap="selectMenu">
      <view class="list-menu-name">{{item.name}}</view>
    </view>

pages/list/list.wxml文件,右侧菜单列表页面结构布局:

desc
list.wxml

<scroll-view scroll-y="true" style="height:1200rpx;">
    <view class="content" id="a{{index}}" wx:for="{{listData}}"  wx:key="lists">
      <view class="list-tab">view>
      <view class="content-list" wx:for="{{item.foods}}" wx:for-item="items"> </view>
</view>
</scroll-view>
请求数据

list.js

const fetch = require('../../utils/fetch.js')
Page({
 data:{ loading:false }  // false,不显示底部操作菜单
 onLoad: function(options) {
     wx.showLoading({ title: '努力加载中' })
       fetch('food/list').then(res => { 
       wx.hideLoading();
       this.setData({  listData: res.data ,loading:true })
     }, () => {   wx.hideLoading()   })
   }
})	
实现菜单栏联动单品列表功能

list.js



Page({
  data: {
    activeIndex: 0,
    toView: 'a0',
    loading: false
  },
  // 左侧菜单项选择
  selectMenu: function(e) {}
})
	
任务3 购物车
任务分析

购物车任务分析:

  • 当购物车里商品数量为0时,购物车图标为灰色,处于不可单击状态。
  • 当商品数量不为0时,在购物车图标的右上角显示商品数量,图标变为可单击状态。
  • 单击购物车可以展开里面的商品,此时可以添加或者减少商品数量,动态计算总金额。
  • 单击清空购物车,商品数量和商品总价都变为0,购物车图标切换到灰色,此时不可单击
设计底部购物车区域

菜单列表页面数据请求成功后,loading值设为true,显示底部购物车区域。当购物车里商品数量为0时,购物车图标为灰色,处于不可单击状态

desc
list.wxml

<!-- 接口请求成功后,loading为 true -->
<view class="bottom-operate-menu" wx:if="{{loading}}">
  <view class="shopping-cart">  </view>
  <view class="submit-btn {{sumMonney!=0?'activity-color-bg':'' }}"  bindtap="goBalance">  </view>
</view>	
添加商品到购物车

单击图标“+”,把商品添加到购物车。

desclist.js

Page({
  data: {
    activeIndex: 0,
    currentType: 0,
    currentIndex: 0,
    loading: false
  },
  // 加入购物车
  addToCart: function(e) {}
})	

购物车界面

desc
list.wxml



<!-- 遮罩层 -->
<view class="drawer-screen" bindtap="showCartList" data-statu="close"  wx:if="{{showCart}}"></view>
     <!-- 商品列表 -->
     <view 
     class="cartlist-content" wx:if="{{showCart}}">
     <scroll-view scroll-y="true" class="{{cartList.length>5?'cart-scroll-list':''}}"></scroll-view>
</view>

list.js

showCartList: function() {
    if (this.data.cartList.length != 0) {
      this.setData({ showCart: !this.data.showCart });  }
  }	

添加商品数量

desc
list.js



Page({
  // 购物车添加商品数量
  addNumber: function(e) {  }
})	

减少商品数量

desc
list.js

Page({
  // 购物车减少商品数量
  decNumber: function(e) {  }
})	

清空购物车

desc
list.js



Page({
clearCartList: function() {
    this.setData({
      cartList: [],  	// 商品列表为空
      showCart: false, // 不展开购物车
      sumMonney: 0,
      cupNumber: 0
    })
  }
})	
满减优惠

desc
list.wxml

<view class="cut-bar" wx:if="{{sumMonney==0&&loading}}"></view>
<view class="cut-bar" wx:if="{{sumMonney<25&&sumMonney!=0&&loading}}"></view>	

跳转到订单确认页面

desc
list.js


const fetch = require('../../utils/fetch.js')
pages({
  // 单击"选好了",判断页面是否跳转
  goBalance: function(e) {}
})	

任务4 订单确认
任务分析

订单确认页面任务分析:

  • 请求商品订单接口。
  • 获取到接口数据,渲染页面。
订单信息

desc
balance.wxml

  <view class="top-bar"></view>
  <!-- 订单详情 -->
  <view class="order-info">
   <view class="cart-list-box" wx:for="{{order.foods}}" wx:for-item="item" wx:key="list"></view>
    <view class="order-cut" wx:if="{{order.promotion.length > 0}}"></view>
    <view class="order-sum"></view>
</view>	

balance.js



const fetch = require('../../../utils/fetch.js')
Page({
onLoad: function(options) {
    // 请求订单接口
   fetch('food/order', {: options.order_id}).then(res => {})
} order_id

备注功能实现

desc
balance.wxml


<!-- 备注 -->
<view class="note">
  <textarea maxlength="{{max}}" placeholder="如有其他要求,请输入备注" bindinput="listenerTextarea" class="note-text">{{note}}</textarea>
</view>

balance.js


listenerTextarea: function(e) {
    var note = e.detail.value
  // 存储note值 
    wx.setStorageSync('note', note)
}

detail.js


onLoad: function (options) {
    // 获取note值
    var note = wx.getStorageSync('note')
  }
支付功能

desc
balance.wxml


 <view bindtap="gotopay">
    <view>去支付</view>
</view>


balance.js


gotopay: function(e) {
  fetch('food/pay', {order_id:order_id},method).then((res)=>{} )
}
支付成功返回订单列表

desc
app.js


App({
  // 定义全局变量:是否刷新页面。为false不执行刷新
  isReloadOrderList: false
}) 


order/detail/detail.js


onUnload:function(){
    var app = getApp(); 
     // 支付成功之后调到订单页面,通知订单页刷新
    app.isReloadOrderList = true
    wx.switchTab({ url: '/pages/order/list/list‘ })
  }
任务5 订单详情
任务分析

订单详情页面任务分析:

  • 支付成功之后跳转到订单详情页面pages/order/detail/detail.wxml。
  • 发起网络情求,获取订单信息。
  • 信息包括取餐号、订单信息、订单号码、订单时间等。
取餐部分信息展示

desc
order/detail/detail.wxml

<view class="go-center go-top-10">
  <view class="card-box">
    <view class="card-fetch">取餐号</view>
     <view class="go-top-10" ></view>
</view>

订单详情部分

desc
order/detail/detail.wxml

<view class="order-info">
  <view class="order-info-title">订单详情</view>
  <view class="cart-list-box"></view>
  <view class="cart-list-box"></view>
  <view class=“order-sum"></view>
</view>
订单信息部分

desc
order/detail/detail.wxml

<view class="order-info">
  <view class="order-info-title"></view>
  <view class="order-info-title"></view>
  <view class="order-info-title"></view>
</view>
<view class="go-center">...</view>
任务6 订单列表
任务分析

订单列表页面任务分析:

  • pages/order/list/list.wxml文件为tabBar页面,两种打开方式。
  • 直接切换底部标签导航进入订单页面,此时不执行页面刷新。
  • 在订单支付成功之后,单击左上角返回也可以回到订单列表页面,此时需要执行页面刷新。
订单列表设计

在订单列表页面,展示订单信息,显示订单的下单时间和订单的总价、取餐状态、单击“查看详情”,根据订单内标的order_id 跳转到订单详情页面,效果图如下:
descorder/list/list.wxml

<scroll-view class="container" scroll-y="true">
   <block wx:for="{{orderList}}" wx:for-item="item" wx:for-index="idx" wx:key="{{item.order_id}}">
   <view class="orderList" data-postId="{{item.order_id}}">
     <view class="order-content">
        <view class="content-time">下单时间</view></view>
        <view class="content-btm"></view></view>
     </view>
   </view>  
</block>
 <view class="bottom" wx:if="{{is_last}}">到底啦~</view>
</scroll-view>
封装数据请求

因为页面中加载初始化数据、下拉刷新、上拉触底事件都需要调用相同的接口,所以在这里重新定义一个加载数据的方法,根据传递参数的不同获取不同的数据。。

进入pages/order/list/list.js 文件,定义请求接口方法,封装请求的公共部分,传递参数 ,参考代码如下:


const fetch = require('../../../utils/fetch')
Page({
  data: {
    orderList: [], // 下拉触底时追加数据
    is_last: false  // 数据是否加载完毕
  },
  last_id: 0,   // 加载文件的标识
  // 定义请求方法,封装请求的公共部分(3个参数:数据、成功、失败)
  loadData: function(data, success, fail) {
    data.row = 10  // 每一页10条数据
    fetch('food/orderlist', data).then((res) => {})
})
初始化页面

进入pages/order/list/list.js 文件,在onShow中获取全局变量isReloadOrderList ,是否为true,为true就刷新;请求订单数据,渲染页面;单击“查看详情” 跳转到订单详情页面,根据订单号查询订单数据渲染订单详情页面,参考代码如下:

onLoad: function(options) {
    wx.showLoading({  title: '加载中...})
    // 调用loadData()方法
    this.loadData({
      last_id: 0
    }, (data) => {
     this.setData({orderList: data.list}, () => {
     wx.hideLoading() // 请求失败关闭加载框
      })
    })
  }

onShow: function() {
    var app = getApp();
    // 获取到并判断全局变量isReloadOrderList,是否为true,为true就刷新
    if (app.isReloadOrderList) {
      this.onLoad()
    // 刷新完成之后,把isReloadOrderList的值设为false
      app.isReloadOrderList = false
    }
  }

  // 跳转到订单详情页
  orderdetail: function (e) {
    // 获取订单号
    var index = e.currentTarget.dataset.postid
    wx.navigateTo({
      url: '../detail/detail?order_id=' + index
    })
  }


下拉刷新功能

进入pages/order/list/list.js 文件,编写下拉刷新onPullDownRefresh()函数,参考代码如下:

onPullDownRefresh: function() {
 wx.showNavigationBarLoading(); // 显示顶部刷新图标
  this.loadData({
    last_id: 0
  }, data => {
    this.setData({
      orderList: data.list
    }, () => {
   wx.hideNavigationBarLoading(); // 隐藏导航条栏加载框
    })
  })
}

上拉触底功能

进入pages/order/list/list.js 文件,编写下拉刷新onReachBottom()函数,参考代码如下:

onReachBottom: function() {
  // 判断数据是否到底,如果is_last为true到底了,则不执行请求
  if (this.data.is_last) {return}
 wx.showLoading({ title: '玩命加载中' })
  this.loadData({last_id: this .last_id}, (data) => {
    var orderList = this .data.orderList
    for (var i = 0; i < data.list.length; i++) {orderList.push(data.list[i])}
   this.setData({ orderList: orderList }, () => { 
      wx.hideLoading() // 隐藏加载框 
    })
  })
}
任务7 消费记录
任务分析

消费记录页面任务分析:

  • pages/record/record.wxml文件为tabBar页面
  • 发起网络情求,获取消费记录信息。
  • 展示用户的个人历史订单信息。
  • 包括用户的下单时间、商品总价钱。
设计消费记录列表

消费记录页面展示用户的个人历史订单信息,包括用户的下单时间、商品总价钱。消费记录页面效果如下:
desc进入pages/record/record/record.wxss文件,设计消费记录页面样式,具体代码:略

进入pages/record/record/record.wxml文件,设计消费记录页面布局,具体代码如下:

<view class="avatar"><image></image></view>
<view class="content">消费记录</view>
<view class="record-content">
  <view class="content-infoL">{{items.date}} {{items.time}}</view>
  <view class="content-infoR">
    <text>{{items.summoney}}</text>
  </view>
</view>

进入pages/record/record/record.js文件,请求数据渲染页面,具体代码如下:


const fetch=require('../../utils/fetch.js')
Page({
  onLoad: function (options) {
    wx.showLoading({ title: '努力加载中' })
   wx.setNavigationBarTitle({ title: '消费记录' }) // 设置小程序导航栏标题文字内容
    // 请求消费记录接口 
    fetch('food/record').then(res=>{
    wx.hideLoading() // 关闭加载信息
      this.setData({ listData:res.data })
  }) 
}
})

成果展示


该文章转自@Naiva链接

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

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

相关文章

内网不出网上线cs

一:本地正向代理目标 如下&#xff0c;本地(10.211.55.2)挂好了基于 reGeorg 的 http 正向代理。代理为: Socks5 10.211.55.2 1080python2 reGeorgSocksProxy.py -l 0.0.0.0 -p 1080 -u http://10.211.55.3:8080/shiro/tunnel.jsp 二&#xff1a;虚拟机配置proxifer 我们是…

ThinkPHP Nginx 重写配置

目录 NGINX 重写 Admin项目隐藏入口文件&#xff0c;且禁用Admin模块&Admin.php 1️⃣配置仅用模块 2️⃣新增admin_xyz.php文件&#xff08;自定义入口文件名&#xff09;&#xff0c;并绑定admin模块 3️⃣配置nginx 重写规则 NGINX 重写 在Nginx低版本中&#xff0…

宠物电商对接美团闪购:实现快速配送与用户增值

随着宠物行业的快速发展&#xff0c;宠物电商市场也在不断扩张。消费者的需求不再局限于传统的线上购物模式&#xff0c;越来越多的人开始追求更快捷的配送服务和更优质的购物体验。为了适应这一趋势&#xff0c;许多宠物电商平台开始寻求与本地配送平台合作&#xff0c;以提供…

Flink高可用配置(HA)

从Flink架构中我们可以看到,JobManager这个组件非常重要,是中心协调器,负责任务调度和资源管理。默认情况下,每个Flink集群只有一个JobManager实例。这会产生单点故障(SPOF):如果JobManager崩溃,则无法提交新程序,正在运行的程序也会失败。通过JobManager的高可用性,…

Vue使用Mockjs插件实现模拟数据

官方文档&#xff1a;Mock.js 一.引言 在前端开发过程中&#xff0c;我们经常会遇到后端接口尚未完成&#xff0c;但前端需要进行页面构建和功能测试的情况。这时候&#xff0c;Mockjs就如同救星一般出现了。Mockjs 是一款能够模拟生成随机数据&#xff0c;拦截 Ajax 请求并返…

Liinux——进程间通信之共享内存与信号量

进程间通信之共享内存与信号量 System V进程间通信 system V 进程通信是一组在 Unix 和类 Unix 系统中用于进程间通信的机制&#xff0c;主要三种方式&#xff1a;共享内存、消息队列与信号量 今天我们一起来对共享内存进行详细的学习&#xff0c;并了解信号量的基本概念 1.…

阿里发布 EchoMimicV2 :从数字脸扩展到数字人 可以通过图片+音频生成半身动画视频

EchoMimicV2 是由阿里蚂蚁集团推出的开源数字人项目&#xff0c;旨在生成高质量的数字人半身动画视频。以下是该项目的简介&#xff1a; 主要功能&#xff1a; 音频驱动的动画生成&#xff1a;EchoMimicV2 能够使用音频剪辑驱动人物的面部表情和身体动作&#xff0c;实现音频与…

node.js nvm 安装和使用

个人笔记记录。 参考文档&#xff1a;https://blog.csdn.net/weixin_45811256/article/details/130860444 1、下载nvm-setup.exe 安装程序 2、将本地的node卸载&#xff0c;然后点击进行安装。 3、安装 node.js 方法一&#xff1a; 去nodejs官网搜索历史版本&#xff0c;找…

js:函数

函数 函数&#xff1a;实现抽取封装&#xff0c;执行特定任务的代码块&#xff0c;方便复用 声明 函数命名规范 尽量小驼峰 前缀应该为动词&#xff0c;如getName、hasName 函数的调用 函数体是函数的构成部分 函数传参 参数列表里的参数叫形参&#xff0c;实际上写的数据叫实…

【大模型】基于LLaMA-Factory的模型高效微调

LLaMA-Factory项目介绍 LLaMA Factory 是一个简单易用且高效的大型语言模型&#xff08;Large Language Model&#xff09;训练与微调平台。通过 LLaMA Factory&#xff0c;可以在无需编写任何代码的前提下&#xff0c;在本地完成上百种预训练模型的微调&#xff0c;框架特性包…

论文笔记 SliceGPT: Compress Large Language Models By Deleting Rows And Columns

欲买桂花同载酒&#xff0c;终不似&#xff0c;少年游。 数学知识 秩&#xff1a; 矩阵中最大线性无关的行/列向量数。行秩与列秩相等。 线性无关&#xff1a;对于N个向量而言&#xff0c;如果任取一个向量 v \textbf{v} v&#xff0c;不能被剩下的N-1个向量通过线性组合的方式…

hadoop_zookeeper详解

Zookeeper秒懂 工作机制特点数据结构应用场景安装选举机制初始化启动无法和Leader保持连接 节点类型监听器原理写数据流程Paxos算法算法流程 客户端命令 Zookeeper 是一个开源的分布式的&#xff0c;为分布式框架提供协调服务的 Apache 项目。 工作机制 Zookeeper是一个基于观察…

MD5算法加密笔记

MD5是常见的摘要算法。 摘要算法&#xff1a; 是指把任意⻓度的输⼊消息数据转化为固定⻓度的输出数据的⼀种密码算法. 摘要算法是 不可逆的, 也就是⽆法解密. 通常⽤来检验数据的完整性的重要技术, 即对数据进⾏哈希计算然后⽐ 较摘要值, 判断是否⼀致. 常⻅的摘要算法有: MD5…

【LeetCode每日一题】——717.1比特与2比特字符

文章目录 一【题目类别】二【题目难度】三【题目编号】四【题目描述】五【题目示例】六【题目提示】七【解题思路】八【时空频度】九【代码实现】十【提交结果】 一【题目类别】 数组 二【题目难度】 简单 三【题目编号】 717.1比特与2比特字符 四【题目描述】 有两种特…

ATTCK红队评估实战靶场(二)

http://vulnstack.qiyuanxuetang.net/vuln/?page2 描述&#xff1a;红队实战系列&#xff0c;主要以真实企业环境为实例搭建一系列靶场&#xff0c;通过练习、视频教程、博客三位一体学习。本次红队环境主要Access Token利用、WMI利用、域漏洞利用SMB relay&#xff0c;EWS re…

SpringMVC |(一)SpringMVC概述

文章目录 &#x1f4da;SpringMVC概述&#x1f407;三层架构&#x1f407;异步调用 &#x1f4da;SpringMVC入门案例&#x1f407;入门案例&#x1f407;注意事项 &#x1f4da;小结 学习来源&#xff1a;黑马程序员SSM框架教程_SpringSpringMVCMaven高级SpringBootMyBatisPlus…

uniapp实现APP版本升级

App.vue 直接上代码 <script>export default {methods: {//APP 版本升级Urlupload() {// #ifdef APP-PLUSplus.runtime.getProperty(plus.runtime.appid, (info) > {// 版本号变量持久化存储getApp().globalData.version info.version;this.ToLoadUpdate(info.versi…

visionpro官方示例分析(一) 模板匹配工具 缺陷检测工具

1.需求&#xff1a;找出图像中的这个图形。 2.步骤 使用CogPMAlignTool工具&#xff0c;该工具是模板匹配工具&#xff0c;见名知意&#xff0c;所谓模板匹配工具就是说先使用该工具对一张图像建立模板&#xff0c;然后用这个模板在其他图像上进行匹配&#xff0c;匹配上了就说…

QT:多ui界面显示

文章目录 1.多ui界面添加2.跳转函数3.返回函数4.Qt5源码工程5.模态显示 1.多ui界面添加 最终生成这个目录 2.跳转函数 void MainWindow::on_pushButton_clicked() {//this->setWindowModality(Qt::WindowModal);test1 *t1 new test1();t1->setParentData(this);this-…

python代码示例(读取excel文件,自动播放音频)

目录 python 操作excel 表结构 安装第三方库 代码 自动播放音频 介绍 安装第三方库 代码 python 操作excel 表结构 求出100班同学的平均分 安装第三方库 因为这里的表结构是.xlsx文件,需要使用openpyxl库 如果是.xls格式文件,需要使用xlrd库 pip install openpyxl /…