vue移动端上传文件插件_vue+vux实现移动端文件上传样式

样式使用的是vux的cell组件 如下图的官方demo样子

上图的样式需要修改一下,把 保护中 修改成一个图片 并且内嵌一个input type=‘file'就可以拥有好看的样式的文件上传了

import { Cell } from 'vux'

下面我们要改造cell变成我们想要的结果

解释一下:

@是v-on的缩写;在组建中调用原声clik要加native;stop解释不清楚,请读者百度

input相当于隐藏了,再也看不到那么丑陋的样式了

i标签是图片,使用了fontawesome的样式,在main.js里边引入

import '../node_modules/font-awesome/css/font-awesome.min.css'

如果不使用fontawesome也可以添加样式

style="background: url("图标地址../../的形式");"

现在移动端的文件上传html+css已经写完了

js代码如下:

openFile(){

this.$refs.file.click();

}

解释一下:

html中给input绑定了一个属性ref = ‘file'我个人觉得相当于 给input赋值一个id

在通过this.$refs.file就相当于document.getElementById('file');这个都是vue特有的功能;比较特别的dom操作

然后click()方法就会打开文件;

至于@change()方法待续!!!这个方法不大众化,需要单独写!

以上所述是小编给大家介绍的vue+vux实现移动端文件上传样式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

时间: 2017-07-26

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用Vant的Upload组件和pdf.js库来实现移动端的PDF文件上传和预览功能。 首先,在你的Vue项目中安装Vant和pdf.js库: ``` npm install vant pdfjs-dist --save ``` 然后,在你的组件中引入Upload组件和pdf.js库: ```javascript <template> <div> <van-upload :max-count="1" :before-read="beforeRead" :after-read="afterRead" accept="application/pdf" :show-upload="false" > <van-button type="primary">上传文件</van-button> </van-upload> <div ref="pdfContainer"></div> </div> </template> <script> import { Upload, Button } from 'vant' import pdfjsLib from 'pdfjs-dist' export default { components: { VanUpload: Upload, VanButton: Button, }, methods: { beforeRead(file) { // 判断文件类型是否为PDF return file.type === 'application/pdf' }, afterRead(file) { // 读取文件并渲染PDF预览 const reader = new FileReader() reader.readAsArrayBuffer(file) reader.onload = () => { pdfjsLib.getDocument(new Uint8Array(reader.result)).promise.then(pdf => { pdf.getPage(1).then(page => { const canvas = document.createElement('canvas') const scale = 1.5 const viewport = page.getViewport({ scale }) const context = canvas.getContext('2d') canvas.height = viewport.height canvas.width = viewport.width page.render({ canvasContext: context, viewport }).promise.then(() => { this.$refs.pdfContainer.innerHTML = '' this.$refs.pdfContainer.appendChild(canvas) }) }) }) } }, }, } </script> ``` 在上面的代码中,我们使用了Vant的Upload组件来实现文件上传功能,并且设置了只能上传PDF文件。在afterRead方法中,我们使用pdf.js库来读取上传的PDF文件,并将PDF渲染到页面上。 需要注意的是,pdf.js库会异步加载PDF文件,因此我们需要在Vue组件中使用promise来处理异步操作。此外,为了在页面上显示PDF预览,我们需要使用canvas元素来渲染PDF页面。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值