Vue触发隐藏input file的方法

Posted wangjishu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vue触发隐藏input file的方法相关的知识,希望对你有一定的参考价值。

1、使用input透明覆盖法

  将input的z-index设置为1以上的数字并覆盖到需点击的内容上,将input的样式opacity设置为0(即为透明度为0),这样通过绑定在input上的change事件触发     ----推荐

<p class="uploadImg">
    <input type="file" @change="picUpload($event)" accept="image/*" />
</p>
.uploadImg 
    width: 100%;
    height: 1.46rem;
    position: relative;
    input 
      width: 1.46rem;
      height: 100%;
      z-index: 1;
      opacity: 0;
      position: absolute;
      cursor: pointer;
    

 

2、使用vue的ref参数直接操作input的点击事件触发

<div class="upload-btn-box">
  <Button @click="choiceImg" icon="ios-cloud-upload-outline" type="primary">点击上传</Button>
   <input ref="filElem" type="file" class="upload-file" @change="getFile">
</div>
choiceImg()
    this.$refs.filElem.dispatchEvent(new MouseEvent(‘click‘)) 
,
getFile()
    console.log("成功");

3、使用html的lable机制触发input事件

<label for="upfile" class="pTitleRight" @click="IDRecognition">
<span>身份证识别</span>
    <i class="iconfont">&#xe612;</i>
    <input ref="filElem" type="file" accept="image/*" id="upfile" name="upfile" style="display: none;" @change="uploadPic">
</label>
IDRecognition: function() ,    //触发事件  
uploadPic: function() 
  console.log(‘dsa‘);

  lable上的for属性绑定input的id,即可通过触发lable上的点击事件触发input的change事件    ----推荐

以上是关于Vue触发隐藏input file的方法的主要内容,如果未能解决你的问题,请参考以下文章

css:隐藏input file标签并触发点击上传文件事件

vue input标签隐藏使用label自定义样式

onchange监听input值变化及input隐藏后change事件不触发的原因与解决方法

onchange监听input值变化及input隐藏后change事件不触发的原因与解决方法(设置readonly后onchange不起作用的解决方案)

vue框架实现文件上传功能

vue input 输入框聚焦