基于微信小程序云开发(统计学生信息并导出excel)4.0版(稳定版)

简介: 基于微信小程序云开发(统计学生信息并导出excel)4.0版(稳定版)

前言

随着移动端的不断发展,人们大部分的办公及生活应用都开始趋向于移动端。然而在2017年“微信之父”张小龙带领团队,开发了一款叫做微信小程序的东西,它的出现打破了人们认识移动端的隔膜,由以前的需要先下载app然后在开始工作的老式模式,逐渐的趋向于小程序app(无需下载)的形式。

一、微信小程序是什么?

微信小程序是一种不需要下载安装即可使用的应用,它实现了应用的随开随用,用户只需要用微信扫一扫或者通过微信搜一下即可打开应用,使用完即可关闭,还可以把小程序添加到桌面,真正的做到了便捷方便,用完就走。

二、什么是微信小程序的云开发?

云开发为开发者提供完整的云端支持,弱化了后端和运维概念,无需搭建服务器,使用平台提供的 API 进行核心业务开发,即可实现快速上线和迭代,同时这一能力,同开发者已经使用的云服务相互兼容,并不互斥。

从开发流程来看,以往开发一个微信小程序需要经过产品功能构思、模块划分、原型设计、UI 设计、前端开发、后端开发、接口联调、测试上线等开发阶段。有了「小程序·云开发」后,前端工程师将可以独立实现前端开发、后端开发、接口联调工作,且无需太多后端知识。


三、首先我想说的是4.0版本比起3.0版本的优势:

一、登录界面由以前3.0的直接从首页开始,到现在4.0的先弹出一个简约的产品介绍,点击授权登录后,后出现立即进入的button按钮!(我觉得这是4.0版本在登录的UI设计方面最大的提升)

如图:

image.png

image.png

二、共有两点优化

1.当我们点击立即进入时,系统会跳转到首页但是会发现以前的授权登录不见了,而是在一、中的首次打开中!

2.很清楚的发现首页的最上方不是显示用户信息了,而是我做了一个跳转,它可以跳转到微信小程序以外的页面注意:要想微信小程序跳转到外部网页,就必须在微信公众平台配置域名服务!!!配置域名的官方文档,供参考!!!


image.png

三、我认为这是4.0版本的点睛之笔,因为我在今天测试3.0版本的时候发现当我点击,当我点击刷新填表记录时,有一个bug,就是不管你填不填,只要你登陆了,点击刷新填表记录时就会显示xxx用户已填写的记录!我后来才发现,我直接在事件中读取的是openid这个数据库(填写用户信息的数据库)所以当用户每一次点击授权登录时,都会自动添加一遍数据,所以导致不管填不填表,只要刷新就会由用户显示的bug!!!


而今天的4.0版本,在修复了此bug的同时,又将其升级(如下图)

image.png

知识点的讲解:

一、这里设计到了一个知识点,也是我们前端学者们的一个基础但是容易忘掉的地方,就是关于css(wxss)中的z-index的使用,在使用他之前我们必须要在使用的这个类的前面写:position:absolute;绝对定位,要不然z-index是不起效果的!!!(谨记)


关于这个button重叠,且当用户点击授权登录时变成立即进入的效果,这里我开始做的时候,想了两种办法

一种:是当用户点击授权登录时,我们可以写一个判断语句将授权登录button按钮组件禁用(但是当我测试的时候我发现,行不通)

另一种:是利用wxss在页面的后台传参的效果:(这也是我用的此方法)


wxml:

<buttonclass="button"bindtap="denglu"style="position:absolute;left: 30%;z-index:{{LJJR}};">授权登录</button>

1.我们先不把z-index这个属性写死,我们给他动态的绑定一个数据!如上代码!:

<buttonbindtap="tiaozhuan"class="button1">立即进入</button><buttonclass="button"bindtap="denglu"style="position:absolute;left: 30%;z-index:{{LJJR}};">授权登录</button>

2.这里我们“立即进入”的样式写在button1当中,样式代码如下:

.button1{
position:absolute;
left: 30%;
color: blanchedalmond;
width: 300rpx;
margin-top:650rpx;
border-radius: 30rpx;
background: -webkit-linear-gradient(topleft,rgb(4, 244, 144),rgb(237, 15, 245));
}

3.我们把”授权登录“的一部分样式写在button当中,样式代码如下:

.button{
width: 300rpx;
margin-top: 650rpx;
border-radius: 30rpx;
background: -webkit-linear-gradient(topleft,rgb(4, 244, 144),rgb(237, 15, 245));
}

4.”授权登录“的另一部分样式我们直接写在wxml中,通过style的方式:

<buttonclass="button"bindtap="denglu"style="position:absolute;left: 30%;z-index:{{LJJR}};">授权登录</button>

5.我们先不把z-index这个属性写死,我们给他动态的绑定一个数据,绑定数据如下:

js:注意LJJR这个变量名!!我们先将他的默认值为0;先让授权登录的按钮显示在立即进入按钮的上面!!!

Page({
data: {
LJJR:0,
name:"信息填写系统",
path:"https://wx.qlogo.cn/mmhead                                 /Q3auHgzwzM5xGneETMfziaJ0dVKk8j5VrqibtE0NOmXIcoJsdIV0Rzmg/0",
isshow:true,
show:true,
    },
})

6. 我们在通过授权登录按钮绑定的denglu事件函数中来根据页面中的:(如下所示)

image.png

这两个系统名称以及系统图标 是否用户点击了授权登录,如果点击了授权登录(已登录的状态),我们的系统的名称和图标就会变成用户的微信头像和微信昵称:(如下所示)

image.png

所以我们就可以根据以上的说明,来根据当name和path着两个变量名改变的时候LJJR 这个变量也会跟着前面的两个变量进入data:{}当中,这是我们提前在wxml中写好的z-index:{LJJR}就起作用了!

denglu(){
letthat=thiswx.getUserProfile({
desc: '正在获取',
success:function(res){
console.log('获取成功: ',res)
//添加用户信息到openid数据库wx.cloud.database().collection('openid').add({
data:{
name:res.userInfo.nickName,
path:res.userInfo.avatarUrl                    }
                })
//显示用户信息到首页that.setData({
name:res.userInfo.nickName,
path:res.userInfo.avatarUrl,
show:false,
LJJR:-999,
              })
console.log(res)
//             },
fail:function(err){
console.log("获取失败:",err)
          },
        })
// return that.setData    },

二、我们需要先写一个js里面的跳转,跳转到一个空页面但是里面必须要有你要跳转且已经在微信公众平台中配置好的域名!!!

shouye.wxml:

<viewclass="denglu"><viewclass="denglu1"bindtap="wangye"><viewstyle="padding-top:35rpx;">每周校园新闻</view></view></view>

shouye.js:

wangye(){
wx.navigateTo({
url: '../waibu_yemian/waibu_yemian',
        })
    },

waibu_yemian.wxml:

<web-viewsrc="https://www.toutiao.com/"></web-view>

三、我们需要将以前写的liulan.js中的事件重新调整一下:

1.我们需要现在data创建两个集合,来用作我们循环渲染的集合对象:

data: {
users:[],
openid:[]
  },

2.然后我们需要在wxml中写入一个刷新填表记录的button绑定事件按钮,绑定事件为:shuaxin:

<buttonbindtap="shuaxin"type="primary">刷新填表记录</button>

3.然后我们在js中写入:

这里我们要分别读取两个云数据库,因为我们创建的存储用户数据信息在openid中,而用户的填表信息则在users中:

image.png

image.png

4.所以我们要在shuaxin这个点击事件中写入两个读取云数据库的代码(如下):

shuaxin(){
letthat=thisdb.collection('openid').get({
success:function(res){
console.log('用户信息获取成功',res.data)
that.setData({
openid:res.data            })
        },
fail:function(res){
console.log('用户信息获取失败',res)
        }
    })
db.collection('users').get({
success:function(res){
console.log('用户信息获取成功',res.data)
that.setData({
users:res.data            })
        },
fail:function(res){
console.log('用户信息获取失败',res)
        }
    })
  },

5.js中的逻辑事件完成之后,我们开始写wxml中的显示渲染事件了!!

6.我们要将在js中的data:{}中的两个被shuaxin事件所支承而变化的两个数组遍历出来(如下):

<viewstyle="font-size: 35rpx;color:blue;">登录显示(可上下滑动):</view><viewclass="xianshi_tianbiao"><viewclass="xianshi_tianbiao1"><!-- 显示用户头像及昵称 --><viewclass="paihao2"><scroll-viewscroll-y="true"class="yonghuxinxi"><viewclass="boxR"wx:for="{{openid}}"wx:key="index"><viewclass="item-y"style="font-size: 25rpx;margin-top:5rpx;"><imagestyle="width: 40rpx;height: 40rpx;"src="{{item.path}}"></image>                {{item.name}}</view></view></scroll-view></view></view></view><viewstyle="font-size: 35rpx;color:blue;">填表人名显示:</view><viewclass="xianshi_tianbiao"><viewclass="xianshi_tianbiao1"><!-- 显示用户头像及昵称 --><viewclass="paihao2"><scroll-viewscroll-y="true"class="yonghuxinxi"><viewclass="boxR"wx:for="{{users}}"wx:key="index"><viewclass="item-y"style="font-size: 25rpx;margin-top:5rpx;">{{item.xingming}}</view></view></scroll-view></view></view></view>

7.这里用csroll-view的方法可以让页面不随着要显示用户数据的增多而高度随着变化,也是一种美观的表现!!!

目录
相关文章
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
2803 7
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
2387 1
|
8月前
|
人工智能 自然语言处理 小程序
技术小白如何利用DeepSeek半小时开发微信小程序?
通过通义灵码的“AI程序员”功能,即使没有编程基础也能轻松创建小程序或网页。借助DeepSeek V3和R1满血版模型,用户只需用自然语言描述需求,就能自动生成代码并优化程序。例如,一个文科生仅通过描述需求就成功开发了一款记录日常活动的微信小程序。此外,通义灵码还提供智能问答模式,帮助用户解决开发中的各种问题,极大简化了开发流程,让普通人的开发体验更加顺畅。
2227 11
技术小白如何利用DeepSeek半小时开发微信小程序?
|
7月前
|
小程序 Java 关系型数据库
weixin163基于微信小程序的校园二手交易平台系统设计与开发ssm(文档+源码)_kaic
本文介绍了一款基于微信小程序的校园二手物品交易平台的开发与实现。该平台采用Java语言开发服务端,使用MySQL数据库进行数据存储,前端以微信小程序为载体,支持管理员和学生两种角色操作。管理员可管理用户、商品分类及信息、交易记录等,而学生则能注册登录、发布购买商品、参与交流论坛等。系统设计注重交互性和安全性,通过SSM框架优化开发流程,确保高效稳定运行,满足用户便捷交易的需求,推动校园资源共享与循环利用。
|
7月前
|
小程序 关系型数据库 Java
weixin168“返家乡”高校暑期社会实践微信小程序设计与开发ssm(文档+源码)_kaic
本文探讨高校暑期社会实践微信小程序的开发与应用,旨在通过信息化手段提升活动管理效率。借助微信小程序技术、SSM框架及MySQL数据库,实现信息共享、流程规范和操作便捷。系统涵盖需求分析、可行性研究、设计实现等环节,确保技术可行、操作简便且经济合理。最终,该小程序可优化活动发布、学生信息管理和心得交流等功能,降低管理成本并提高工作效率。
|
8月前
|
小程序 JavaScript 前端开发
微信小程序开发全流程:从注册到上线的完整指南
这篇文章详细记录了微信小程序的完整开发到最终上线的每一个步骤。适合对小程序开发感兴趣的个人开发者或希望了解完整流程的学习者,涵盖了云开发、事件绑定、生命周期管理、组件使用等关键内容。
2823 11
|
9月前
|
JSON 缓存 小程序
微信小程序组件封装与复用:提升开发效率
本文深入探讨了微信小程序的组件封装与复用,涵盖组件的意义、创建步骤、属性与事件处理,并通过自定义弹窗组件的案例详细说明。组件封装能提高代码复用性、开发效率和可维护性,确保UI一致性。掌握这些技能有助于构建更高质量的小程序。
|
缓存 小程序 索引
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
846 1
|
JavaScript 小程序 开发者
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
uni-app开发实战:利用Vue混入(mixin)实现微信小程序全局分享功能,一键发送给朋友、分享到朋友圈、复制链接
1924 0
|
小程序
uni-app开发微信小程序使用onPullDownRefresh(下拉刷新)总结
uni-app开发微信小程序使用onPullDownRefresh(下拉刷新)总结
1837 0