-
在小程序开发中,我们都知道小程序是没有cookie的,那么用户身份是如何确定的,后段颁发token,前端每次请求头部附带token。既然是token,那么肯定有它的过期时间,没有一个token是永久的,永久的token就相当于一串永久的密码,是不安全的,那么既然有刷新时间,问题就来了前后端交互的过程中token如何存储?
token过期时,前端该怎么处理?
当用户正在操作时,遇到token过期该怎么办?直接跳回登陆页面?
-
在小程序下开发中,我们有一个需求是支持用户导出excel文件,后端是通过接口返回文件流给到前端,小程序需要保存文件到用户端。
目前小程序提供的接口有以下几个接口downloadFile、copyFileSync、openDocument、saveFileToDisk
在手机端excel文件是无法直接保存到本地的,但是微信提供了openDocument这个API,此接口支持预览excel文件,预览界面有操作按钮,可选择转发给好友,或者使用第三方App打开(如WPS),注意showMenu的默认值是fasle
-
报错errMsg: "XXXX:fail privacy permission is not authorized"
errno: 104,uniapp开发小程序,接入隐私协议弹窗,主动显示弹窗,被动显示弹窗,完美显示/关闭,另附bus全局工具类,隐私协议弹窗组件源码奉上。
-
琴房易约上线啦!!!琴房易约,让预约琴房简易便捷不再难!经过一段时间的研发,给予母校的第二款产品终于上线啦,第一款是在校期间研发的商图助理,这款产品在需求产出、原型设计、界面开发、数据库设计、API接口开发等,一个人耗费了大概2年时间(2017/11/24~2019/09/03),4次大版本迭代,数不尽的小版本最终上线(目前线上版本后端已托朋友重构,毕竟自己不是专业后端童鞋)。琴房易约 是我正式工作四年后开发的产品,因为有了积累的研发经验,这款产品研发周期并不算长,大概1月时间左右。
-
uniCloud云存储文件批量删除
-
<view class="page"><scroll-view:upper-threshold="0":scroll-y="true"class="message-main"@scroll="scroll":scroll-top="lastMessagePosition"><view class="message-content" id="messageContent"><viewclass="message-conten
-
拼多多小程序优惠券路径,京东小程序优惠券路径
-
目前微信小店开放组件已经申请成功,且第一时间去体验了一把。
想介入 微信小店开放组件的开发者可以点击下方链接提交申请
https://developers.weixin.qq.com/doc/ministore/minishopopencomponent/Introduction.html
官方在审核完成后会推送申请成功的模板消息,且拉入官方组件问题反馈群
你的微信小程序后台也会增加小商店店开放组件
-
default.getters is not a function,getters在别得地方调用不需要括号也就是vuex将getters里面的函数对外暴露为一个属性,而不是一个方法
-
在小程序内想实现长按识别二维码 加群?加好友?关注公众号?很高兴告诉你可以实现在微信版本高于7.0.11支持微信跳转webview且支持长按识别!决绝方案/**
* 比较版本号大小
* @Author: wkiwi
* @param {String|Number} 版本号
* @return {Number}
*/
function compareVersion(v1, v2) {//com
-
requestSubscribeMessage,在低版本无法调用订阅消息,报错提示requestSubscribeMessage:fail can only be invoked by user TAP gesture
-
在小程序【打卡圈】的开发过程中,需要实现作业批改的需求,这就需要实现图片的编辑涂鸦添加对号叉号等贴纸,在其中有一个需求那就是涂鸦的撤回,在canvas中绘制的了很多步,点击撤回总能回退到上一步操作,当时在想这个需求该如何去实现,每一步绘制结束去 生成一张图片?回退显示之前的图片吗,这样处理生成图片太频繁,再有就是调用canvas本来属性就不稳定,还去频繁的生成图片,这不更容易翻车吗,继续查看文档,发现了两个属性canvasPutImageData,canvasGetImageData,这不正是我
-
1.绘制圆形头像ctx.beginPath();
ctx.arc(80, 550, 40, 0, 2 * Math.PI);
ctx.clip();
ctx.drawImage(_this.AvatarTempFilePath, 40,510, 80, 80);
ctx.restore();
ctx.save();2.文本截取不换行.../**
* 文本截取不换行...
* @param {Object} ctx
* @param {String} text
*
-
ctx.fillText() 在画布上绘制“被填充的”文本
ctx.strokeText() 在画布上绘制文本(无填充)
ctx.measureText() 返回包含指定文本宽度的对象1 ctx.font(); 设置或返回文本内容的当前字体属性
2 ctx.textAlign = 'start|end|center|left|right'textAlign 设置或返回文本内容的当前对齐方式
start : 默认。文本在指定的位置开始。
end : 文本在指定的位置结束。
center: 文本的中
-
小程序A页面传参给B页面,且参数中存在用户自定义信息,切记使用encodeURIComponent进行转译