微信小程序登录按钮遮罩浮层效果的实现方法


Posted in Javascript onDecember 16, 2018

前言

近期在写一点小东西,碰到遮罩...所以将实现的过程分享出来,供大家参考学习,下面话不多说了,来一起看看详细的介绍吧

逻辑如下:

1:第一次登陆的时候会有一个登录按钮遮罩浮层提示去授权登录

2:在弹出的授权框里,拒绝授权按钮的时候,界面的数据没有办法加载出来,允许授权的时候,界面就能渲染从后端拿过来的数据

3:判断是否授过权(判断是第一次登录还是第n次),如果用户第一次已经登录授权,后面继续登录的时候悬浮框就不会再出现

效果如下:

微信小程序登录按钮遮罩浮层效果的实现方法

代码如下:

index.html

<!-- 授权弹框提示 -->
 <view class="container">
 <view class="float" hidden='{{viewShowed}}'>
 <view class='floatContent'>
  <view class='floatText'>
  <text>获取微信授权信息</text>
  <button open-type="getUserInfo" bindgetuserinfo="getUserInfo">去设置</button>
  </view>
 </view>
 </view>
</view>

index.wxss

.float {
 height: 100%;
 width: 100%;
 position: fixed;
 background-color: rgba(0, 0, 0, 0.5);
 z-index: 2;
 top: 0;
 left: 0;
}

.floatContent {
 padding: 20rpx 0;
 width: 80%;
 background: #fff;
 margin: 40% auto;
 border-radius: 20rpx;
 display: flex;
 flex-direction: column;
 justify-content: space-around;
 align-items: center;
 position: relative;
 height: 332rpx;
}

.floatText text {
 color: #000;
 font-size: 40rpx;
 display: block;
 text-align: center;
 line-height: 90rpx;
 border-radius: 30rpx;
 margin-right: 10rpx;
}

index.js

js代码,与后台数据库交互,授权的信息存入了数据库,可根据自己的需要做出相应的修改。

//index.js
//获取应用实例

var app = getApp()

Page({
 data: {
 carList: [], //车辆数据集合
 viewShowed: true, //控制授权是否显示

 },

 onLoad: function () {
 var that = this;
 

 app.getOpenid().then(function (res) {
  if (res.status == 200) {
  //判断是否授权
  wx.getSetting({
   success(e) {
   if (e.authSetting['scope.userInfo']) { //已经授权
    that.getCars(res.data);
   } else { //没有授权,显示授权框
    that.setData({
    viewShowed: false,
    })
   }
   }
  })
  }
 })
 },

 getUserInfo: function (e) {
 var that = this;
 that.setData({
  viewShowed: true,
 });
 var userinfo = e.detail.userInfo;
 wx.request({
  url: "http://localhost:8081/wpDeboServer/wx.do",
  data: {
  "openid": app.globalData.openid,
  "nickname": userinfo.nickName
  },
  method: 'PUT',
  header: {
  'Content-type': 'application/json'
  },
  success: function (res) {
  //查询绑定车辆
  that.getCars(app.globalData.openid);
  }
 });
 },
})

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
基于JQuery的密码强度验证代码
Mar 01 Javascript
基于jQuery制作迷你背词汇工具
Jul 27 Javascript
使用CSS样式position:fixed水平滚动的方法
Feb 19 Javascript
JavaScript访问CSS属性的几种方式介绍
Jul 21 Javascript
Js实现自定义右键行为
Mar 26 Javascript
纯JavaScript实现的兼容各浏览器的添加和移除事件封装
Mar 28 Javascript
利用require.js与angular搭建spa应用的方法实例
Jul 19 Javascript
通俗解释JavaScript正则表达式快速记忆
Aug 23 Javascript
jquery ajax异步提交表单数据的方法
Oct 27 jQuery
vue-cli axios请求方式及跨域处理问题
Mar 28 Javascript
js+html实现点名系统功能
Nov 05 Javascript
js 闭包深入理解与实例分析
Mar 19 Javascript
微信小程序 JS动态修改样式的实现方法
Dec 16 #Javascript
Echart折线图手柄触发事件示例详解
Dec 16 #Javascript
vue使用pdfjs显示PDF可复制的实现方法
Dec 14 #Javascript
antd Upload 文件上传的示例代码
Dec 14 #Javascript
Vue源码解析之Template转化为AST的实现方法
Dec 14 #Javascript
JavaScript模板引擎实现原理实例详解
Dec 14 #Javascript
Angular2 自定义表单验证器的实现方法
Dec 14 #Javascript
You might like
php 删除无限级目录与文件代码共享
2008/11/22 PHP
ThinkPHP采用原生query实现关联查询left join实例
2014/12/02 PHP
PHP MSSQL 分页实例
2016/04/13 PHP
php实现的http请求封装示例
2016/11/08 PHP
JQuery扩展插件Validate—4设置错误提示的样式
2011/09/05 Javascript
Javacript实现颜色梯度变化和渐变的效果代码
2013/05/31 Javascript
freemarker判断对象是否为空的方法
2015/08/13 Javascript
Bootstrap布局之栅格系统详解
2016/06/13 Javascript
JS工作中的小贴士之”闭包“与事件委托的”阻止冒泡“
2016/06/16 Javascript
JS+HTML+CSS实现轮播效果
2017/11/28 Javascript
Vue 项目部署到服务器的问题解决方法
2017/12/05 Javascript
vue 使某个组件不被 keep-alive 缓存的方法
2018/09/21 Javascript
利用Webpack实现小程序多项目管理的方法
2019/02/25 Javascript
ES6入门教程之Array.from()方法
2019/03/23 Javascript
js+html5 canvas实现ps钢笔抠图
2019/04/28 Javascript
ES6 Set结构的应用实例分析
2019/06/26 Javascript
[46:42]DOTA2-DPC中国联赛正赛 Aster vs Magma BO3 第二场 3月5日
2021/03/11 DOTA
python将MongoDB里的ObjectId转换为时间戳的方法
2015/03/13 Python
详解Python的Django框架中的通用视图
2015/05/04 Python
Python 40行代码实现人脸识别功能
2017/04/02 Python
Python cookbook(数据结构与算法)通过公共键对字典列表排序算法示例
2018/03/15 Python
执行Django数据迁移时报 1091错误及解决方法
2019/10/14 Python
Pycharm小白级简单使用教程
2020/01/08 Python
打包PyQt5应用时的注意事项
2020/02/14 Python
如何用python处理excel表格
2020/06/09 Python
python 逆向爬虫正确调用 JAR 加密逻辑
2021/01/12 Python
使用python实现学生信息管理系统
2021/02/25 Python
好莱坞百老汇御用王牌美妆:Koh Gen Do 江原道
2018/04/03 全球购物
求职信模板怎么做
2014/01/26 职场文书
初三开学计划书
2014/04/27 职场文书
幼儿园母亲节活动总结
2015/02/10 职场文书
学生党支部工作总结2015
2015/05/26 职场文书
Nginx反向代理及负载均衡如何实现(基于linux)
2021/03/31 Servers
springBoot基于webSocket实现扫码登录
2021/06/22 Java/Android
Elasticsearch 数据类型及管理
2022/04/19 Python
Mysql表数据比较大情况下修改添加字段的方法实例
2022/06/28 MySQL