图片上传并显示

js图片上传
<img :src="userInfo.avatar">
// type="file" 代表要上传的是个文件
// accept="image/*" 表示input所能接受的文件类型,我们要上传的是一个图片,所以前面是image开头的 * 代表任何类型的图片都可以 特定类型的话 image/.jpg,.png
// change事件是在找到图片之后点击确定/打开的时候才触发的
<input type="file" accept="image/*" @change="onChangeAvater"/>
onChangeAvater(e){
	// 对象可以把文件整理成数据提交给后台
	const formdata = new FormData()	// 其实就是一个空对象{} 
	// formdata.append 有这个方法 向里面添加一个file字段 {file:字段的值,要拿到那个input输入框,files[0]获取选中的第一张图片,files[1]获取选中的第二张图片} {file:xxxx}
	formdata.append("file",e.target.files[0])
	// 把参数传给我们后台的接口 http://120.53.31.103:84/api/app/img
	avater(formdata).then(res =>{
		// res.path返回一个新的图片路径 
		// http://120.53.31.103:84/api/app/user
		// 调用更新的接口 把最新的路径赋值给avatar
		this.user({avatar:res.path})
	})
}
element框架 图片上传

使用upload组件完成图片上传
在element.js中引入upload组件,并注册
因为upload组件进行图片上传的时候并不是使用axios发送请求
所以,我们需要手动为上传图片的请求添加token,即为upload组件添加headers属性

  // 在页面中添加upload组件,并设置对应的事件和属性
  // action			指定图片上传的地址
  // :on-preview 	当点击图片时会触发该事件进行预览操作,处理图片预览
  // :on-remove		当用户点击图片右上角的X号时触发执行
  // :on-success	当用户点击上传图片并成功上传时触发
  // list-type		设置预览图片的方式
  // :headers		设置上传图片的请求头
  // multiple		是否多选文件
  // drag			拖拽上传
  // before-remove	删除文件之前,会弹出一个confirm
<el-upload :action="uploadURL" :on-preview="handlePreview" :on-remove="handleRemove" :on-success="handleSuccess" list-type="picture" :headers="headerObj">
	<el-button size="small" type="primary">点击上传</el-button>
</el-upload>
// 在el-card卡片视图下面添加对话框用来预览图片
// 预览图片对话框
<el-dialog title="图片预览" :visible.sync="previewVisible" width="50%">
  <img :src="previewPath" class="previewImg" />
</el-dialog>

//在data中添加数据
data(){
  return {
    ......
    //添加商品的表单数据对象
    addForm: {
      goods_name: '',
      goods_price: 0,
      goods_weight: 0,
      goods_number: 0,
      goods_cat: [],
      //上传图片数组
      pics: []
    },
    //上传图片的url地址
    uploadURL: 'http://127.0.0.1:8888/api/private/v1/upload',
    //图片上传组件的headers请求头对象
    headerObj: { Authorization: window.sessionStorage.getItem('token') },
    //保存预览图片的url地址
    previewPath: '',
    //控制预览图片对话框的显示和隐藏
    previewVisible:false
  }
},
//在methods中添加事件处理函数
methods:{
  .......
  handlePreview(file) {
    //当用户点击图片进行预览时执行,处理图片预览
    //形参file就是用户预览的那个文件
    this.previewPath = file.response.data.url
    //显示预览图片对话框
    this.previewVisible = true
  },
  handleRemove(file) {
    //当用户点击X号删除时执行
    //形参file就是用户点击删除的文件
    //获取用户点击删除的那个图片的临时路径
    const filePath = file.response.data.tmp_path
    //使用findIndex来查找符合条件的索引
    const index = this.addForm.pics.findIndex(item => item.pic === filePath)
    //移除索引对应的图片
    this.addForm.pics.splice(index, 1)
  },
  handleSuccess(response) {
    //当上传成功时触发执行
    //形参response就是上传成功之后服务器返回的结果
    //将服务器返回的临时路径保存到addForm表单的pics数组中
    this.addForm.pics.push({ pic: response.data.tmp_path })
  }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值