当前位置: 首页 > news >正文

网站建设立项ppt模板推广普通话海报

网站建设立项ppt模板,推广普通话海报,做推广app赚钱的项目,建设管理部门网站查询关于app更新,uni-app官方推荐的是 uni-upgrade-center,看了下比较繁琐,因此这里自己实现检查更新并下载安装的逻辑。 1.界面效果 界面中的弹框和 进度条采用了uView 提供的组件 2.检查更新并下载安装 一、版本信息配置在服务端&#xff0c…

关于app更新,uni-app官方推荐的是 uni-upgrade-center,看了下比较繁琐,因此这里自己实现检查更新并下载安装的逻辑。

1.界面效果

               

界面中的弹框和 进度条采用了uView 提供的组件

2.检查更新并下载安装

一、版本信息配置在服务端,请求服务端接口判断是否需要更新 。

二、点击下载按钮,则开始下载App安装包,并监听下载进度,实时更新下载进度条

注意:下载App如果是在浏览器测试,可能会有跨域的问题,需要后端服务允许跨域。

三、待下载完成后开始安装。

安装App采用的是 uni-installApk插件,请自行导入项目

uni-installApk - DCloud 插件市场

3.完整代码 

update.vue

<template><u-modal :show="show"   :showConfirmButton="false"><view class="box-a4"><image class="img-up" mode="widthFix" src="https://beilizhengxuan.oss-cn-hangzhou.aliyuncs.com/huayu/update.png"/><view class="box-a5"><text>发现新版本V{{version}},升级后体验更顺畅</text></view><view class="row-b0" v-if="!startDownload"><view class="btn0" @click="downLoadApp" >马上更新</view><view class="btn0 white" color=""  @click="cancel"v-if="forceUpdata=='0'">暂不更新</view></view><view v-if="startDownload" class="row-b1"><view class="te-j0">下载进度</view><u-line-progress :percentage="percent" height="24"activeColor="#3c9cff"></u-line-progress></view></view></u-modal>
</template>
<script>
import {getAppNewVersion} from '@/api/system/user'
export default{props:{},data(){return{startDownload: false, //是否开始下载show: false,version: '',forceUpdata: '',//是否需要强制更新apkDownloadUrl: '',//percent: 0,filePath: '',}},created(){this.handleToUpgrade()},computed:{showUpdate(){console.log('this.$stroe.state.user',this.$stroe.state.user)return this.$stroe.state.user.showUpdate}},methods:{async handleToUpgrade() {const sysInfo = uni.getSystemInfoSync()const appVersion = sysInfo.appVersionconsole.log('appVersion', appVersion)//请求服务端检查更新接口,判断是否需要更新const res = await getAppNewVersion()if(res.code == 200){if(res.data && res.data.newVersion){const newVersion = res.data.newVersionif(appVersion == newVersion){this.showToast('当前已是最新版本')this.cancel()} else{this.apkDownloadUrl = res.data.apkDownloadUrlthis.show = trueconsole.log('需要更新')this.version = newVersionthis.forceUpdata =  res.data.forceUpdata}}}},installApp(){uni.installApk({filePath : this.filePath,success: (res)=>{console.log('安装成功--', res);},fail : (res)=>{console.log('安装失败--', res);},complete: (res)=>{console.log('安装完成--', res);}})},downLoadApp(){this.startDownload = trueconst downloadTask = uni.downloadFile({url: this.apkDownloadUrl , //仅为示例,并非真实的资源timeout: 6000000,success: (res) => {console.log('success res', res)if (res.statusCode === 200) {this.filePath = res.tempFilePathconsole.log('下载成功');this.cancel()this.installApp()}},complete: (res)=> {console.log('complete res', res)},fail: (res)=> {console.log('fail res', res)},});downloadTask.onProgressUpdate((res) => {//console.log('下载进度' + res.progress);//console.log('已经下载的数据长度' + res.totalBytesWritten);//console.log('预期需要下载的数据总长度' + res.totalBytesExpectedToWrite);this.percent = res.progressif (res.progress >= 100) {console.log('下载进度 abort' + res.progress);//downloadTask.abort();}});},cancel(){this.$emit('cancel')this.show = false},showToast(message){uni.showToast({title: message,icon: 'none'})}}
}
</script><style>.img-up{width: 100%;}.box-a4{width: 100%;display: flex;flex-direction: column;justify-content: flex-start;}.box-a5{flex:1;text-align: center;font-size: 28rpx;color: #999;padding: 20rpx 0;}.row-b0{display:flex;flex-direction: row;justify-content: space-around;align-items: center;padding: 0 50rpx;margin-top:60rpx;margin-bottom:60rpx;}.row-b0 .btn0{width: 240rpx;height: 68rpx;border-radius: 34rpx;color: white;display: grid;place-content: center;background:#3c9cff;}.row-b0 .btn0:active{opacity: 0.7;}.row-b0 .btn0.white{background:#fff;color: #666;border:1px solid #eee;}.row-b1{margin: 60rpx 40rpx;}.te-j0{text-align: center;color:#999;font-size: 26rpx;margin-bottom:20rpx;}
</style>

 4.引入并使用

上面将检查更新的逻辑封装在了update.vue中,使用时只需引入该组件,在父页面点击检查更新按钮时,只需将 checkUpdate 属性设置为 true,则加载 update.vue组件,进入created 方法并调用检查更新的相关逻辑,有新版本则弹框,提示更新,无新版本则将 checkUpdate重置为 false

注意:当检查更新的弹框弹出时,调用页面需要禁用 android的 返回按键,在  onBackPress函数里面做相应的逻辑判断即可。

<template><view ><UpdateApp v-if="checkUpdate" @cancel="checkUpdate=false"/></view>
</template>
<script>
import UpdateApp from './update'export default {components:{UpdateApp},data() {return {checkUpdate: false,}},onBackPress(options) {console.log('onBackPress options', options)// 禁用返回if (options.from == 'backbutton') {console.log('--禁用返回')if(this.checkUpdate){return true;// 禁用返回按键}else {return false;}}},methods: {}}
</script>
<style lang="scss" scoped></style>

http://www.hkea.cn/news/512551/

相关文章:

  • 青海网站建设企业海南百度竞价推广
  • 南京做网站yuanmus电脑突然多了windows优化大师
  • 美国做deals的网站软文营销经典案例优秀软文
  • 招标网站怎么做吴江seo网站优化软件
  • 苏州建设工程协会网站seo去哪里学
  • 上海正规网站制作价格可口可乐软文营销案例
  • 番禺网站 建设信科网络站长之家ping
  • 建筑工程施工承包合同关键词优化报价推荐
  • 网站可以免费看企业网站系统
  • 中华人民共和国建设部网站seo怎么快速提高排名
  • 南宁做网站的有几家东莞网络营销网站建设
  • 苏州知名网站建设开发新区seo整站优化公司
  • 政府建设网站计划书品牌营销策略包括哪些内容
  • 深圳市做网站百度seo排名点击器app
  • 五莲网站建设维护推广网络营销推广及优化方案
  • 重庆网红整站多关键词优化
  • 动易网站cms一级消防工程师考试
  • wordpress更新报错想找搜索引擎优化
  • 提供网站建设费用资源网
  • wordpress怎么使用主题seo优化评论
  • 柳州做网站如何建网站详细步骤
  • 黄岛做网站哪家好四川seo关键词工具
  • dede门户网站模版写软文推广
  • 网站开发者排名开发一个app平台大概需要多少钱?
  • 做网站 博客百度推广助手客户端
  • 温州市手机网站制作哪家好爱站网长尾词挖掘
  • 党委网站建设要求凡科建站靠谱吗
  • wordpress 安卓客户端福建seo优化
  • 襄阳seo技术长沙seo网站优化
  • 做一的同志小说网站做seo要投入什么