HarmonyOS 网页唤起图片选择,文件选择框突兀

APP内嵌入网页(网页使用uniapp框架),网页选择图片上传,触发后弹起文件选择框,未让用户选择就直接进入了图库。导致用户选择图片返回后,还能看到选择框。

HarmonyOS
2024-12-25 14:32:26
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
superinsect

可以参考demo的实现:

// WebComponent.ets
import { webview } from '@kit.ArkWeb';
import { picker } from '@kit.CoreFileKit';
import { BusinessError } from '@kit.BasicServicesKit';

@Entry
@Component
struct WebComponent {
  controller: webview.WebviewController = new webview.WebviewController();

  build() {
    Column() {
      Web({ src: $rawfile('index.html'), controller: this.controller })
        .onShowFileSelector((event) => {
          console.log('MyFileUploader onShowFileSelector invoked');
          const documentSelectOptions = new picker.PhotoSelectOptions();
          let uri: string | null = null;
          const documentViewPicker = new picker.PhotoViewPicker();
          documentViewPicker.select(documentSelectOptions).then((documentSelectResult) => {
            console.log('[documentSelectResult]',JSON.stringify(documentSelectResult))
            console.log('[documentSelectResult]',JSON.stringify(documentSelectResult.photoUris[0]))
            uri = documentSelectResult.photoUris[0];
            console.info('documentViewPicker.select to file succeed and uri is:' + uri);
            if (event) {
              event.result.handleFileList([uri]);
            }
          }).catch((err: BusinessError) => {
            console.error(`Invoke documentViewPicker.select failed, code is ${err.code}, message is ${err.message}`);
          })
          return true;
        })
    }
  }
}

// index.html
<!DOCTYPE html>
  <html>
  <head>
  <meta name="viewport" content="width=device-width, initial-scale=1.0" charset="utf-8">
  </head>
  <body>
  <form id="upload-form" enctype="multipart/form-data">
  <input ref="album" type="file" id="upload" name="upload" accept="*/*" onchange="showPic()"/>
  <p id="image_preview">图片预览</p>
  <img id="image" width="100%"/>
  </form>
  </body>
  </html>
  <script>
  function showPic() {
    let event = this.event;
    let tFile = event ? event.target.files : [];
    if (tFile === 0) {
      document.getElementById('image_preview').style.display = 'block';
      document.getElementById('image_preview').innerHTML = "未选择图片";
      return
    }
    document.getElementById('image').setAttribute('src', URL.createObjectURL(tFile[0]));
    document.getElementById('image_preview').style.display = 'block';
    document.getElementById('image').style.display = 'block';
  }
  </script>
分享
微博
QQ
微信
回复
2024-12-25 16:43:45
相关问题
HarmonyOS photoAccessHelper选择图片问题
31浏览 • 1回复 待解决
HarmonyOS DocumentViewPicker选择文件问题
89浏览 • 1回复 待解决
HarmonyOS 选择图片,裁剪的功能
290浏览 • 1回复 待解决
HarmonyOS 如何实现文件选择功能?
235浏览 • 1回复 待解决
HarmonyOS 自定义图片选择界面
244浏览 • 1回复 待解决
HarmonyOS 图片选择器怎么实现
239浏览 • 1回复 待解决