この記事の例では、WeChatアプレットで写真をアップロードするための具体的なコードを参考までに共有しています。具体的な内容は次のとおりです。 レンダリング WXML <view class="img-wrap"> <view class="txt">写真をアップロード</view> <view class="imglist"> <view class="item" wx:for="{{imgs}}" wx:key="item"> <image src="{{item}}" alt=""></image> <view class='delete' bindtap='deleteImg' data-index="{{index}}"> <画像 src="../../../images/icon.png"></画像> </ビュー> </ビュー> <view class="last-item" wx:if="{{imgs.length >= 3 ? false : true}}" bindtap="bindUpload"> <text class="sign">+</text> </ビュー> </ビュー> </ビュー> JS データ: { 画像: [], カウント: 3 }, バインドアップロード: 関数 (e) { スイッチ (this.data.imgs.length) { ケース0: このデータ数 = 3 壊す ケース1: このデータ数 = 2 壊す ケース2: このデータ数 = 1 壊す } var that = これ wx.chooseImage({ count: that.data.count, // デフォルトは 3 sizeType: ["original", "compressed"], // オリジナル画像か圧縮画像かを指定できます。どちらもデフォルトで使用可能です。sourceType: ["album", "camera"], // ソースがアルバムかカメラかを指定できます。どちらもデフォルトで使用可能です。success: function (res) { // 選択した写真のローカルファイルパスのリストを返します。tempFilePath は、画像を表示するための img タグの src 属性として使用できます。var tempFilePaths = res.tempFilePaths (var i = 0; i < tempFilePaths.length; i++) { wx.uploadFile({ URL: 'https://graph.baidu.com/upload', ファイルパス: tempFilePaths[i], 名前: "ファイル", ヘッダー: { 「コンテンツタイプ」: 「マルチパート/フォームデータ」 }, 成功: 関数 (res) { (res.statusCode == 200)の場合{ wx.showToast({ タイトル: 「アップロードに成功しました」 アイコン: "なし", 所要時間: 1500 }) that.data.imgs.push(JSON.parse(res.data).data) that.setData({ 画像: that.data.imgs }) } }, 失敗: 関数 (err) { wx.showToast({ タイトル: 「アップロードに失敗しました」 アイコン: "なし", 期間: 2000 }) }, 完了: 関数 (結果) { コンソールログ(結果.errMsg) } }) } } }) }, // 画像を削除する deleteImg: function (e) { var that = これ wx.showModal({ タイトル: 「ヒント」、 内容:「削除」、 成功: 関数 (res) { (res.confirm)の場合{ (var i = 0; i < that.data.imgs.length; i++) { i == e.currentTarget.dataset.index の場合、i, 1 でデータイメージをスプライスします。 } that.setData({ 画像: that.data.imgs }) } そうでない場合 (res.cancel) { console.log("ユーザーがキャンセルをクリック") } } }) } ウィス 。包む { 幅: 100%; パディング: 0 30rpx; ボックスのサイズ: 境界線ボックス; } .wrap .img-wrap { フォントサイズ: 30rpx; 色: #33373E; 下部マージン: 10rpx; } .wrap .img-wrap .txt { 下部マージン: 20rpx; } .wrap .img-wrap .imglist { ディスプレイ: フレックス; flex-wrap: ラップ; } .wrap .img-wrap .imglist .item { 幅: 150rpx; 高さ: 150rpx; 右マージン: 22rpx; 下部マージン: 10rpx; 位置: 相対的; } .wrap .img-wrap .imglist .last-item { 幅: 150rpx; 高さ: 150rpx; テキスト配置: 中央; 行の高さ: 146rpx; 境界線: 2rpx 破線 #8B97A9; ボックスのサイズ: 境界線ボックス; } .wrap .img-wrap .imglist .item 画像 { 幅: 100%; 高さ: 100%; } .wrap .img-wrap .imglist .item .delete { 幅: 30rpx; 高さ: 30rpx; 位置: 絶対; 上: -14rpx; 右: -12rpx; } 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: Docker /var/lib/docker/aufs/mnt ディレクトリのクリーニング方法
>>: Linux (Centos7) に mysql8.0.18 をインストールするチュートリアル図
前回の記事では、Promise を使用して小さなプログラム wx.request をカプセル化する実...
Cocos Creator バージョン: 2.3.4デモのダウンロード: https://files...
目次1. まずRefとは何かを説明しましょう2. フックでのrefの使用1. HTMLDomフックで...
目次ここでの問題は次の通りです:解決策1:解決策2: コンストラクタで初期化を割り当てる採掘場の概要...
ネットで検索してみたところ、多くの面接でモバイル適応方法について質問されることが分かりました。最近い...
クラスタリングは、実際には InnoDB データベース エンジンに関連しています。したがって、インデ...
文字化けしたコードの問題は次のとおりです。 この問題の原因は非常に単純です。コマンドラインのエンコー...
テーブル名とフィールド–1. 学生リスト学生 (s_id、s_name、s_birth、s_sex)...
1. コマンド > と >> の違いコマンド>: ファイルが存在する場合は、...
目次1. プロトタイプとは何ですか? 2. プロトタイプ__プロト__ 4. コンストラクター5. ...
成果を達成する要件/機能: CSS + HTML を使用してハートを描く方法。分析:正方形と 2 つ...
著者 | 編集者 Awen | 制作 Tu Min | CSDN (ID: CSDNnews)不満を...
目次背景関数目的アイデアの源成し遂げるセット得るプロパティの削除拡張機能を禁止するもっている要約する...
効果を直接確認するために、リロード、左を閉じる、右を閉じる、その他の機能を閉じるなどの右クリック メ...
この記事は、参考のためにMySQL 8.0.18のインストールと設定のグラフィックチュートリアルを記...