ホームページ > ウェブフロントエンド > uni-app > uni-appをベースにした画像アップロードJSプラグインを実装する

uni-appをベースにした画像アップロードJSプラグインを実装する

coldplay.xixi
リリース: 2020-09-28 16:05:20
転載
3482 人が閲覧しました
uni-appをベースにした画像アップロードJSプラグインを実装する

#関連する学習に関する推奨事項: javascript(ビデオ)

# 作成new before use
すべてのメソッドは Promise オブジェクトを返します。then() を使用して後続のビジネスを記述するか、async await
Preview

uni-appをベースにした画像アップロードJSプラグインを実装する# を使用できます。 #体験してみよう

H5 アドレス http://uni_upload.gek6.com/uploader/#/

サーバー リターンの例
{	"code":0,	"msg":"上传成功",	"data":"http://www.test.com/uploads/20190227/f2824d2d4dc38f30699f816226b4a578.jpg"}复制代码
ログイン後にコピー
直接アップロードソースコード
/*
	2019-02-27
	lane
	封装 uni-app 图片上传功能
	
	使用前先new 一下
	
	所有方法均返回 promise 对象 可使用then() 写后续业务 或 使用 async await
	
	服务端返回示例
	{		"code":0,		"msg":"上传成功",		"data":"http://www.test.com/uploads/20190227/f2824d2d4dc38f30699f816226b4a578.jpg"
	}
	choose	选择图片
		参数 num 为要选择的图片数量
	upload_one 上传一张图片
		参数 path  选择成功后返回的 缓存文件图片路径
	upload  上传多张图片
		参数 path_arr 选择图片成功后 返回的图片路径数组
	choose_and_upload  选择图片并上传
		参数 num 为要选择的图片数量
		
*/

// 引入配置信息或者自己创建个 config 对象
// import config from "../config.js";let config = {
	// 上传图片的API
	upload_img_url:'http://uni_upload.gek6.com/index.php/index/upload'}
class Uploader {	constructor() {
		
	}
	choose(num) {		return new Promise((resolve, reject) => {
			uni.chooseImage({
				count: num,
				success(res) {
					// console.log(res);
					// 缓存文件路径
					resolve(res.tempFilePaths)
				},
				fail(err) {
					console.log(err)
					reject(err)
				}
			})
		})

	}
	upload_one(path) {		return new Promise((resolve, reject) => {
			uni.showLoading({
				title:'上传中'
			})
			uni.uploadFile({
				url: config.upload_img_url, //仅为示例,非真实的接口地址
				filePath: path,
				name: 'file',
				success: (uploadFileRes) => {					if("string"===typeof uploadFileRes.data){
						resolve(JSON.parse(uploadFileRes.data).data)
					}else{
						resolve( uploadFileRes.data.data )
					}
					
				},				complete() {
					uni.hideLoading()
				}
			});
		})
	}
	upload(path_arr) {		let num = path_arr.length;		return new Promise(async (resolve, reject) => {			let img_urls = []			for (let i = 0; i < num; i++) {				let img_url = await this.upload_one(path_arr[i]);
				console.log(img_url)
				img_urls.push(img_url)
			};
			console.log("全部上传成功")
			resolve(img_urls)
		})


	}
	choose_and_upload(num) {		return new Promise(async (resolve, reject) => {			let path_arr = await this.choose(num);			let img_urls = await this.upload(path_arr);
			resolve(img_urls);
		})

	}
}export default Uploader;复制代码
ログイン後にコピー

choose 画像を選択してください

参数 num 为要选择的图片数量
返回 图片缓存路径 数组复制代码
ログイン後にコピー
upload_one 画像をアップロードしてください
参数 path  选择成功后返回 远程图片路径复制代码
ログイン後にコピー
upload 複数の画像をアップロードしてください
参数 path_arr 选择图片成功后 返回远程图片路径数组复制代码
ログイン後にコピー
choose_and_upload 画像を選択してアップロード
参数 num 为要选择的图片数量 返回 图片缓存路径 数组复制代码
ログイン後にコピー
その他の優れた記事については、
uni-app

列にご注目ください~

以上がuni-appをベースにした画像アップロードJSプラグインを実装するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:juejin.im
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート