uniapp 下载app的方法并且赋值进度条

这段代码展示了如何使用下载管理器进行文件下载,并在下载完成后进行安装。当状态为200时,文件下载成功并尝试安装;否则显示更新失败。下载过程中,代码监听并更新下载进度。
// 下载
			downloader(downloadUrl) {
				console.log(downloadUrl)
				this.isDownload = true;
				let dtask = plus.downloader.createDownload(downloadUrl, {}, (d, status) => {
					console.log(d, status)
					// 下载完成
					if (status == 200) {
						plus.runtime.install(plus.io.convertLocalFileSystemURL(d.filename), {}, {}, (error) => {
							uni.showToast({
								title: '安装失败',
								mask: false,
								duration: 1500
							});
						})
					} else {
						uni.showToast({
							title: '更新失败',
							mask: false,
							duration: 1500
						});
					}
				});
				dtask.addEventListener('statechanged', (task) => {
					if (!dtask) {
						return;
					}

					// no default

					switch (task.state) {

						case 1:

							console.log('开始下载');

							break;

						case 2:

							console.log('链接到服务器...');

							break;

						case 3:

							this.progressVal = Math.ceil(this.changeTwoDecimal_f(task.downloadedSize / task
									.totalSize) *
								100);
							console.log(this.progressVal)
							break;

						case 4:

							console.log('监听下载完成');
							break;

					}

				});
				dtask.start();
			},
			/**
			 * 例如
			 * 2         →     2.00
			 * 2.3       →     2.30
			 * 2.321   	 →     2.32
			 * 2.328     →     2.33
			 * 
			 * */
			changeTwoDecimal_f(x) {
				var f_x = parseFloat(x);
				if (isNaN(f_x)) {
					return 0;
				}
				var f_x = Math.round(x * 100) / 100;
				var s_x = f_x.toString();
				var pos_decimal = s_x.indexOf('.');
				if (pos_decimal < 0) {
					pos_decimal = s_x.length;
					s_x += '.';
				}
				while (s_x.length <= pos_decimal + 2) {
					s_x += '0';
				}
				return s_x;
			}```

### 如何在 UniApp 中加载和显示外部网页 #### 使用 `plus.runtime.openURL` 方法直接打开外部浏览器 对于希望直接通过设备默认浏览器打开链接的情况,可以使用 `plus.runtime.openURL` 函数来处理。此函数能够接收一个 URL 参数,并启动系统的默认 Web 浏览器访问该地址[^1]。 ```javascript // 打开外部链接至系统默认浏览器 function openExternalBrowser(url) { plus.runtime.openURL(url); } ``` #### 利用 `<web-view>` 组件嵌入外部网页 如果目标是在应用内部展示第三方网站,则推荐采用内置的 `<web-view>` 组件。这个组件允许开发者将任意 HTML 页面无缝集成到应用程序当中,同时支持自定义样式设置以及传递参数给子页面[^3]。 ```html <!-- 嵌入特定网址 --> <web-view src="https://example.com"></web-view> ``` 或者动态绑定数据源: ```html <template> <view> <!-- 动态加载不同网页 --> <web-view :src="dynamicUrl"></web-view> </view> </template> <script> export default { data() { return { dynamicUrl: '' }; }, onLoad(option) { // 获取传过来的url参数并赋值给data中的变量 this.dynamicUrl = option.targetUrl; } }; </script> ``` 上述方式提供了两种不同的解决方案,具体选择取决于实际需求——即是否要在 App 内部还是外部浏览所指向的内容。 #### 配置 WebView 的样式与行为 为了提升用户体验,在某些情况下可能还需要调整 WebView 加载进度条的颜色等外观属性。这可以通过配置 `webview-styles` 属性实现[^4]。 ```json { "progress": { "color": "#FF3333" } } ``` 以上就是关于如何在 UniApp 应用程序里加载并呈现来自互联网上的公开资源的方法介绍。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值